AMI MOS Products Catalogue Winter 1979 # **EDGE INDEX** # 1 GENERAL INFORMATION AMI Sales Offices Domestic Distributors Domestic Reps International Reps Ordering Information Packaging Terms of Sale Product Assurance Program MOS Processes - 2 MEMORIES RAMs, ROMs and EPROMs - **3** S6800 FAMILY - **4** S2000 FAMILY - **5** S9900 FAMILY - 6 TELECOMMUNICATIONS - 7 CONSUMER INTERFACE PRODUCTS - 8 APPLICATION NOTES | Copyright@1978 American Microsystems, Inc. (All rights reserved.) | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Trade Marks Registered® | | Information furnished by AMI in this catalog is believed to be accurate and reliable. Devices sold by AMI are covered by the warranty and patent indemnification provisions appearing in its Terms of Sale. AMI makes no warranty, express, statutory, implied, or by description regarding the information set forth herein or regarding the freedom of the described devices from patent infringement. AMI reserves the right to change specifications and prices at any time and without notice. Advanced Product Desription means that this product has not been produced in volume, the specifications are preliminary and subject to change, and device characterization has not been done. Therefore, prior to designing any product into a system, it is necessary to check with AMI for current information. | | This estalog prepared for American Microsystems, Inc., by Briteday, Inc. | | | ## MOS/LSI is the Business of AMI ... and MOS/LSI is AMI's only business. The first company to produce commercial quantities of MOS circuits starting in 1966, AMI has ever since been among the leaders in circuit design, process technology and new product and market development. Today, the company is a major producer of standard products for the electronic data processing, telecommunications, and consumer product industries. DESIGN EXPERIENCE — Many areas of applications in which MOS is used today were pioneered with an AMI-designed device. This accumulated experience results in a line of high performance standard products and imaginatively designed, cost-effective custom circuits. PROCESS VERSATILITY — AMI's head start in the industry gives it a mature capability in every one of the major production processes: P-channel — high voltage and ion implanted metal gate, and silicon gate; N-channel — silicon gate, ion implanted silicon gate with depletion loads, high density and narrow geometry "H" MOS; and CMOS — metal and silicon gate, and high density, isoplanar silicon gate. AMI's new patented process, VMOS, is already producing high speed, low power state-of-the-art memory products. PRODUCTION CAPABILITY — AMI has three major facilities worldwide. Headquarters in Santa Clara, California has 327,000 square feet of office and manufacturing space and about 1,000 employees. Administration, R&D, the majority of the engineering staff, one of the company's two wafer fabrication facilities, pilot assembly and a final test facility are located there. The other major fabrication facility is at Pocatello, Idaho with 103,000 square feet and about 600 employees. The plant includes an engineering group, four fabricating lines and some final test activity. Located at Inchon, Korea is KMI, the company's major circuit assembly plant. It covers 116,000 square feet, employs about 1,300 persons. This combination of facilities can produce over 2,000,000 LSI circuits per month using the latest production equipment to maximize yields in today's more complex circuits. PRODUCT RELIABILITY — By designing reliability into the product — a standard procedure for AMI, the most experienced designer of custom MOS circuits — problems are minimized or climinated. Process control (and we run more processes than any other MOS manufacturer) is the second most important step in maintaining our reputation for reliability. Design and process control are buttressed by a closed feedback loop that continually collects AMI internal data and field data from our customers to analyze and solve design, layout and process problems. These activities are further supported by accelerated tests to determine failure rates and the activation energies for observed failure modes. IT'S STANDARD AT AMI — The company's dedication to the design and manufacture of high performance MOS/LSI products is reflected in the variety of products listed in this catalog. ## AMI and Made-to-Order MOS Since 1966, AMI has designed and manufactured over 1,000 custom MOS circuits. The largest design engineering staff in the industry has helped to keep AMI in the number one position among custom MOS producers. If your product can be controlled by an MOS circuit, and you plan to manufacture it in high volume, you should contact your nearest AMI Sales Office or the main office in Santa Clara, California. AMI will be happy to discuss the possibility of designing a custom circuit for your application, or manufacturing such a circuit from your tooling. # **Numerical Index** | Device | Page | Device | Page | Device | Page | |---------|---------|----------|------|--------|-------| | TCK 100 | . 7.9 | S2601 | 7.3 | S6820 | 3.2 | | S1103A | . 2.3 | S2709 | 7.2 | S6821 | 3.39 | | S1424A | . 7.2 | S2733 | 7.2 | S68A21 | 3.39 | | S1424C | , 7.2 | S2742 | 7.26 | S68B21 | 3.39 | | S1425A | . 7.2 | S2743 | 7.26 | S6830 | 2.3 | | S1427A | . 7.2 | S2811 | 6.39 | \$6831 | 2.3 | | S1856 | . 7.2 | S2900 , | 6.40 | S6831A | 2.41 | | S1883 | . 3.170 | S2901 | 6.40 | S6831B | 2.41 | | S1998A | . 7.2 | S3514 | 2.3 | S6831C | 2.3 | | S1998B | . 7.2 | S4006 | 2.3 | S6834 | 2.55 | | S10110 | . 7.2 | S4008 | 2.3 | S6840 | 3.53 | | S10111 | | S4015 , | 2.13 | S6846 | 3.68 | | S10129 | . 7.2 | S4017 | 2.16 | S6850 | 3.88 | | S10130 | . 7.2 | S4025 | 2.13 | S68A50 | 3.98 | | S10131 | | S4028 | 2.19 | S68B50 | 3.98 | | S10377 | . 7.2 | S4216B | 2.35 | S6852 | 3.109 | | S10430 | . 7.2 | S4264 | 2.38 | S6854 | 3.124 | | S2000 | . 4.1 | S4532 | | S68A54 | 3.124 | | S2000A | | S4716 | | S68047 | 3.147 | | S2114 | . 2.4 | S5101 | 2.20 | S68332 | 2.44 | | S2114H | | S5204A | 2.49 | S68488 | 3.159 | | S2147 | . 2.10 | S5232 | 2.3 | S8564 | 2.3 | | S2150 | . 4.2 | S50145 | 7.2 | S8771 | 2.3 | | S2150A | . 4.2 | S50240 | 7.2 | S8773 | 2.3 | | S2193 | . 7.2 | S50241 | 7.2 | \$8865 | 2.3 | | S2200 | . 4.2 | S50242 | 7.2 | S8890 | 7.2 | | S2200A | . 4.2 | S50243 | 7.2 | S8996 | 2.3 | | S2222 | . 2.2 | S50244 , | | S9260 | 7.13 | | S2222A | . 2.2 | S6508 | 2.25 | S9261 | 7.13 | | S2350 | . 3.171 | S6508A | 2.25 | S9262 | 7.19 | | S2400 | . 4.2 | S6518 | 2,30 | S9263 | 7.13 | | S2400A | . 4.2 | S6518A | 2.30 | S9264 | 7.13 | | S2559A | . 6.3 | S6800 | 3.3 | S9265 | 7.13 | | S2559B | . 6.3 | S68A00 | 3.3 | S9266 | 7.19 | | S2559C | | S68B00 | 3.3 | S9660 | 7.2 | | S2559D | . 6.3 | S6801 | 3.21 | S9900 | 5.3 | | S2560A | | S6802 | | S9901 | 5.33 | | S2560B | . 6.13 | S6809 | 3.31 | S9902 | 5.44 | | S2561 | . 6.21 | \$6810A | 3.32 | S9903 | 5.68 | | S2562 | . 6.29 | S6810A-1 | 3.32 | S9940 | 5.69 | | S2567 | . 7.2 | S68A10 | 3.36 | S9980 | 5.70 | | S2600 | . 7.3 | S68B10 | | \$9981 | 5.70 | ## **Functional Index** | Device | Page | Device | Page | Device | Page | |--------------------|--------|-------------------|---------|--------------------------|--------| | RAMs | | S6800 Microcomput | er | Telecommunication | | | S1103A | . 2.3 | Family | | S2559A | . 6.3 | | S2114 | 2.4 | S6800 | 33 | S2559B | | | S2114H | | S68A00 | | S2559C | | | | | S68B00 | | S2559D | | | S2147 | | | | | _ | | S2222 | | \$6801 | *** | S2560A | | | S2222A | | S6802 | | S2560B | | | S4006 | | \$6809 | | S2561 | | | S4008 | . 2.3 | S6810A | . 3.32 | S2562 | . 6.29 | | S4015 | . 2.13 | S6810A-1 | 3.32 | S2811 | . 6.39 | | S4017 | . 2.16 | S68A10 | . 3.36 | S2900 | 6.40 | | S4025 | | S68B10 | 3.36 | S2901 | | | S4028 | | \$6820 | | | | | S5101 | | S6821 | | | | | | | _ | | Remote Control Cir | cuits | | S6508 | | S68A21 , | | S2600 | . 7.3 | | S6508A | | S68B21 | | S2601 | | | S6518 | | S6830 | | S2742 | | | S6518A | | S6831 | | S2743 | | | S68A10 | . 3.36 | S6831A | 2.41 | 32140 | . 1.20 | | S68B10 | . 3.36 | S6831B | . 2.41 | Table Circles | | | | | S6831C | . 2.3 | Interface Circuits | | | ROMs | | S6834 | | (TouchControl) | | | S3514 | 2.3 | S6840 | | TCK100 | | | S4216B | | S6846 | | S9260 | . 7.13 | | . S4264 | | S6850 | | S9261 | . 7.13 | | | | | | S9262 | . 7.19 | | S5232 | | S68A50 | | S9263 | . 7.13 | | S6830 | | S68B50 | | S9264 | . 7.13 | | S6831 | | S6852 | | S9265 | | | S6831A | | S6854 | | S9266 | | | S6831B | | S68A54 | | 55200 | , 1.10 | | S6831C | | S68047 | | Onnon Cinosito | | | S68332 | . 2.44 | S68332 | . 2.44 | Organ Circuits<br>S10110 | 70 | | S8564 | . 2.3 | S68488 | . 3.159 | | | | S8771 | . 2.3 | | | S10111 | | | S8773 | . 2.3 | S2000 Family | | S10129 | | | S8865 | | S2000 | . 4.2 | S10130 | | | S8896 | | S2000A | . 4.2 | S10131 ., | . 7.2 | | 00000 | . 2.0 | S2150 | . 4.2 | S10377 | . 7.2 | | EDDOM. | | S2150A | . 4.2 | S10430 | . 7.2 | | EPROMs | 0.45 | S2200 | | S50145 | . 7.2 | | \$4532 | _ | S2200A | | S50240 | | | S4716 | | S2400 | | S50241 | | | S5204A | | _ | | S50242 | | | S6834 ., | . 2.55 | S2400A | . 4.2 | S50243 | | | | | S9900 Family | | | | | Character Generate | or | S9900 | 5.3 | S50244 | . 12 | | S8564 | . 2.3 | S9901 | | | | | | | | | Watch/Clock Circuit | te | | | | \$9902 | | S1424A | . 7.2 | | | | S9903 | | S1424C | | | | | S9940 | | S1425A | | | | | S9980 | | S1427A | | | | | S9981 | . 5.70 | S1856 | | | | | Data Co | | S1998A | | | | | Data Communicatio | п | | | | | | Circuits | 0.450 | \$1998B ,, | | | | | S1883 | | \$2709 | | | | | S2350 | . 3.171 | S2733 | . 7.2 | ## **General Information** **AMI Sales Offices** **Domestic Distributors** **Domestic Reps** **International Reps** **Ordering Information** **Packaging** **Terms of Sale** **Product Assurance Program** **MOS Processes** ### DOMESTIC ### Western Area 100 East Wardlow Rd., Suite 203 Long Beach, California 90807 Tel: (213) 595-4768 TWX: 910-341-7668 3800 Homestead Road Santa Clara, California 95051 Tel: (408) 249-4550 TWX: 910-338-0018 20709 N.E. 232nd Avenue Battleground, Washington 98604 ### Central Area Tel: (206) 687-3101 500 Higgins Road, Suite 210 Elk Grove Village, Illinois 60007 Tel: (312) 437-6496 TWX: 910-222-2853 Suite Number 204 408 South 9th Street Noblesville, Indiana 46060 Tel: (317) 773-6330 TWX: 810-260-1753 29200 Vassar Ave., Suite 303 Livonia, Michigan 48152 Tel: (313) 478-9339 TWX: 810-242-2903 ### 725 So. Central Expressway, Suite A-9 Richardson, Texas 75080 Tel: (214) 231-5721 (214) 231-5285 TWX: 910-867-4766 ### Eastern Area 237 Whooping Loop Altamonte Springs, Florida 32701 Tel: (305) 830-8889 TWX: 810-853-0269 1420 Providence Turnpike, Suite 220 Norwood, Massachusetts 02062 Tel: (617) 762-0726 TWX: 710-336-0073 20 Robert Pitt Drive, Room 212 Monsey, New York 10952 Tel: (914) 352-5333 TWX: 710-577-2827 Axe Wood East Butler & Skippack Pikes, Suite 230 Ambler Pennsylvania 19002 Tel: (215) 643-0217 TWX: 510-661-3878 ### INTERNATIONAL ### England AMI Microsystems, Ltd. 108 A Commercial Road Swindon, Wiltshire Tel: (793) 31345 or 25445 TLX: 851-449849 ### France AMI Microsystems, S.A.R.L. 124 Avenue de Paris 94300 Vincennes ,France Tel: (01) 374 00 90 TLX: 842-670500 ### Holland AMI Microsystems, Ltd. Calandstraat 62 Rotterdam, Holland Tel: 010-36 14 83 TLX: 844-27402 ### italy AMI Microsystems, S.p.A. Via Pascoli 60 20133 Milano Tel: 29 37 45 or 2360154 TLX: 843 32644 ### Japan AMI Japan Ltd. 502 Nikko Sanno Building 2-5-3, Akasaka Minato-ku, Tokyo 107 Tel: Tokyo 586-8131 TLX: 781-242-2180 AMI J ### West Germany AMI Microsystems, GmbH Rosenheimer Strasse 30/32, Suite 237 8000 Munich 80, West Germany Tel: (89) 483081 TLX: 841-522743 Rapifax: (89) 486591 ### ALABAMA Huntsville Resistaçap (205) 881-9270 ### ARIZONA Phoenix Kierulff (602) 243-4101 Sterling Electronics (602) 258-4531 R.V. Weatherford Co. (602) 272-7144 #### CALIFORNIA Anaheim R.V. Weatherford Co. (714) 634-9600 Glendale R.V. Weatherford Co. (213) 849-3451 Schweber Electronics (213) 537-4320 or (714).556.3880Los Angeles Kierulff (213) 685-5511 Palo Alto Rierulff (415) 968-6292 R.V. Weatherford Co. (415) 493-5373 R.V. Weatherford Co. (714) 623-1261 or (213) 966-8461 San Diego Intermark Electronics (714) 279-5200 Kierulff (714) 278-2112 R.V. Weatherford Co. (714) 278 7400 Santa Ana Intermark Electronics (714) 540-1322 or (213) 436-5275 Sunnyvale Intermark Electronics (408) 738-1111 Western Microtechnology (408) 737-1660 ### Kierulff (714) 731-5711 ### COLORADO Denver Kierulff (303) 371-6500 Englewood R.V. Weatherford Co. (303) 770-9762 Wheatridge Century Electronics (303) 424-1985 ### CONNECTICUT Danbury Schweber Electronics (203) 792 3500 Hamden Arrow Electronics (203) 248-3801 ### FLORIDA Ft. Lauderdale Arrow Electronics (305) 776-7790 Hollywood Schweber Electronics (305) 927-0511 Palm Bay Arrow Electronics (305) 725 1480 St. Petersburg Kierulff Electronics (813) 576-1966 ### GEORGIA Atlanta Schweber Electronics (404) 449-9170 Arrow Electronics (404) 455-4054 ### ILLINOIS Elk Grove Village Kierulff (312) 640 0200 Schweber Electronics (312) 593-2740 Schaumburg Arrow Electronics (312) 893-9420 Westmont R/M Electronics (312) 323-9670 ### INDIANA Indianapolis R/M Electronics (317) 247-9701 ### LOUISIANA Metairie Sterling Electronics (504) 887-7610 ## MARYLAND Baltimore Arrow Electronics (301) 247-5200 Gaithersburg Schweber Electronics (301) 840 5900 ### MASSACHUSETTS Natick Future Electronics Corp. (617) 237-6340 Waltham Schweber Electronics (617) 890-8484 Sterling Electronics (617) 894-6200 Wohurn Arrow Electronics (617) 933-8130 ### MICHIGAN Ann Arbor Arrow Electronies (313) 971-8220 Schweber Electronics (313) 525-8100 Wyoming R/M Electronics (616) 531-9300 ### MINNESOTA Bloomington Arrow Electronics (612) 887-6400 Schweber Electronics (612) 941-5280 ### NEW HAMPSHIRE Manchester Arrow Electronics (608) 668-6968 ### NEW JERSEY Moorestown Arrow Electronics (609) 235-1900 Perth Ambov Sterling Electronics (201) 442-8000 Saddlebrook Arrow Electronics (201) 797-5800 Somerset Schweber Electronics (201)469-6008 ### NEW MEXICO Albuquerque Century Electronics (505) 292 2700 Sterling Electronics (505) 345-6601 NEW YORK Farmingdale Arrow Electronics (516) 694-6800 Fishkill Arrow Electronics (914) 896-7530 Rochester Schweber Electronics (716) 424-2222 Westbury Schweber Electronics (516) 334-7474 ### NORTH CAROLINA Kernersville Arrow Electronies (919) 996-2039 оню ### Beechwood Schweber Electronics (216) 464-2970 Kettering Arrow Electronics (513) 253-9176 Solon Arrow Electronics (216) 248-3990 ### OREGON Beaverton Parrott (503) 641-3355 #### PENNSYLVANIA Schweber Electronics (215) 441-0600 ### TEXAS Dallas Component Specialities, Inc. (214) 357 6511 Schweber Electronics (214) 661-5010 Sterling Electronics (214) 357-9131 R.V. Weatherford Co. (214) 243-1571 Houston Component Specialities, Inc. (713) 771-7237 Schweber Electronics (713) 784-3600 Sterling Electronics (713) 627 9800 R.V. Weatherford Co. (713) 688-7406 UTAH Salt Lake City Century Electronics (801) 972-6969 Kierulff (801) 973-6913 ### VIRGINIA Richmond Sterling Electronics (804) 226-2190 ### WASHINGTON Seattle Kierulff (206) 575-4420 R.V. Weatherford Co. (206) 575-1340 WISCONSIN Oak Creek Arrow Electronics (414) 764-6600 ### CANADA Alberta Bowtek Electric Co. (403) 452-9050 British Columbia Vancouver Bowtek Electric Co. (604) 736-1141 Manitoba Winnepeg Bowtek Electric Co. (204) 633-9525 ### Ontario Downsview Cesco Electronics, Ltd. (416) 661-0220. Future Electronics Corp. (416) 663-5563 Cesco Electronics, Ltd. (613) 729-5118 Future Electronics Corp. (613) 820-9471 Quebec Montreal Cesco Electronics, Ltd. (514) 735 5511 Future Electronics, Corp. (514) 785-5775 Cesco Electronics, Ltd. (418) 524-4641 ALABAMA Huntsville Rep, Inc. Tel: (205) 881-9270 TWX: 810-726-2101 ARIZONA Phoenix Hecht, Henschen & Assoc., Inc. Tel: (602) 275-4411 TWX: 910-951-0635 CALIFORNIA Long Beach Application Representatives Tel: (213) 594-6608 TWX: 910-341-6599 Mt. View Thresum Associates, Inc. Tel: (415) 965-9180 TWX: 910-379-6617 San Diego Hadden Associates Tel: (714) 565-9445 TWX: 910-335-2057 COLORADO Parker R<sup>2</sup>Marketing Tel: (303) 841 5822 CONNECTICUT Orange CPS Corp. Tel: (203) 795-3515 GEORGIA Tucker Rep. Inc. Tel: (404) 938-4358 ILLINOIS Elk Grove Village Oasis Sales Tel: (312) 640-1850 TWX: 910-222-2170 INDIANA Ft. Wayne Technical Representatives, Inc. Tel: (219) 484-1432 Indianapolis Technical Representatives Tel: (317) 849-6454 TWX: 810-260-1792 IOWA Cedar Rapids Comstrand, Inc. Tel: (319) 377-1575 KENTUCKY Louisville Technical Representatives, Inc. Tel: (502) 451-9818 MARYLAND Baltimore Coulbourn DeGreif, Inc. Tel: (301) 247-4646 TWX: 710-236-9011 MASSACHUSETTS Lexington Circuit Sales Company Tel: (617) 861-0567 MINNESOTA Minneapolis Comstrand, Inc. Tel: (612) 788-9234 TWX: 910-576-0924 MISSOURI Grandview Beneke & McCaul Tel: (816) 765-2998 St. Louis Beneke & McCaul. Tel: (314) 434-6242 NEW YORK Clinton Advanced Components Tel: (315) 853-6438 Endicott Advanced Components Tel: (607) 785-3191 Melville Astroren, Inc. Tel: (516) 423-2266 TWX: 510-226-6147 NEW YORK North Syracuse Advanced Components Tel: (315) 699-2671 TWX: 710-541-0439 Scottsville Advanced Components Tel: (716) 889-1429 NORTH CAROLINA Raleigh Rep, Inc. Tel: (919) 851-3007 Centerville S.A.I. Marketing Tel:(513) 435-3181 TWX: 810-459-1647 Shaker Heights S.A.I. Marketing Tel: (216) 751-3633 TWX: 810-421-8289 Zanesville S.A.I. Marketing Tel: (614) 454-8942 OKLAHOMA Oklahoma City Ammon & Rizzos Tel: (405) 942-2552 OREGON Portland SD-R<sup>2</sup> Products & Sales Tel: (503) 246-9305 PENNSYLVANIA Pittsburgh S.A.I. Marketing Tel: (412) 782-5120 TEXAS Austin Ammon & Rizos Tel: (512) 454-5131 Dallas Ammon & Rizos Tel: (214) 233-5591 TWX: 910-860-5137 Houston Ammon & Rizos Tel: (713) 781-6240 TWX: 910-881-6382 TENNESSEE Jefferson City Rep, Inc. Tel: (615) 475-4105 TWX: 810-570-4203 Salt Lake City R<sup>2</sup> Marketing Tel: (801) 972-5646 TWX: 910-925-5607 VIRGINIA Charlottesville Coulbourn DeGreif, Inc. Tel: (804) 977-0031 WASHINGTON Bellevue SD-R<sup>2</sup> Products & Sales. Tel: (206) 747-9424 or (206) 624-2621 TWX: 810-443-2483 WISCONSIN Menomonee Falls Oasis Sales Tel: (414) 251-9431 CANADA Ottowa, Ontario Cantec Reps, Inc. Tel: (613) 225-0363 TWX: 610-562-8967 Point Claire, Quebec Cantec Reps, Inc. Tel: (514) 694-4049 Tlx: 58-22790 Toronto, Ontario Cantec Reps, Inc. Tel: (416) 675-2460 or 2461 TWX: 610-492-2655 AUSTRALIA Rifa Pty. Ltd. 202 Bell Street Preston, Victoria 3072 Tel: (03)480 1211 TLX: AA31001 BRAZII. Datronix Electronica Ltda. Av. Pacaembu, 746 - Conj. 11 Sao Paulo Tel: 209-0134 TLX: 391-1122372 CENTRAL AMERICA ROW, Inc. 3421 Lariat Shingle Springs, Calif. 95682 Tel: (916) 677-2827 ENGLAND Ritro Electronics (U.K.) Grefell Place Maidenhead Berkshire Tel: (0628) 36227 FINLAND OY Atomica AB PL 22 02171 Espoo 17 Tel: 80-423533 TLX: 12-1080 FRANCE Produits Electronique Professionals S.A.R.L. 2 · 4 Rue Barthelemy 92120 Montrouge Tel: 8353320 TLX: 204534 HOLLAND AMI Microsystems, Inc. Calandstraat 62 Rotterdam Tel: 010-36 14 83 TLX: 844-27402 HONG KONG Apcom Systems, Ltd. 1201 Kimberly Center 35 Kimberly Road Kowloon Tel: 3-694659 TLX: 64095 INDIA **ROW** International 149 Kimble Rd. Los Gatos, Calif. Tel: (408) 354-7698 CVS Technologies (1974) Ltd. 9 Jobotinsky St. Box 946 Bnei Brak Tel: 799156 TLX: 341109 ITALY Paolo Meoni & Associates Giovanni Pascoli 60 20133 Milano Tel: 29 37 45 TLX: 843-32644 **JAPAN** Micro-Systems, Inc. 15-29 Mita 4-Chome Minato-ku, Tokyo 108 Tel: (03) 452-4994 Matsushita Electric Trading Company, Ltd. 71, 5-Chome, Kawaramachi Higashi-ku Osaka Tel: (06) 204-5510 TLX: 781-63417 MALAYSIA Dynamar International Ltd. 208 Shaw House, Orchard Rd. Singapore 9, Tel: 2351139 TLX: RS26283 MEXICO ROW, Inc. 3421 Lariat Shingle Springs, Calif. 95682 Tel: (916) 677-2827 NEW ZEALAND David P. Reid (NZ) Ltd. Box 2630, Auckland 1 Tel: 492-189 TLX: 791 2612 SINGAPORE Dynamar International Ltd. 208 Shaw House, Orchard Rd. Singapore 9 Tel: 2351139 TLX; RS 26283 SOUTH AFRICA Tecnetics P.O. Box 56310 Pinegowrie 2123, Transvaal Johannesburg Tel: 48-5712 TLX: 960-80838 SOUTH AMERICA ROW, Inc. 3421 Lariat Shingle Springs, Calif. 95682 Tel: (916) 677-2827 **SWEDEN** A.B. Rifa Fack, S-16300 Spanga Tel: (08) 751 00 20 TLX: 13690 SWITZERLAND W. Moor AG Bahnstrasse 58. 8105 Regensdorf Zurich Tel: (01) 8406644 TLX: 52042 TAIWAN Dynamar (Taiwan) Ltd. 2nd Flr., No. 14, Lane 164 Sung Chiang Road Taipei, 104 Tel: 541-8252 thru 54 TLX: 785-11064 WEST GERMANY Aktiv Electronics GmbH Leonorenstrasse 49 D-1000 Berlin 46 Tel: (030) 771 4408 TLX: 185327 Gustav Beck KG Eltersdorfer Strasse 7 8500 Nurnberg 15 Tel: (0911) 34966 TLX: 622334 Ultratronik Munchenerstr, 6 D-8031 Oberalting-Seefeld Tel: (08152) 7696 TLX: 526459 Ditronic, GmbH Im Asemwald 48 D-7000 Stuttgart 70 Tel: (0711) 724844 TLX: 7255638 Miktrotec, GmbH Johannesstr. 91 D-7000 Stuttgart 1 Tel: (0711) 22807 TLX: 722818 YUGOSLAVIA Iskra Standard Celovska 122 61000 Ljubljana Tel: (061) 551093 TLX: 31300 YU-ISKRA Any product in this MOS Products Catalog can be ordered using the simple system described below. With this system it is possible to completely specify any standard device in this catalog in a manner that is compatible with AMI's order processing methods. The example below shows how this ordering system works and will help you to order your parts in a manner that can be expedited rapidly and accurately. All orders (except those in sample quantities) are normally shipped in plastic carriers or aluminum tube containers, which protect the devices from static electriticy damage under all normal handling conditions. Either container is compatible with standard automatic IC handling equipment. Any device described in this catalog is an AMI Standard Product. However, ROM devices that require mask preparation or programming to the requirements of a particular user, devices that must be tested to other than AMI Quality Assurance standard procedures, or other devices requiring special masks are sold on a negotiated price basis. Device Number — prefix S, followed by four (or five\*) numeric digits that define the basic device type. If there are versions to the basic device, the numeric digits will be followed by additional alphanumeric digits, in this example A-1. The last digit should always be followed by a space. Package Type — a single letter designation which identifies the basic package type. The letters are coded as follows: P - Plastic package E - Cer-DIP package S - SLAM package C - Ceramic (three-layer) package T-TO type package \*Organ Circuits ### PLASTIC PACKAGE The AMI plastic dual-in-line package is the equivalent of the widely accepted industry standard, refined by AMI for MOS/LSI applications. The package consists of a plastic body, transfer-molded directly onto the assembled lead frame and die. The lead frame is Kovar or Alloy 42, with external pins tin plated. Internally, there is a 50µin, gold spot on the die attach pad and on each bonding fingertip. Gold bonding wire is attached with the thermocompression gold ball bonding technique. Materials of the lead frame, the package body, and the die attach are all closely matched in thermal expansion coefficients, to provide optimum response to various thermal conditions. During manufacture every step of the process is rigorously monitored to assure maximum quality of the AMI plastic package. Avaliable in: $\mathbf{8}$ , $\mathbf{14}$ , $\mathbf{16}$ , $\mathbf{18}$ , $\mathbf{22}$ , $\mathbf{24}$ , $\mathbf{28}$ and $\mathbf{40}$ pin configurations. ### Cer-DIP PACKAGE The Cer-DIP dual-in-line package has the same high performance characteristics as the standard three-layer ceramic package, yet approaches plastic in cost. It is a military approved type package, with excellent reliability characteristics. Although the Cer-DIP concept has been around for a number of years, AMI leads the technology with this package, having eliminated the device instability and corrosion problems of earlier Cet-DIP processes. The package consists of an Alumina $(Ai_2O_3)$ base and the same material lid, hermetically fused onto the base with low temperature solder glass. Inert gasses are sealed inside the die cavity. Available in: 16, 18, 22, 24, 28 and 40 pin configurations. ### SLAM PACKAGE The SLAM (single layer metallization) dual-in-line package is an AMI innovation that offers a lower cost alternative to three-layer ceramic packages, without sacrifice of performance or reliability. The SLAM package uses the same basic materials as ceramic, but is constructed in a simpler and thereby more reliable manner. It uses a 96% Alumina base, one basic refractory metallization layer, coated with an Alumina passivation layer, and brazed-on Kovar leads. The leads are suitable for either socket insertion or soldering. Either a ceramic or a Kovar lid is used to hermetically seal the package. The ceramic lid is attached with an epoxy resin sealant, but a gold-silicon eutectic solder is used for Kovar lids. Avaliable in: various 14 to 40 pin configurations. **EPOXY SEAL PACKAGE** ### CERAMIC PACKAGE Industry standard high performance, high reliability package, made of three layers of $Al_2O_3$ ceramic and nickel-plated refractory metal. Either a low temperature glass sealed ceramic lid or a gold tin eutectic sealer Kovar lid is used to form the hermetic cavity of this package. Package leads are available with gold over nickle or tin plating for socket insertion or soldering. ACCEPTANCE THE FROMS OF SALE CONTAINED HERREIN APPLY TO ALL OUR TATHONS MADE AND PURCHAST DIBINES ENTERED INTO BY THE SPELER SOME OF THE TERMS SET OUT HER BAND DIFFELL HOM THOSE IN BUYER'S PURCHASE ORDER AND SOUR MAY BE NEW THIS ACCEPTANCE IS CONDITIONAL ON BUYER'S PASSENT TO THE TRANSSET OUT HERE IN LIEU OF THOSE IN RUYER'S PURCHASE ORDER SET OUT HERE IN LIEU OF THOSE IN RUYER'S PURCHASE ORDER AND COMMUNICATION FROM BUYER SHALL NOT BE DEEMED A WAIVER OF THE PROMISIONS OF THIS ACCEPTANCE. AND CHANGES IN THE LIEWS CONTAINED IS ADDITIONAL OF THE PROMISIONS OF THIS ACCEPTANCE. AND CHANGES IN THE LIEWS CONTAINED HEREIN MUST SPECIFICALLY BE AGREED TO IN WRITING BY AN OFFICER OF THE SELLER BEFORE BECOMING BINDING OF THIS SELLER BEFORE BECOMING BINDING OF THIS SELLER BEFORE BECOMING BINDING OF THE BUYER. All orders of contained the appropriate of accounted by the Self as dischoole office These terms shall all appropriate whether one things the state of the one discharge and acknowledged maskly are from eight support of a subject of a state of the propriate of the reference of other propriates. #### 2. PAYMENT Lift Unless otherwise agreed, a fill rivoldes are thut and pavable thirty (30) days from date of involve. Moridisculants are authorized. Shipments, achieving, and performance of work shall still times be subject to the approval of the Salter's credit department and the Salter has the decline to make any shipment or deliveries or perform any work excess appointed by private the upon terms and confidence at the other salters are performed. and conditions or security satisfactory to such disparchient. (O) If, in the judgment of the Seller, the financial condition of the Bover at any time does not justify continuation of production or shipment on the terms of payment originally specified, the Seller may require full or partial payment in accounce and, in the event of the Seller may require full or partial payment in event any proceeding is brought by or against the Boyer under the teat kniptcy or insoftwork laws, the Seller shall be entitled to cancer any proceeding to the full be entitled to cancer any order then constanting and shall receive reimborrement for its concellation changes. (c) Fach thipmont shall be considered a separate and independent transaction, and payment therefor shall be made accordingly. If showness are delayed by the Buyer, payments shall become due on the date when the Selfer's prepared to make at prients. If the work covered by the purchase order is delayed by the Buyer, payments shall be maile based on the purchase order is delayed by the Buyer, by the products held for the Buyer shall be at the risk and expense of the Buyer. - 3. TAXES: Unless otherwise provided herein, the amount of any potential or future was revinue excised other taxes, test, or other charges of any nature, imposed by any public auditionity, instoner state, local or other, applicable to the anothers covered by this order, or the manufacturer or safe chereof, shall be added for the purchase price and shall be paid by the Buyer, or in less thereof, the Buyer shall showed the Seffer with a tex exemption certificate acceptable to the taxing authority. - 4 F.O.B. POINT: All sales or made F.O.B. point of supment. Select's trip passes to Buyer, and Seller's liability as to delivery ocases upon making delivery of material purchased heroundor to carrier of shipping soint, the carrier acting as Buyer's agent. All claims for domages must be filed with the carrier. Shipments will normally be made by Parcel Fost, Ballway Express, Arr Express, or Air Freight. Ubdess specific instructions from Buyer specify which of the foregoing methods of shipment is to be used, the Seller will exercise but eavy discretion. - 5. DELIVERY: Shipping dates are approximate and are based upon promot receipt from Buyer of all necessary information. In no event will seller be fable for any re-procurement costs, not for datay or non-delivery, due to causes beyond its reasonable control including, but not limited to, acts of Gou, acts of cut or infirstry authority, profites, fires, strikes, lock-outs, slow-downs, shorteses, factory or labor conditions, errors in manufacture, and inability due to quiese beyond the Seller's reasonable control to obtain necessary labor, materials, or manufacturing facilities. In the event of any such delay, the cate of helivery shall, as the request of the Seller, be deferred for a period equal to the time lost by reason of the fellow. In the event Seller's production is curtailed for any of the above crasons so that Seller cannot deliver the full amount refeased hereunder. Seller may allocate production deliveries an only its verious customers then under contract for smill goods. The allocation will be made in a commerciafly fair and responsible mainer, When allocation was been made, Boyer will be notified of the estimated quipta made available. 6. PATENTS: The Buyer shall hold the Seller hamiless against any expense or loss resulting from infringement of patents, trademarks, or unifair competit or arising from compliance with Buyer's despits, specifications, or instructions. This sale of products by the Seller does not convey any license, by implication, escoppe or intrevivus, unifair patent claims powering combinations of said products with other devices or elements. Except as otherwise provided in the preciding paragraph, the Seller shall detend any suit or procededing brought against the Buyer, so far as based on a claim that any product, or any part thereof, furnished under this contract constitutes an infiningement of any patent of the United States, if notified promptly in writing and given institutions, information, and assistance for the Seller's expensel for offense of same, and the Seller shall pay all damages and costs awarded therein against the Buyer. In case said product, or any purt thereof, is, in such surf, held to constitute infiningement of patent, and the use of said product is error ned, the Seller's shall act so own expense, either produce of or the Buyer the right to continuous aid product on pair, replace same with non-infringing product, modify it so it becomes unon-infringing, or remove stild product and reflund the purchase price and the transportation and installation costs thereof. In no event shall Seller's total liability to the Buyer under or a result of compliance with the provisions of this paragraph excess the agregate some paid by the Buyer for the allegedly infringing product. The foregoing states the antire liability of the Seller for patent infringement by the said products or any part thereof. THIS PROVISION IS STATED IN LIFU OF ANY OTHER EXPRESSED, IMPLIED, OR STATILTORY WARRANTY AGAINST INFRINGEMENT AND SHALL BE THE SOLE AND EXCLUSIVE REMEDY FOR PATENT INFRINGEMENT OF ANY SIND. - 7 INSPECTION. Unlins other easy specified and agreed upon, the manifeld to be forms rad imper this popular shall be subject to the Select's standard impercion at the place of immufacture. If it is belief speed upon and specified in this eader can Bayor is to inspect or provide for impertion at obacc of manifecture such inspection also be to conducted as to not interfere unreasonably worth Selfer's operations and consequent approval or relection shall be made before shipment of the material. Note instand, or the foregoing of, uson relegion of such material by Buyer, the same shall appear not to conform to the contract, the Buyer shall presentedly notify the Selfer's fact such conditions and affect dithe Selfer's consent. Selfer's Return Material Authorization form must accompany seen determined materials. - 8. WARRANTY: The Selfer variants that the products to be delivered under this processo order will be their from delects in material and workmanship under regimal use and service. Selfer's obligations order this Warranty are financed to realisting or tropaling or giving credit for, at its option, at its factory, any of said products which shall, within and fill year after shipment, be returned to the Selfer's factory of origin, transportation charges prepare, and which are, after examination, displaced to the Selfer's statistication to be this defective. THIS WARRANTY 'S EXPRESSED IN LIEU OF ALL OTHER WARRANTES, EXPRESSED STATUTORY, OR IMPLIED, INCLUDING THE IMPLIED WARRANTES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND OF ALL OTHER OBELIGATIONS OR LIABILITIES ON THE SELLER'S PART, AND IT NETTHER ASSUMES NOR AUTHORIZES ANY OTHER "ERSON TO ASSUME FOR THE SELLER ANY OTHER LIABILITIES IN CONNECTION WITH THE SALE OF THE SAID ARTICUSES. This Warranty shall not deplay to any of such products which shall have been repaired or altered, except by the Seller, or which shall have been subjected to inside, original warranty period of any product which has either been repaired or inerical by Seller. In is uniferstand that if this order calls for the delivery of semiconductor devices which are not finished and fully encapsulated, that no warranty, statutory, expressed or implied, including the implied warranty of inerchantability and it is nest for a particular purpose, shall apply. All such devices are sold as is where is. #### 9. GENERAL: (a) The validity, performance and construction of these terms and all sales frequency shall be governed by the laws of the State of California. (b) The Seller represents that with respect to the profitchion of articles and/or performance of the services covered by this order it will finity comply with all requirements of the Fair Labor Standerds Act of 1938, as amended, Williams Steiger Occupational Sarety and Health Act of 1970, Executive Orders 19376 and 19246. Section 202 and 704. (c) In no event shall Seller be fiable for consequential or special damages. (d) The Buyer may not unilaterally make changes in the drawings, distinct specifications for the items to be furnished hereunder without Seller's prior consent. (e) Except to the extent provided in Paragraph 10, below, this order is not subject to cancellation or termination for convenience. (f) Briver acknowledges that all or part of the products point-asset hereunder may be manufactured and/or assembled at any of Soller's facilities, thomastic or foreign. (g) In the evens that the cost of the products are increased as a result of increases in materials, labor costs, or duties, Seller into take the price of the products to gover the cost increases. (h) It Buyer is in broach of its obligations under this order. Buyer shall remain liable for all unipend charges and sums due to Sellie and will reimburss. Seller for all damages suffered or incurred by Solier as a result of Buyer's broach. The remedies promided herein shall be in section to all other legal means and remed as available to Sellie. 10. GOVERNMENT CONTRACT PROVISIONS: If Buyer's original purchase order indicates by contract in mer, that it is placed under a government contract, only the tollowing provisions of the current Armed Services Produrement Regulation are applicable in accordance with the terms thereof, with an appropriate substruction of purities, as the case may be in its, "Contracting Officer" shall mean "Buyer", "Contractor" shall mean "Seller", and the term "Contract" shall mean this order. 2-103.1, Definitions: 7-103.3, Extras: 7-103.4, Variation in Quantiny: 7-103.8, Assignment of Claims; 7-103.9, Additional Band Sacurity, 7-103.13, Renegotation: 7-103.15, Phodesis and Certain Germanist Areas: 7-103.16, Contract Work Hours and Safety Standards Act. Overtine Compensation; 7-103.17, Watsh Healey Public Contracts Act. 7-103.18, Equal Opportunity Clause: 7-103.19, Ottician Not to Benefit; 7-103.20, Covernant Against Contingent Fee; 7-103.21, Terrimostion for Convenience of the Government (anity to the extent that Bayer's contract; is terminated for the convenience of the government; 7-103.22, Authorization and Consent, 7-103.23, Notice and Assistance Regarding-Patert Infringement; 7-103.24, Responsibility for Inspection, 7-103.25, Commercial Bills of Lading Covering Shipments Under FO3 Origin Contracts; 7-104.27, Listing of Employment Openings; 7-104.4, Notice to the Government of Labor Disputes; 7-104.1, Excess Profit, 7-404.15, Examination of Records by Comptrolis Genera; 7-104.20, Utilization of Labor Surplus Area Concent. ### INTRODUCTION Quality is one of the most used, least understood, and variously defined assets of the semiconductor industry. At AMI we have always known just how important effective quality assurance, quality control, and reliability monitoring are in the ability to deliver a repeatably reliable product. Particularly, through the manufacture of custom MOS/LSI, experience has proved that one of the most important tasks of quality assurance is the effective control and monitoring of manufacturing processes. Such control and monitoring has a twofold purpose: to assure a consistently good product, and to assure that the product can be manufactured at a later date with the same degree of reliability. To effectively achieve these objectives, AMI has developed a Product Assurance Program consisting of three major functions: - Quality Control - · Quality Assurance - · Reliability Each function has a different area of concern, but all share the responsibility for a reliable product. ### The AMI Product Assurance Program The program is based on MIL-STD-883, MIL-M-38510, and MIL-Q-9858A methods. Under this program, AMI manufactures highest quality MOS devices for all segments of the commercial and industrial market and, under special adaptations of the basic program, also manufactures high reliability devices to full military specifications for specific customers. The three aspects of the AMI Product Assurance Program — Quality Control, Quality Assurance, and Reliability—have been developed as a result of many years of experience in MOS device design and manufacture. Quality Control establishes that every method meets, or fails to meet, product parameters - QA checks results. Quality Control establishes that every method meest, or fails to meet, processing or production standards -QC checks methods. Reliability establishes that QA and QC are effective - Reliability checks device performance. One indication that the AMI Product Assurance Program has been effective, is that NASA has endorsed AMI products for flight quality hardware since 1967. The Lunar Landers and Mars Landers all have incorporated AMI circuits, and AMI circuits have also been utilized in the Viking and Vinson programs, as well as many other military airborne and reconnaissance hardware programs. ### QUALITY CONTROL The Quality Control function in AMI's Product Assurance Program involves constant monitoring of all aspects of materials and production, starting with the raw materials purchased, through all processing steps, to device shipment. There are three major areas of Quality Control: - Incoming Materials Control - Microlithography Control - Process/Assembly Control ### Incoming Materials Control All purchased materials, including raw silicon, are checked carefully to various test and sampling plans. The purpose of incoming materials inspection is to ensure that all items required for the production of AMI MOS circuits meet such standards as are required for the production of high quality, high reliability devices. Incoming inspection is performed to specifications agreed to by suppliers of all materials. The Quality Control group continuously analyzes supplier performance, performs comparative analysis of different suppliers, and qualifies the suppliers. Tests are performed on all direct material, including packages, wire, lids, eutectics, and lead frames. These tests are performed using a basic sampling plan in accordance with MIL-S-19500, generally to a Lot Tolcrance Percent Defective (LTPD) level of 10%. The AQL must be below 1% overall. Two incoming material inspection sequences illustrate the thoroughness of AMI Quality Control: - Purchased packages are first inspected visually. Then, dimensional inspections are performed, followed by a full functional inspection, which subjects the packages to an entire production run simulation. Finally, a full electrical evaluation is made, including checks of the insulation, resistance, and lead-to-lead isolation. A package lot which passes these tests to an acceptable LTPD level is accepted. - Raw silicon must also pass visual and dimensional checks. In addition, a preferential etch quality inspection is performed. For this inspection, the underlayers of bulk silicon are examined for potential anomalies such as dislocation, slippage, or etch pits. Resistivity of the silicon is also tested. ### Microlithography Control Microlithography involves the processes which result in finished working plates, used for the fabrication of wafers. These processes are pattern or artwork generation, photoreduction, and the actual printing of the working plates. ## **Product Assurance Program** Pattern generation now is the most common practice at AMI. The circuit layout is digitized and stored on a tape, which then is read into an automated pattern generator, which prints a highly accurate 10x reticle directly. In cases where the more traditional method of artwork generation is used whether Rubylith, Gerber Plots, AMI generated or customer generated — the artwork is thoroughly inspected. It is checked for level-to-level registration and dimensional tolerances. Also, a close visual inspection of the workmanship is made. AMI artwork is usually produced at 200x magnification and must conform to stringent design rules, which have been developed over a period of years, as part of the process control requirements. Acceptable artwork is photographically reduced to a 20x magnification, and then further to a 10x magnification. The resulting 10x reticles are then used for producing 1x masters. The masters undergo severe registration comparisons to a registration master and all dimensions are checked to insure that reductions have been precise. During this step, image and geometry are scrutinized for missing or faded portions and other possible photographic omissions. For a typical P-channel silicon gate device, master sets are checked at all six geometry levels in various combinations against each other and against a proven master set. Allowable deviations within the die are limited to 0.5 micron, deviations within a plate are limited to 1 micron, and all plate deviations are considered cumulatively. Upon successful completion of a device master set, it is released to manufacturing where the 1x plates are printed. A sample inspection is performed by manufacturing on each 30-plate lot and the entire lot is returned to Quality Control for final acceptance. Quality Control performs audits on each manufacturing inspector daily, by sample inspection techniques. The plates can be rejected first by manufacturing, when the 30-plate lots are inspected, or by Quality Control when the lots are submitted for final acceptance. If either group rejects the plates, they are rescreened and then undergo the same inspection sequence. In the rescreening process, the plates undergo registration checks; visual checks for pin holes, protrusions, and faded or missing images, as well as all critical dimension checks. ### Process Control Once device production has started in manufacturing, AMI Quality Control becomes involved in one of the most important aspects of the Product Assurance Program — the analysis and monitoring of virtually all production processes, equipment, and devices. Process controls are performed in the fabrication area, by the Quality Control Fabrication Group, to assure adherence to specifications. This involves checks on operators, equipment and environment. Operators are tested for familiarity with equipment and adherence to procedure. Equipment is closely checked both through calibration and maintenance audits. Environmental control involves close monitoring of temperature, relative humidity, water resistivity and bacteria content, as well as particle content in ambient air. All parameters are accurately controlled to minimize the possibility of contamination or adverse effects due to temperature or humidity excesses. Experience has proven that such close control of the operators, equipment, and environment is highly effective towards improved quality and increased yields. In addition to the specification adherence activities of the QC Fabrication Group, a QC Laboratory performs constant process monitoring of virtually every step of all processes. Specimens are taken from all production steps and critically evaluated. Sampling frequency varies, depending on the process, but generally, oxidation, diffusion, masking, and evaporization are the most closely monitored steps. Results are supplied both to manufacturing and engineering. When evidence of a problem occurs, QC provides recommendations for corrections and follows up the corrective action taken. Optical inspections are performed at several steps; quality control limits are based on a 10% LTPD. The chart-in Figure 1 shows process steps and process control points. ### QUALITY ASSURANCE The Quality Assurance function in the Product Assurance Program involves checking the ability of manufactured parts to meet specifications. In addition, the QA group also is responsible for calibration of all equipment, and for the maintenance of AMI internal product specifications, to assure that they are always in conformance with customer specifications, or other AMI specifications. After devices undergo 100% testing in manufacturing, they are sent to Quality Assurance for acceptance. Lots are defined, and using the product specifications, sample sizes are determined, along with the types of tests to be performed and the test equipment to be used. Lots must pass QA testing either with an LTPD or 10%, or less, if the specification requires tighter limits. Three types of tests are performed on the samples: visual/mechanical, parametric, and functional. All tests are performed both at room temperature and at elevated temperature. In addition, a number of other special temperature tests may be performed, if required by the specification. Generally, high temperature tests are at 125°C. To perform the tests, QA uses AMI PAFT test systems, ROM test systems, Macrodata testers, Fairchild Sentry systems, Figure 1. Flowchart of Product Assurance Program Implementation Western Digital Spartan systems, Impact testers, and various bench test units. In special instances a part may also be tested in a real life environment, in the equipment which is to finally utilize it. If a lot is rejected during QA testing, it is returned to the production source for an electrical rescreening. It is then returned to QA for acceptance, but is identified as a resubmitted lot. If it fails again, it is discarded and corrective action in engineering is initiated. As evidence of the problem is detected, the parts may also be traced all the way back to the wafer run, to analyze the cause. When a lot is acceptable, it is sent to packaging and then to finished goods. When parts are sent from finished goods, they are again checked by the QA group to a 10% LTPD, with visual/mechanical tests. Also, all supporting documentation for the parts is verified, including QA acceptance, special customer specifications, certificates of compliance, etc. Only after this last check are devices considered ready for plant clearance. If there are customer returns, they are first sample tested by QA, to determine the cause of the return. (Many times an invalid customer test will incorrectly cause returns.) After QA evaluates all returns, they are sent to Reliability for failure analysis. ### RELIABILITY The Reliability function in the Product Assurance Program involves process qualification, device qualification, package qualification, reliability program qualification, and failure analysis. To perform these functions AMI Reliability group is organized into two major areas: - Reliability Laboratory - Failure Analysis ### Reliability Laboratory AMI Reliability Laboratory is responsible for the following functions: - · New Process Qualification - Process Change Qualification - Process Monitoring - New Device Qualification - Device Change Qualification - New Package Qualification - Device Monitoring - Package Change Qualification - Package Monitoring - High Reliability Programs There are various closely interrelated and interactive phases involved in the development of a new process, device, package, or reliability program. A process change may affect device performance, a device change may affect process repeatability, and a package change may affect both device performance and process repeatability. To be effective, the Reliability Laboratory must monitor and analyze all aspects of new or changed processes, devices, and packages. It must be determined what the final effect is on product reliability, and then evaluate the metits of the innovation or change. ### Process Qualification For example, AMI Research and Development group recommends a new process or process alteration when it feels that the change can result in product improvement. The Reliability Laboratory then performs appropriate environmental and electrical evaluations of new process. Typically, a special test vehicle, or "rel chip", generated by R&D during process development, is used to qualify the recommended new process or process change. The rel chip is composed of circuit elements similar to those that may be required under worst-case circuit design conditions. The rel chip elements are standard for any given process, and thus allow precise comparisons between diffusion runs. The following is an example of what is included on a typical rel chip: - · A discrete inverter and an MOS capacitor - · A large P-N junction covered by an MOS capacitor - A large P-N junction area (identical to the junction area above, but without the MOS capacitor) - A large area MOS capacitor over substrate - Several long contact strings with different contact geometries. - Several long conductor geometries, which cross a series of eight deeply etched areas. Each circuit element of a rel chip allows a specific test to be performed. As an example, the discrete inverter and MOS load device accommodate power life tests. As a consequence, any type of parameter drift can be observed. The MOS capacitor, covering the large P-N junction, can serve to indicate the presence of contamination in the oxide, under the oxide, or in the bulk silicon. If unusual drift is evidenced, the location of contamination can be determined through analysis of the additional MOS capacitor and the large P-N junction area. The metal conductor interconnecting contacts is useful for life testing under relatively high current conditions. It facilitates the detection of metal separation when moisture or other contaminants are present. The conductors crossing deeply etched areas allow the checking of process control. Rather than depending upon optical inspection of metal quality, burned out areas caused by high currents are readily identified and provide a quantitative measure of metal quality. If the Reliability Laboratory determines that a recommended new process or process change is viable for manufacturing purposes, further analysis is necessary to determine that production devices can be manufactured in high volume, in a repeatable and reliable manner. ### Process Monitoring In addition to process qualification, the Reliability group also conducts ongoing process monitoring programs. Once every 90 days each major production process is evaluated using relichips as test vehicles. The resulting test data is analyzed for parameter limits and process stability. In this manner AMI can help assure repeatability and high product quality. ### Package Qualification New packages are also qualified before they are adopted. To analyze packages, a qualification matrix is designed, according to which the new package and an established package (used for control) are tested concurrently. The test matrix consists of a full spectrum of electrical and environmental stress tests, in accordance with MIL-STD-883. ### Failure Analysis Another important function of the Reliability group is failure analysis. Scanning electron microscopes, high power optical microscopes, diagnostic probe stations, and other equipment is used in failure analysis of devices submitted from various sources. It is the function of the Reliability group to determine the cause of failure and recommend corrective action. The Reliability group provides a failure anlaysis service for the previously mentioned in-house programs and for the evaluation of customer returns. All AMI customers are provided a failure analysis service for any part that fails within one year from date of purchase and the results of the analysis are returned in the form of a written report. ### SUMMARY The Product Assurance Program at AMI is oriented towards process control and monitoring, and the evaluation of devices. The Program consists of three major functions: Quality Control, Quality Assurance, and Reliability. Constant monitoring of all phases of production, with information feedback at all levels, allows fast and efficient detection of problems, evaluation and analysis, correction, and verification of the correction. The overall result is a line of products which are highly repeatable and reliable, with a very low reject level. ### PROCESS DESCRIPTIONS Each of the major MOS processes is described on the following pages. First, the established production proven processes are described, followed by those advanced processes, which are starting to go into volume production now. In each case, the basic processes is described first, followed by an explanation of its advantages, applications, etc. ### P-CHANNEL METAL GATE PROCESS Of all the basic MOS processes, P-channel Metal Gate is the oldest and the most completely developed. It has served as the foundation for the MOS/LSI industry and still finds use today in some devices. Several versions of this process have evolved since its earliest days. A thin slice (8 to 10 mils) of lightly doped N-type silicon wafer serves as the substrate or body of the MOS transistor. Two closely spaced, heavily doped P-type regions, the source and drain, are formed within the substrate by selective diffusion of an impurity that provides holes as majority electrical carriers. A thin deposited layer of aluminum metal, the gate, covers the area between the source and drain regions, but is electrically insulated from the substrate by a thin layer (1000-1500 Å) of silicon dioxide. The P-channel transistor is turned on by a negative gate voltage and conducts current between the source and the drain by means of holes as the majority carriers. The basic P-channel metal gate process can be subdivided in two general categories: high-threshold and low- FIGURE 10-1. SUMMARY OF MOS PROCESS CHARACTERISTICS threshold. Various manufacturers use different techniques (particularly so with the low threshold process) to achieve similar results, but the difference between them always rests in the threshold voltage $V_T$ required to turn a transistor on. The high threshold $V_T$ is typically -3 to -5 volts and the low threshold $V_T$ is typically -1.5 to -2.5 volts. The original technique used to achieve the difference in threshold voltages was by the use of substrates with different crystalline structures. The high $V_T$ process used (111) silicon, whereas the low $V_T$ process used (100) silicon. The difference in the silicon structure causes the surface charge between the substrate and the silicon dioxide to change in such a manner that it lowers the threshold voltages. One of the main advantages of lowering $V_T$ is the ability to interface the device with TTL circuitry. However, the use of (100) silicon carries with it a distinct disadvantage also. Just as the surface layer of the (100) silicon can be inverted by a lower $V_T$ , so it also can be inverted at other random locations—through the thick oxide layers—by large voltages that may appear in the metal interconnections between circuit components. This is undesirable because it creates parasitic transistors, which interfere with circuit operation. The maximum voltage that can be carried in the interconnections is called the parasitic field oxide threshold voltage $V_{TF}$ , and generally limits the overall voltage at which a circuit can operate. This, then, is the main factor that limits the use of the low $V_T$ process. A drop in $V_{TF}$ between a high $V_T$ and low $V_T$ process may, for example, be from -28V to -17V. The low $V_T$ process, because of its lower operating voltages, usually produces circuits with a lower operating speed than the high $V_T$ process, but is easier to interface with other circuits, consumes less power, and therefore is more suitable for clocked circuits. Both P-channel metal gate processes yield devices slower in speed than those made by other MOS processes, and have a relatively poor speed/power product. Both processes require two power supplies in most circuit designs, but the high $V_T$ process, because it operates at a high threshold voltage, has excellent noise immunity. ### ION IMPLANTED P-CHANNEL METAL GATE PROCESS The P-channel Ion Implanted process uses essentially the same geometrical structure and the same materials as the high $V_T$ P-channel process, but includes the ion implantation step. The purpose of ion implantation is to introduce P-type impurity ions into the substrate in the limited area under the gate electrode. By changing the characteristics of the substrate in the gate area, it is possible to lower the threshold voltage $V_T$ of the transistor, without influencing any other of its properties. Figure 10-2 shows the ion implantation step in a diagrammatic manner. It is performed after the gate oxide is deposited, but before the source, gate, and drain metallization deposition. The wafer is exposed to an ion beam which penetrates through the thin gate oxide layer and implants ions into the silicon substrate. Other areas of the substrate are protected both by the thicker oxide layer and sometimes also by other masking means, lon implantation can be used with any process and, therefore could, except for the custom of the industry, be considered a special technique, rather than a process in itself. The implantation of P-type ions into the substrate, in effect, reduces the effective concentration of N-type ions in the channel area and thus lowers the $V_{\rm T}$ required to turn the transistor on. At the same time, it does not alter the N-type ion concentration elsewhere in the substrate and therefore, does not reduce the parasitic field oxide threshold voltage $V_{\rm TF}$ (a ### FIGURE 10-2. DIAGRAM OF ION IMPLANTATION STEP problem with the low $V_T$ P-channel Metal Gate process, described above). The (111) silicon usually is used in ion-implanted transistors. In fact, if the channel area is exposed to the ion beam long enough, the substrate in the area can be turned into P-type silicon (while the body of the substrate still remains N-type) and the transistor becomes a depletion mode device. In any circuit some transistors can be made enhancement type, while others are depletion type, and the combination is a very useful circuit design tool. The lon-implanted P-channel Metal Gate process is very much in use today. Among all the processes, it represents a good optimization between cost and performance and thus is the logical choice for many common circuits, such as memory devices, data handling (communication) circuits, and others. Because of its low $V_{\rm T}$ , it offers the designer a choice of using low power supply voltages to conserve power or increase supply voltages to get more driving power and thus increase speed. At low power levels it is more feasible to implement clock generating and gating circuits on the chip. In most circuit designs only a single power supply voltage is required. ### N-CHANNEL PROCESS Historically, N-channel process and its advantages were known well at the time when the first P-channel devices were successfully manufactured, however it was much more difficult to produce N-channel. One of the main reasons was that the polarity of intrinsic charges in the materials combined in such a way that a transistor was on at OV and had a $V_{\rm T}$ of only a few tenths of a volt (positive). Thus, the transistor operated as a marginal depletion mode device, without a well-defined onloff biasing range. Attempts to raise $V_{\rm T}$ by varying gate oxide thickness, increasing the substrate doping, and back biasing the substrate, created other objectionable results and it was not until research into materials, along with ion implantation, silicon gates, and other improvements came about that N-channel became practical for high density circuits. The N-channel process gained its strength only after the P-channel process, ion implantation, and silicon gate all were already well developed. N-channel went into volume productions with advent of the 4K dynamic RAM and the microprocessor, both of which required speed and high density. Because P-channel processes were nearing their limits in both of these respects, N-channel became the logical answer. The N-channel process is structurally different from any of the processes described so far, in that the source, drain, and channel all are N-type silicon, whereas the body of the substrate is P-type. Conduction in the N-channel is by means of electrons, rather than holes. The main advantage of the N-channel process is that the mobility of electrons is about three times greater than that of holes and, therefore, N-channel transistors are faster than P-channel. In addition, the increased mobility allows more current flow in a channel of any given size, and therefore N-channel transistors can be made smaller. The positive gate voltage allows an N-channel transistor to be completely compatible with TTL. Although metal gate N-channel processes have been used, the predominant N-channel process is a silicon gate process. Among the advantages of silicon gate is the possibility of a buried layer of interconnect lines, in addition to the normal aluminum interconnections deposited on the surface of the chip. This gives the circuit designer more latitude in layout and often allows the reduction of the total chip size. Because the polysilicon gate electrode is deposited in a separate step, after the thick oxide layer is in place, the simultaneous deposition of additional polysilicon interconnect lines is only a matter of masking. These interconnect lines are buried by later steps, as shown in Figure 10-3. FIGURE 10-3. CROSSECTION OF A SILICON GATE MOS TRANSISTOR One minor limitation associated with the buried interconnect lines is their location. Because the source and drain diffusions are done after the polysilicon is deposited [see (a) of Figure 10-3] the interconnect lines cannot be located over these diffusion regions. A second advantage of a silicon gate is associated with the reduction of overlap between the gate and both the source and drain. This reduces the parasitic capacitance at each location and improves speed, as well as power consumption characteristics. Whereas in the metal gate process, the P region source and drain diffusion must be done prior to deposition of the gate electrode, in silicon gate process, the electrode is in place during diffusion, see (a) of Figure 10-3. Therefore, no planned overlap for manufacturing tolerance purposes need exist and the gate is said to be self-aligned. The only overlap that occurs is due to the normal lateral extension of the source and drain regions during the diffusion process. The silicon-gate process produces devices that are more compact than metal gate, and are slightly faster because of the reduced gate overlap capacitance. Because the basic silicon gate process is relatively simple, it is also economical. It is a versatile process that is used in memory devices and most any other circuit. Because N-channel is relatively new, however, its production techniques and variations in applications still are undergoing development. However, the combination of high speed, TTI, compatibility, low power requirements, and compactness have already made N-channel the most widely used process. The cost of N-channel has been coming down also. In addition to its use in large memory chips and microprocessors, N-channel has become a good general purpose process for circuits in which compactness and high speed are important. The addition of a second layer of polysilicon to this process has allowed the formation of overlapping electrodes making possible charge coupled devices for very compact dynamic memory cells, for filters, and for analog/digital conversion. ### CMQ\$ The basic CMOS circuit is an inverter, which consists of two adjacent transistors — one an N-channel, the other a P-channel, as shown in Figure 10-4. The two are fabricated on the same substrate, which can be either N or P type. The CMOS inverter in Figure 10-4 is fabricated on an N-type silicon substrate in which a P "tub" is diffused to form the body for the N-channel transistor. All other steps, including the use of silicon gates and ion implantation, are much the same as for other processes. The main advantage of CMOS is its extremely low power consumption. When the common input to both gate electrodes is at a logic 1 (a positive voltage) the N-channel transistor is biased on, the P-channel is off, and the output is near ground potential. Conversely, when the input is at a logic 0 level, its negative voltage biases only the P-channel transistor on and the output is near the drain voltage $^{\rm +}V_{\rm DD}$ . In either case, only one of the two transistors is on at a time and thus, there is virtually no current flow and no power consumption. Only during the transition from one logic level to the other are both transistors on and current flow increases momentarily. Silicon Gate CMOS is also fast, approaching speeds of bipolar TTL circuits. On the other hand, the use of two transistors in every device makes CMOS slightly more complex, FIGURE 10-4. CROSSECTION AND SCHEMATIC DIAGRAM OF A CMOS INVERTER costly, and requires more chip size. For these reasons, the original popularity of CMOS was in SSI logic elements and MSI circuits — logic gates, inverters, small shift registers, counters, etc. These CMOS devices constitute a logic family in the same way at TTL, ECL, and other bipolar circuits do and in the areas of very low power consumption, high noise immunity, and simplicity of operation, are still widely accepted by discrete logic circuit designers. Low power CMOS circuits made the watch circuit possible and also have been used in space exploration, battery operated consumer products, and automotive control devices. As experience was gained with CMOS, tighter design rules and reduced device sizes have been implemented and now LSI circuits, such as 1K RAM memories and microprocessors, are being manufactured in volume. CMOS circuits can be operated on a single power supply voltage, which can be varied from +3 to about +18 volts, with a higher voltage giving more speed and higher noise immunity. ### VMOS AMI's patented VMOS process is a significant departure from the other processes described so far. The VMOS transistor is constructed along the sides of a V-shaped groove, that has been etched into the silicon, as shown in the simplified diagram of Figure 10-5(a). (A distinction arises between the VMOS transistor and the planar transistor, whose source, gate, and drain are laid out in the usual manner, along the surface plane of the substrate.) The source is a heavily N doped region, diffused into the substrate (heavy doping is denoted by + after the N). An epitaxially grown layer over the source constitutes the channel. The lower part of this layer is more heavily P-doped and its depth determines the effective channel length. The upper part, designated $\pi$ , is very lightly P-doped and is used as an isolating layer, to improve device performance characteristics (as described below). The drain is a heavily N-doped diffusion on the surface of the structure. The gate oxide and gate electrode are deposited all along the bias surfaces of the V-groove, as shown in the crossection (b), and a field oxide layer extends over the drain. On the surface of a die, the VMOS transistor appears as in (c). In producing a VMOS device, the source diffusion, epitaxial growth of the channel layer, drain diffusions and insulating oxide all are completed first and only then the V-groove is etched. The precise V shape of the groove results because of the interaction of the etchant with the anisotropic crystal structure. The VMOS process has several significant advantages: - Because it uses the sides of the V-groove for device construction, the VMOS transistor requires a much smaller chip surface area than any planar transistor. For this reason, very high density circuits can be built with VMOS. - Devices with very short channels and large W/ε ratios can be built, making possible the design of very high speed circuits, that can carry large currents. In any planar process the channel length can be no smaller than the physical limits of photolithographic masks, whereas in VMOS the effective channel length is controlled only by diffusion and epitaxial thickness, and can be 2 μm or less. On the other hand, channel width is the perimeter distance around all four sides of the V-groove (at the channel elevation) and this clearly is an advantage in getting a high W/ε ratio without using up a large surface area. (The perimeter distance is 2-3 times that of a corresponding chip surface area planar device.) - The π type epitaxial layer isolates the heavily doped N<sup>+</sup> drain from the P channel and thus reduces substrate-to-drain capacitance and increases drain breakdown voltage. Other parasitic capacitances are also typically smaller than those of planar devices and so the overall power consumption at a given operating speed is smaller than that of other processes (with the exception of CMOS). On the strength of its density and speed advantages, VMOS appears to be most promising for next generation memories—the 16K and larger RAMs. However, various other device configurations, besides the floating source transistor shown in Figure 10-5, are possible and thus VMOS can become a good all-purpose process—usable on ROMs, EPROMs, microprocessors, and random logic. For example, in a ROM the N<sup>+</sup> source diffusion is eliminated and instead, the entire substrate is N type. In this manner all the cells have a common grounded source and a very simple straightforward structure results. ### FIGURE 10-5. THE VMOS TRANSISTOR b. Crossection of a Completed Floating Source VMOS Transistor c. Photograph of Two Parallel VMOS Transistors with Surface V-Groove Dimensions of 6µm x 23µm ## FIGURE 10-6. COMPARATIVE DATA ON MAJOR MOS PROCESSES Memories (RAMs, ROMs and EPROMs) ### MOS STATIC RANDOM ACCESS MEMORIES | PART NO. | ORGANIZATION | PROCESS | MAX. ACCESS<br>TIME (ns) | MAX. ACTIVE<br>POWER (mW) | MAX. STANDBY<br>POWER (mW) | POWER<br>Supplies | PACKAGE | |-----------|--------------|---------|--------------------------|---------------------------|----------------------------|-------------------|---------| | S68B10 | 128 × 8 | NMOS | 250 | 420 | n/A | +5₹ | 24 PIN | | S68A10 | 128 x 8 | NMOS | 36C | 420 | N/A | +5V | 24 PIN | | 54015 2 | 1024 x 1 | VMOS | 60 | 660 | N/A | +5V | 16 PIN | | \$4025-2 | 1024 x 1 | VMCS | 60 | 660 | N/A | +5V | 16 PIN | | S2114H* | 1024 x 4 | VMOS | 70 | 79D | N/A | +5¥ | 18 PIN | | \$2114A-1 | 1024 x 4 | VMCS | 150 | 265 | N/A | ۷د + | 18 PIN | | \$2114L-1 | 1024 x 4 | VMCS | 150 | 370 | N/A | +5V | 18 PIN | | \$2114-1 | 1024 x 4 | VMOS | 150 | 525 | N/A | +5V | 18 P'N | | S2114A-2 | 1024 x 4 | VMCS | 200 | 265 | N/A | +5V | 18 PIN | | S2114L-2 | 1024 x 4 | VMOS | 200 | 37D | N/A | +5 <b>V</b> | 18 PIN | | \$2114-2 | 1024 × 4 | VMOS | 200 | 525 | N/Ā | ٠ ٧خ+ | 18 PIN | | S2114A-3 | 1024 x 4 | VMOS | 300 | 265 | N/A | +5V | 18 PIN | | \$2114L-3 | 1024 × 4 | VMOS | 300 | 370 | N/A | +5٧ | 18 PIN | | S21'4-3 | 1024 x 4 | VMCS | 30C | 525 | N/A | +5V | 18 PIN | | S4017-3 | 4096 x 1 | VMOS | 55 | 660 | N/A | +5V | 18 P!N | | \$4017 | 4096 x 1 | VMCS | 7C | 660 | N/A | ۸۶+ | 18 PIN | | S2147-3° | 4096 x 1 | VMOS | 55 | 945 | 160 | +5V | 18 PIN | | \$21478 | 4096 x 1 | VMOS | 70 | 840 | 105 | +5V | 18 PIN | | S4028° | 2048 x 8 | VMOS | 200 | 525 | N/A | +5V | 24 PIN | ## **CMOS STATIC RANDOM ACCESS MEMORIES** | PART NO. | UNGANIZATION | MAX. ACCESS<br>TIME (ns) | MAX. ACTIVE<br>POWER (mW) | MAX. STANDBY<br>POWER (MW) | PDWER<br>SUPPLIES | PACKAGE | |-----------|-------------------|--------------------------|---------------------------|----------------------------|-------------------|-----------------| | \$22221 | 512 x 1 | 350 | 25 | .05 | +,0/ | 16 PIN | | \$2222A1 | 512 x l | 700 | 25 | .25 | +10V | 16 PIN | | \$5101L-1 | 256 x 4 | <b>45</b> 0 | 115 | .055 | +5V | 2 <b>2 P</b> IN | | S51011 | 256 x 4 | 650 | 115 | .055 | +5V | 22 PIN | | S5101L-3 | 256 x 4 | 650 | 115 | .735 | +5V | 22 PIN | | \$5101L-8 | 256 x 4 | 800 | 115 | 2.1 | +5V | 22 PIN | | 55101-8 | 256 x 4 | 800 | 115 | 2.7 | +5V | 22 PIN | | S6508-1 | 1024 x 1 | 300 | 13 | .055 | +5V | 16 PIN | | \$650B | 1024 x 1 | 460 | 13 | .55 | +5V | 16 PIN | | S6508A-1 | 1024 x 1 | 275/115 <sup>2</sup> | 12.5/50² | 1,1 | +4V to +11V | 16 PIN | | S6508A | 1 <b>0</b> 24 x 1 | 460/185² | 12.5/50° | 5.5 | +4V to +11V | 16 PIN | | S6518 1 | 1024 x 1 | 300 | 13 | .055 | +5V | 18 PIN | | \$6518 | 1024 x 1 | 460 | 13 | . <b>5</b> 5 | +5V | 18 PIN | | S6518A-1 | 1024 x 1 | 275/115° | 12.5/50² | 1.1 | +4V 10 +11V | 18 PIN | | \$651BA | 1024 x 1 | 460/185 <sup>2</sup> | 12.5/502 | 5.5 | +4V to +11V | 18 PIN | # MEMORY PRODUCTS ## MOS DYNAMIC RANDOM ACCESS MEMORIES | PART NO. | URGANIZATION | PROCESS | MAX. ACCESS<br>TIME (ns) | MAX. ACTIVE<br>POWER (mW) | MAX, STANDBY<br>POWER (mW) | POWER<br>Supplies | PACKAGE | |----------|--------------|---------|--------------------------|---------------------------|----------------------------|-------------------|---------| | 51103A1 | 1024 x 1 | FM0S | 205 | 425 | 2.0 | +16/+19 | 18 P N | | \$40061 | 1024 x 1 | PMCS | 40C | 450 | 50 | - 12/+5 | 16 PIN | | 54008 9' | 1024 x 1 | PM0S | 800 | 450 | 50 | -12/ 15 | 16 P N | ### UV ERASABLE ELECTRICALLY PROGRAMMABLE READ ONLY MEMORIES | PART NO. | ORGANIZATION | PROCESS | MAX. ACCESS<br>TIME (ns) | MAX. ACTIVE<br>POWER (mW) | MAX. STANOBY<br>POWER (mW) | POWER<br>Supplies | PACKAGE | |---------------------|--------------|---------|--------------------------|---------------------------|----------------------------|-------------------|---------| | 36834 | 512 x 8 | PMOS | 575 | 750 | N/A | +5/ - 12 | 24 P N | | S6834-1 | 512 x 8 | PMOS | 750 | 750 | N/A | +5/ = 12 | 24 PIN | | S5204A | 512 x 8 | PMOS | 750 | 750 | N/A | +5/-12 | 24 P N | | S4716° | 2048 x 8 | VMOS | 250 | 525 | 132 | + 5 | 24 PIN | | \$4532 <sup>8</sup> | 4396 x 8 | VMOS | 250 | 525 | 132 | ر+ | 24 P N | ## MOS READ ONLY MEMORIES | PART NO. | DESCRIPTION | ORGANIZATION | PROCESS | MAX. ACCESS<br>TIME (ns) | MAX. ACTIVE<br>POWER (mW) | POWER<br>Supplies | PACKAGE | |--------------------|-------------------------|----------------------|---------|--------------------------|---------------------------|----------------------|-----------| | S87731 | 2560 Bit Static ROM | 256 x 10 or 512 x 5 | PMOS | 600 | 500 | <b>+</b> 5/-12 | 24/28 PIN | | S8564° | 64 x 7 x 9 Charac, Gen. | 64 Words | PMOS | 450 | 1100 | - 57 – 12 | 28 PIN | | \$35141 | 4096 Bit Static ROM | 512 x 8 cr 1024 x 4 | PMOS | 1000 | 500 | +5/ 12 | 24 PIN | | S5232 <sup>3</sup> | 4096 Bit Static ROM | 512 x B ar 1024 x 4 | PMOS | 1000 | 500 | +5/-12 | 24 PIN | | \$8771' | 5120 Bit Static ROM | 512 x 10 pr 1024 x 5 | PMOS | 45D | 1000 | +5/12 | 28 PIN | | S68301 | 8192 Bit Static ROM | 1024 x 8 | NMOS | 575 | 580 | +5 | 24 PIN | | \$8865° | 8192 Bit Dynamic ROM | 1024 x 8 | PMOS | 1700 | 635 | +5/ <del>- 1</del> 2 | 24 PIN | | S4216B | 16,384 Bit Static ROM | 2048 × 8 | VMOS | 250 | 500 | +5 | 24 PIN | | S68311 | 16,384 Bit Static ROM | 2048 x 8 | NMOS | 450 | 420 | +5 | 24 PIN | | \$6831A | 16,384 Bit Static ROVI | 2048 x 8 | NMOS | 450 | 42G | +5 | 24 PIN | | S6831B | 16,384 Bit Static ROM | 2048 x 8 | NMOS | 450 | 420 | +5 | 24 PIN | | \$683101 | 16,384 Bit Static ROVI | 2048 x 8 | NMOS | 450 | 420 | +5 | 24 PHN | | \$ <b>89</b> 961 | 16,384 Bit Dynamic ROM | 4096 x 4 | PMOS | 1800 | 370 | +5/-12 | 24 PIN | | S89961 | 16,384 Bit Dynamic ROM | 2048 x 8 | PMOS | 1800 | 370 | +5/-12 | 24 PIN | | \$68332 | 32,768 Bit Static ROM | 4096 x 8 | NMOS | 450 | 630 | +5 | 24 PfN | | S4264 | 65,536 Bit Static ROM | 8192 x 8 | VMOS | 350 | 300 | +5 | 24 PIN | <sup>1</sup> NOT RECOMMENDED FOR NEW DESIGNS. <sup>\*</sup> FIRST NUMBER IS AT +5V, SECOND IS AT +10V TO BE ANNOUNCED ## 4096 BIT (1024x4) STATIC VMOS RAM ### Features - ☐ High Speed Operation: Access Time: 150ns Maximum (-1) - ☐ High Density 18 Pin Package - ☐ Single +5 Volt Power Supply - ☐ Completely Static Operation: No Clocks Required - ☐ Completely TTL Compatible - ☐ Common Data I/O: Three-State Outputs - ☐ Fan-Out of 5 TTL: IOL = 8mA @ 0.4V ### General Description The AMI S2114 is a 4096 bit fully static RAM organized as 1024 words by 4 bits. The device is fully TTL compatible on all inputs and outputs and has a single +5V supply. The common data input/output pins facilitate interface with systems utilizing a bidirectional data bus. The stored data is read out non-destructively and is the same polarity as the original input data. The S2114 is fully static requiring no clocks or refreshing for operation. This simplifies device operation as no address setup times are required. The chip select function facilitates memory system expansion by allowing the input/output pins to be OR-tied to other devices. The S2114 is fabricated using AMI's proprietary VMOS technology. This process permits the manufacture of high performance memory devices suitable for high volume production. | | s | Outputs | Mode | |-----|-------------|-------------------|----------------------------------------| | VE | DIN | DOUT | Mode | | x ] | X | Hi - Z | Not Selected | | L ¦ | L | Hi - Z | Write "0" | | L | н | Hi - Z | Write "1" | | н | X | DOUT | Read | | | X<br>L<br>L | X X<br>L L<br>L H | X X Hi - Z<br>L L Hi - Z<br>L H Hi - Z | ### Absolute Maximum Ratings\* | Ambient Temperature Under Bias | - 10°C to 80°C | |-------------------------------------------|-----------------| | Storage Temperature | - 65°C to 150°C | | Voltage on Any Pin With Respect to Ground | | | Power Dissipation | 1W | <sup>\*</sup>COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at 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 effect device reliability. ## D.C. Operating Conditions (V $_{CC}$ = $5V~\pm 5\%;\,T_{\Lambda}$ = $0^{\circ}\,\mathrm{C}$ to $70^{\circ}\,\mathrm{C})$ | | S2114A-1<br>S2114A-2<br>S2114A-3 | | S21 | S2114L-1<br>S2114L-2<br>S2114L-3 | | \$2114-1<br>\$2114-2<br>\$2114-3 | | i | | |---------------------|----------------------------------|------|----------|----------------------------------|--------------|----------------------------------|--------------|-------|------------------------------------------------------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units | l Conditions | | ILI | Input Leakage Current | | 10 | | 10 | | 10 | μA | V <sub>IN</sub> = 0V to 5,25V | | llLO | I/O Leakage Current | | 10 | | 10 | | 10 | μА | CS = 2.4 V;<br>V <sub>I/O</sub> = 0.4 V to V <sub>CC</sub> | | ICC | Power Supply Current | | 45 | | 65 | | 95 | mA | V <sub>IN</sub> = 5.25V;<br>T <sub>A</sub> = 25°C | | .00 | Tower ouppry cuttens | | 50 | | 70 | | 100 | m A | $V_{IN} = 5.25V;$<br>$T_A = 0$ °C | | $\overline{v_{IL}}$ | Input LOW Voltage | -0.5 | 0.8 | -0.5 | 0.8 | -0.5 | 0.8 | V | | | $v_{IH}$ | Input HIGH Voltage | 2.0 | $v_{cc}$ | 2.0 | $v_{\rm cc}$ | 2.0 | $v_{\rm cc}$ | Ý | | | $v_{\rm OL}$ | Output LOW Voltage | | 0.4 | | 0.4 | | 0.4 | V | I <sub>OL</sub> - 8mA | | $v_{OH}$ | Output HIGH Voltage | 2.4 | $v_{cc}$ | 2.4 | $v_{cc}$ | 2.4 | $v_{cc}$ | V | I <sub>OH</sub> ~ -1mA | | I <sub>OS</sub> | Output Short Circuit Current | | 100 | | 100 | | 100 | mA | Duration not to exceed 30 sec. | ## Capacitance ( $T_A = 25^{\circ}C$ ; f = 1.0MHz) | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |-----------------------------|--------------------------|------|------|------|-------|----------------| | $\mathbf{c}_{\mathrm{I/O}}$ | Input/Output Capacitance | | | 10 | рF | $V_{I/O} = 0V$ | | $C_{IN}$ | Input Capacitance | | | 5 | pF | $V_{IN} = 0V$ | ## A.C. Characteristics (V<sub>CC</sub> = 5V ±5%; T<sub>A</sub> = 0°C to 70°C) Read Cycle | Symbol | Parameter | S2114A-1<br>S2114L-1<br>S2114-1 | | S2114A-2<br>S2114L-2<br>S2114-2 | | S2114A-3<br>S2114L-3<br>S2114-3 | | | | |-----------------|------------------------------------|---------------------------------|------|---------------------------------|------|---------------------------------|------|-------|--------------------------------------------| | | | Min. | Max, | Min. | Max. | Min, | Max. | Units | Conditions | | <sup>t</sup> RC | Read Cycle Time | 150 | | 200 | | 300 | | ns | See<br>Test<br>Circuit<br>and<br>Waveforms | | t <sub>A</sub> | Access Time | | 150 | | 200 | | 300 | ns | | | tco | Chip Selection to Output Valid | | 70 | | 70 | | 100 | ns | | | t <sub>CX</sub> | Chip Selection to Output Active | 15 | | 15 | | 15 | | пѕ | | | tOTD | Output 3-State from<br>Deselection | | 40 | _ | 60 | | 80 | ns | | | tOHA | Output Hold from<br>Address Change | 30 | | 30 | | 30 | | ns | | # A.C. Characteristics (Continued) Write Cycle | | | \$2114A-1<br>\$2114L-1<br>\$2114-1 | | S2114A-2<br>S2114L-2<br>S2114-2 | | S2114A-3<br>S2114L-3<br>S2114L-3 | | | | |----------|----------------------------|------------------------------------|------|---------------------------------|------|----------------------------------|------|-------|-------------------------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units | Conditions | | twc | Write Cycle Time | 150 | | 200 | | 300 | | ns | See<br>Test<br>Circuit<br>and | | ίw | Write Time | 90 | | 120 | | 150 | | ns | | | $t_{WR}$ | Write Release Time | 0 | | 0 | | 0 | | ns | | | torw | Output 3-State from Write | <u> </u> | 40 | | 60 | | 80 | ns | | | tDW | Data to Write Time Overlap | 90 | | 120 | | 150 | | ns | Waveforms | | tDH | Data Hold from Write Time | 0 | | 0 | | 0 | | nş | | - 1. A read occurs during the overlap of a LOW $\overline{\text{CS}}$ and a HIGH $\overline{\text{WE}}$ . - 2. A write occurs during the overlap of a LOW CS and a LOW WE. - 3. twR is referenced to the positive transition of $\overline{WE}$ . - 4. WE must be HIGH during all address transitions. - If the CS LOW transition occurs simultaneously with the WE LOW transition, then the output buffers remain in the high impedance state. S2114H # 4096 BIT (1024x4) # **HIGH SPEED STATIC VMOS RAM** ## **Features** - High Speed Operation: Access Time: 70ns Maximum - High Density 18 Pin Package - Single +5 Volt Power Supply - **Completely Static Operation:** No Clocks Required - Completely TTL Compatible - Common Data I/O: Three-State Outputs - $\Box$ Fan-Out of 5 TTL: $I_{OL} = 8mA @ 0.45V$ #### General Description The AMI S2114H is a 4096 bit fully static RAM organized as 1024 words by 4 bits. The device is fully TTL compatible on all inputs and outputs and has a single +5V supply. The common data input/output pins facilitate interface with systems utilizing a bidirectional data bus. The stored data is read out non-destructively and is the same polarity as the original input data. The S2114H is fully static requiring no clocks or refreshing for operation. This simplifies device operation as no address setup times are required. The chip select function facilitates memory system expansion by allowing the input/output pins to be OR-tied to other devices. The S2114H is fabricated using AMI's proprietary VMOS technology. This process permits the manufacture of high performance memory devices suitable for high volume production. ## Truth Table | L | Input | is _ | Outputs | Mode | | |----|-------|------|---------|--------------|--| | CS | WE | DIN | DOUT | | | | н | х | Х | Hi · Z | Not Selected | | | L | L | L | Hi - Z | Write "0" | | | I, | L | H | Hi - Z | Write "1" | | | L | H | x | DOUT | Read | | ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias | 10°C to 80°C | |--------------------------------|--------------| | Storage Temperature | , | | | 0.5V to 7V | | Power Dissipation | 1W | <sup>\*</sup>COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at 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 effect device reliability. ## D.C. Operating Characteristic (VCC = 5V $\pm$ 5%, $\rm T_A$ = $\rm 0^{\circ}C$ to $\rm 70^{\circ}C)$ | Symbol | Parameter | Min, | Тур. | Max. | Units | Conditions | |-----------------|------------------------------|------|-------|---------------------|--------------|--------------------------------------------------------------| | $I_{LI}$ | Input Leakage Current | | | 10 | μA | V <sub>IN</sub> = 0V to 5.25V | | ILOI | I/O Leakage Current | | Ī | 10 | $\mu\Lambda$ | $CS = 2.4V$ ; $V_{I/O} = 0.4V$ to $V_{CC}$ | | I <sub>CC</sub> | Power Supply Current | | | 150 | mA | $V_{\rm IN} = 5.25 \text{V}, T_{\rm A} = 0^{\circ} \text{C}$ | | $v_{\rm IL}$ | Input LOW Voltage | -0.5 | | 0.8 | v | | | $v_{IH}$ | Input HIGH Voltage | 2.0 | | $v_{cc}$ | v | 1 | | $v_{OL}$ | Output LOW Voltage | Ī., | I — — | 0.45 | v | I <sub>OL</sub> = 8mA | | VOH | Output HIGH Voltage | 2.4 | T | $\overline{v_{cc}}$ | v | I <sub>OH</sub> = -1mA | | Ios | Output Short Circuit Current | | | 100 | mA | Duration not to exceed 30 sec. | ## Capacitance ( $T_A = 25^{\circ}C$ ; f = 1.0 MHz) | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |--------------|--------------------------|------|------|------|-------|----------------| | $C_{IO}$ | Input/Output Capacitance | | | 10 | рF | $V_{I/O} = 0V$ | | $C_{\rm IN}$ | Input Capacitance | | | 5 | рF | $V_{IN} = 0V$ | ## A.C. Characteristics ( $V_{CC} = 5V \pm 5\%$ , $T_A = 0^{\circ}C$ to $70^{\circ}C$ ) | ymbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |------------|------------------------------|------|------|-------------|-------|---------------------------------------| | Read Cyc | le | | | <del></del> | • | · · · · · · · · · · · · · · · · · · · | | tRC | Read Cycle Time | 70 | | | ns | | | tΛ | Address Access Time | | T | 70 | ns | See A.C. Test | | toha | Output Hold from Address | 0 | | | ns | Conditions | | tco | Chip Select Access Time | | | 40 | ns | & | | tco<br>tcx | Chip Select to Output Active | 0 | T | | ns | Load | | totd | Output H-Z from Chip Select | 1 | Ï | 30 | ns | | #### Write Cycle | twc | Write Cycle Time | 70 | | ns | J | |-------------|------------------------------|----|----|----|---------------| | tw | Write Time | 50 | | ns | See A.C. Test | | twR | Write Release Time | 0 | | ns | Conditions | | torw | Output H-Z from Write Enable | | 30 | ns | & | | tDW | Data to Write Time Overlap | 40 | | ns | Load | | $t_{ m DH}$ | Data Hold Time | 0 | | ns | _ | - 1. A read occurs during the overlap of a LOW CS and a HIGH WE. - 2. A write occurs during the overlap of a LOW $\overline{\text{CS}}$ and a LOW WE. - 3. twn is referenced to the positive transition of WE. - 4. WE must be HIGH during all address transitions. - If the CS LOW transition occurs simultaneously with the WE LOW transition, then the output buffers remain in the high impedance state. # 4096 BIT (4096×1) HIGH SPEED STATIC VMOS RAM #### Features $\overline{CE}$ $\overline{\text{WE}}$ Chip Enable Write Enable - ☐ High Speed Operation: Access Time: 55ns Max. (-3) - □ Automatic Power-Down - ☐ High Density 18 Pin Package - ☐ Single +5V Power Supply - Completely Stätic Operation - □ Completely TTL Compatible Inputs - ☐ Three-State TTL Compatible Output - $\square$ Fan-Out of 5 TTL: $I_{OL}$ = 8mA @ 0.45V ## **General Description** The AMI S2147 is a high speed 4096 bit fully static RAM organized as 4096 one-bit words. The device is fully TTL compatible and has a single +5V power supply. It has separate data input and output pins for maximum design flexibility. The three-state output facilitates memory expansion by allowing the output to be OR-tied to other devices. The stored data is read out non-destructively and is the same polarity as the input data. The automatic power down feature offers significant system power savings. This feature causes no performance degradation, as chip enable access and address access are equal. The S2147 is fully static eliminating the need for clocks or address set up and hold times as well as maximizing data rates since access times and cycle times are equal. The S2147 is fabricated using AMI's proprietary VMOS technology. The process permits the manufacture of high performance memory devices suitable for high volume production. | Logic Symbol | Pin Configuration | |--------------|-------------------| | AQ | A0 | | 877311 | 877312 | | Truth Table | | Truth Table | Inputs | | Output | Mode | Power | |-----------------------|-------------------|--------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $\overline{ ext{WE}}$ | $D_{IN}$ | Dour | HIOGE | 101161 | | X | X | H.Z | Deselected | Standby | | L | L | H-Z | Write "0" | Active | | L | Н | H-Z | Write "1" | Active | | Н | X | $D_{\mathrm{OUT}}$ | Read | Active | | | WE<br>X<br>L<br>L | WE D <sub>IN</sub> X X L L L H | WE D <sub>IN</sub> D <sub>OUT</sub> X X H · Z L L H · Z L H H · Z | WE D <sub>IN</sub> D <sub>OUT</sub> Mode X X H-Z Deselected L L H-Z Write "0" L H H-Z Write "1" | DOUT Data Output +5V Power $V_{CC}$ ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias | |-----------------------------------------------------| | Storage Temperature65°C to 150°C | | Voltage on Any Pin With Respect to Ground0.5V to 7V | | Power Dissipation 1W | \*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at 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 effect device reliability. D.C. Characteristics: $V_{CC}$ = 5V ± 5%, $T_A$ = 0°C to 70°C | Symbol | Parameter | | Min. | Тур, | Max. | Units | Conditions | |-------------------------|----------------------------------------|---------|------|------|------|-------|-----------------------------------------------------------------------------------------| | VOL | Output LOW Volts | age | | | 0.45 | v | $I_{OL} = 8mA$ | | V <sub>OH</sub> | Output HIGH Vol | tage | 2.4 | | | v | $I_{OH} = -4.0 \text{mA}$ | | $\overline{V_{\rm IL}}$ | Input LOW Voltag | e e | | | 0.8 | V | | | $V_{IH}$ | Input HIGH Volta | ge | 2.1 | | | V | | | $I_{LI}$ | Input Leakage Cur | rent | | | 10 | μΑ | $V_{\rm CC}$ = Max., $V_{\rm IN}$ = 0 to $V_{\rm CC}$ | | $I_{LO}$ | Output Leakage Co | urrent | | | 50 | μΑ | $\overline{\text{CS}}$ = 2.1V, V <sub>CC</sub> = Max.<br>V <sub>OUT</sub> = 0.4 to 4.5V | | Ios | Output Current Sh<br>Circuit to Ground | ort | | | -100 | mA | V <sub>CC</sub> = Max., for not more than one second. | | Lac | Operating Current | S2147 | | | 160 | mA | $V_{CC}$ = Max., $\overline{CE}$ = $V_{IL}$ , | | | I <sub>CC</sub> Operating Current | 82147-3 | | | 180 | mA | $T_A = 0$ °C, Outputs Open | | $I_{SB}$ | Standby Current | S2147 | | | 20 | mΛ | $V_{CC} = Max., \overline{CE} = V_{TH}$ | | LSB | Dominary Current | S2147-3 | | | 30 | m.A | VCC - Max., OE - VIH | Capacitance: $T_A = 25^{\circ} C$ , f = 1.0 MHz | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------|--------------------|------|------|------|-------|-----------------------| | $C_{IN}$ | Input Capacitance | | | 5 | pF | V <sub>IN</sub> = 0V | | COUT | Output Capacitance | | | 10 | pF | V <sub>OUT</sub> = 0V | # A.C. Characteristics: $T_A$ = 0°C to 75°C, $V_{CC}$ = +5V ± 5% Read Cycle S2147-3 S2147 Min. Max. Symbol Parameter Min. Max. Units Conditions Read Cycle Time 55 70 ns tRC Address Access Time 55 70 $t_{AA}$ ns See A.C. Test 70 $t_{AC}$ Chip Enable Access Time 55 ns Conditions Output Hold from Address Change 10 10 and $t_{OH}$ ns Waveform Chip Enable to Output LZ 10 10 ns $t_{LZ}$ Chip Enable to Output HZ 30 30 $t_{\rm HZ}$ ns Chip Enable to Power Up Time 0 0 $\mathbf{t}_{\mathrm{PU}}$ ns $t_{PD}$ Chip Disable to Power Down Time 40 50 ns Write Cycle | | Parameter | S21 | 47-3 | S2: | 147 | | Conditions | |------------------------------|---------------------------------|------|------|------|------|-------|---------------| | Symbol | | Min. | Max. | Min. | Max. | Units | | | $\overline{t_{WC}}$ | Write Cycle Time | 55 | | 70 | | ns | | | t <sub>CW</sub> | Chip Enable to End of Write | 45 | | 55 | | ns | ] | | $\overline{t}_{AW}$ | Address Valid to End of Write | 45 | | 55 | | ns | See A.C. Test | | tAS | Address Setup Time | 5 | | 5 | | nş | Conditions | | twp | Write Pulse Width | 35 | | 40 | | ns | and | | $\overline{t_{WR}}$ | Write Recovery Time | 10 | - | 15 | | ns | Waveforms | | $t_{DW}$ | Data Valid to End of Write | 25 | _ | 30 | | ns | 1 | | $\overline{\mathrm{t_{DH}}}$ | Data Hold Time | 10 | | 10 | | ns | | | twz. | Write Enable to Output HZ | , O | 25 | 0 | 30 | ns | | | $t_{OW}$ | Output Active from End of Write | 0 | 25 | 0 | 30 | ns | | - A read occurs during the overlap of a LOW $\overline{\text{CE}}$ and a HIGH $\overline{\text{WE}}$ . A write occurs during the overlap of a LOW $\overline{\text{CE}}$ and a LOW $\overline{\text{WE}}$ , two is referenced to the positive transition of $\overline{\text{WE}}$ . $\overline{\text{WE}}$ must be HIGH during all address transitions. - ... Single-like the restriction occurs simultaneously with the $\overline{\text{WE}}$ LOW transition, then output buffers remain in the high impedance state. # 1024 BIT (1024x1) HIGH SPEED STATIC VMOS RAM #### **Features** - □ Pin Compatible with 93415 (S4015) and 93425 (S4025) - ☐ Single +5V Power Supply - Completely TTL Compatible - □ Open Collector Output S4015 - ☐ Three-State Output S4025 - □ Fan-Out of 10 TTL $-I_{OL} = 16$ mA @ 0.45V - □ Completely Static no Clocks or Refreshing ## **General Description** The AMI S4015/S4025 family of 1024x1 bit high speed VMOS RAMs offers fully static operation with a single 5V supply. The device is completely TTL compatible on inputs and output. The family is available in two output configurations. The S4015 has an open collector (open drain) output and the S4025 has a three-state output. The stored data is read out nondestructively and is the same polarity as the original input data. The family is completely static requiring no clocks or refreshing for operation. Chip Select $(\overline{CS})$ controls the output and simplifies memory system expansion. The fast chip select time allows decoding the chip select from the address without increasing address access time. ## General Description (Continued) The S4015/S4025 is fabricated using AMI's proprietary VMOS process, thus allowing the production of high speed MOS RAMs that are fully compatible with bipolar RAMs but offering the advantage of lower power dissipation. ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias | -10°C to +85°C | |--------------------------------|-------------------------------------| | Storage Temperature | $-65^{\circ}$ C to $+150^{\circ}$ C | | Output or Supply Voltages | - 0.5V to + 7V | | Input Voltages | - 0.5V to + 5.5V | | Power Dissipation | 1 Watt | <sup>\*</sup>COMMENT: Stresses above those listed under "Absolute Maximum Rating" 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. ## D. C. Characteristics: $V_{CC}$ = 5V ± 5%, $T_A$ = 0°C to 75°C | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |---------------------------------------|------------------------------------------|------|------|----------|-------|------------------------------------------------------------------| | VOL | Output LOW Voltage | | | 0.45 | v | V <sub>CC</sub> =Min, l <sub>OL</sub> =16mA | | $\overline{\mathrm{v}_{\mathrm{OH}}}$ | Output HIGH Voltage (\$4025 Family) | 2.4 | T | <u> </u> | v | $V_{CC}$ =Min, $I_{OL}$ =16mA<br>$V_{CC}$ =Min, $I_{OH}$ =-5.2mA | | $V_{\rm IL}$ | Input LOW Voltage | | | 0.8 | Ÿ | | | $\overline{v_{IH}}$ | Input HIGH Voltage | 2.1 | | | V | | | $\overline{\mathbf{I}_{\mathrm{IL}}}$ | Input LOW Current | | | -40 | μΑ | V <sub>CC</sub> =Max, V <sub>IN</sub> =0.4V | | I <sub>IH</sub> | Input HIGH Current | | | 40 | μA | V <sub>CC</sub> =Max, V <sub>IN</sub> =4.5V | | I <sub>CEX</sub> | Output Leakage Current<br>(S4015 Family) | | | 50 | μA | V <sub>CC</sub> =Max, V <sub>OUT</sub> =4.5V | | T | Output Current (High Z) - | | 1 | 50 | μA | V <sub>CC</sub> =Max, V <sub>OUT</sub> =2.4V | | I <sub>OFF</sub> | (S4025 Family) | | 1 | -50 | μA | V <sub>CC</sub> =Max, V <sub>OUT</sub> =0.5V | | T | Output Current Short Circuit to | | | 100 | | V <sub>CC</sub> =Max, for not more | | Ios | Ground (S4025 Family) | | | -100 | mA | than 1 second | | l <sub>CC</sub> | Power Supply<br>Current | | | 125 | mA | V <sub>CC</sub> =Max<br>All Inputs Grounded<br>Output Open | ## Capacitance | Symbol | Parameter | Min. | Typ. | Max, | Units | Conditions | |---------------------------------------|--------------------|------|------|------|-------|---------------| | $\overline{\mathbf{c}_{\mathtt{IN}}}$ | Input Capacitance | | | 5 | рF | All inputs=0V | | $C_{OUT}$ | Output Capacitance | | | 8 | pF | Output=0V | A.C. Characteristics: $V_{CC}$ = 5V ±5%, $T_A$ = 0°C to 75°C Read Cycle | | | S4 | 1015(25) | . 2 | | | |-----------------|---------------------------------|----------------|----------|------|-------|------------| | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | | tACS | Chip Select Time | | | 40 | ns | See Test | | tres | Chip Select Recovery Time | 1 | | 40 | ns | Circuit & | | t <sub>AA</sub> | Address Access Time | 1 | | 60 | ns | Waveforms | | Write Cy | cle | | • | | | - | | tws | Write Disable Time | Ţ <del>-</del> | | 40 | ns | | | twR | Write Recovery Time | 0 | | 40 | ns | | | tw | Write Pulse Width | 40 | | T | ns | | | twsp | Data Set up Time Prior to Write | 5 | | | пѕ | See Test | | twHD | Data Hold Time After Write | 5_ | | | ns | Circuit & | | twsA | Address Set-up Time | 5 | | | ns | Waveforms | | twha | Address Hold Time | 5 | | | ns | | | twscs | Chip Select Set-up Time | 5 | | | ns | | | twics | Chip Select Hold Time | 5 | | | ns | | # 4096 BIT (4096x1) HIGH SPEED STATIC VMOS RAM ## **Features** ☐ High Speed Operation: Address Access Time: 55ns Maximum Chip Select Access Time: 30ns Maximum - ☐ Fast Chip Select Optimizes Access Time - High Density 18 Pin Package - Single +5V Power Supply - **Completely Static Operation** - **Completely TTL Compatible Inputs** - Three-State TTL Compatible Output - $\square$ Fan-Out of 5 TTL: $I_{OL} = 8mA @ 0.45V$ #### General Description The AMI S4017 is a high speed 4096 bit fully static RAM organized as 4096 one-bit words. The device is fully TTL compatible and has a single + 5V power supply. It has separate data input and output pins for maximum design flexibility. The three-state output facilitates memory expansion by allowing the output to be OR-tied to other devices. The stored data is read out non-destructively and is the same polarity as the original input data. The fast chip select access time offers a significant performance advantage. As the chip select is normally decoded from the address, the time required to decode the chip select will not impact the overall access time. The S4017 is fabricated using AMI's proprietary VMOS technology. The process permits the manufacture of high performance memory devices suitable for high volume production. ## Pin Names A<sub>0</sub>-A<sub>11</sub> Address Inputs D<sub>IN</sub> Data Input ĈS Chip Select DOUT Data Output $\overline{\mathrm{WE}}$ Write Enable +5V Power $v_{cc}$ ## Truth Table | L | Inputs | <u> </u> | Output | Mode | |------|--------|-------------------|------------------|--------------| | CS : | WE | $\mathbf{D_{IN}}$ | D <sub>OUT</sub> | Wode | | Н | X | X | H-Z | Not Selected | | L | L | L | H-Z | Write "0" | | L | L | н | H-Z | Write "1" | | L | H | Х | DOUT | Read | ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias10°C to 80° | c | |----------------------------------------------------|---| | Storage Temperature65°C to 150° | С | | Voltage on Any Pin With Respect to Ground0.5V to 7 | V | | Power Dissipation | W | \*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at 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 effect device reliability. ## D.C. Characteristics: $V_{CC}$ = 5V ± $5\%,\,T_A$ = $0^{\circ}C$ to $70^{\circ}C$ | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------------------------|-------------------------------------------|------|------|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------| | $\overline{v_{\text{OL}}}$ | Output LOW Voltage | | | 0.45 | v | $I_{OL} = 8mA$ | | VoH | Output HIGH Voltage | 2.4 | | - | v | $I_{OH} = -4.0 \text{mA}$ | | $\overline{v_{lL}}$ | Input LOW Voltage | | | 0.8 | V | | | $V_{IH}$ | Input HIGH Voltage | 2.1 | | | V | | | l <sub>LI</sub> | Input Leakage Current | | | 10 | $\mu A$ | $V_{\rm CC}$ = Max., $V_{\rm IN}$ = 0 to $V_{\rm CC}$ | | II <sub>LO</sub> | Output Leakage Current | | | 50 | μΑ | $\overrightarrow{\text{CS}} = 2.1 \text{V}, \ \text{V}_{\text{CC}} = \text{Max}.$<br>$\text{V}_{\text{OUT}} = 0.4 \text{ to } 4.5 \text{V}$ | | IOS | Output Current Short<br>Circuit to Ground | | | -100 | mA | V <sub>CC</sub> = Max., for not more than one second. | | $I_{CC}$ | Power Supply<br>Current | | | 125 | mA | $V_{CC}$ = Max., $\overline{CS}$ = $V_{IL}$<br>Output Open | Capacitance: $T_A = 25^{\circ}C$ , f = 1.0MHz | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |-------------------|--------------------|------|------|------|-------|----------------| | $\mathbf{C_{IN}}$ | Input Capacitance | | | 5 | рF | $V_{iN} = 0V$ | | $c_{out}$ | Output Capacitance | | | 8 | рF | $V_{OUT} = 0V$ | ## A.C. Characteristics: $T_A$ = 0°C to 75°C, $V_{CC}$ = +5V $\pm$ 5% ## Read Cycle | | | S4017-3 | | S4017 | | ] | | |-------------|---------------------------------|---------|------|-------|------|-------|---------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Conditions | | tRC | Read Cycle Time | 55 | | 70 | | ns | | | | Address Access Time | | 55 | | 70 | ns | See A.C. Test | | ACS | Chip Select Access Time | | 30 | | 40 | ns | Condition | | ф | Output Hold from Address Change | 10 | j | 10 | | ns | and | | LZ | Chip Select to Output L — Z | 10 | | 10 | | ns | Waveform | | $t_{ m HZ}$ | Chip Select to Output H — Z | | 30 | | 30 | ns | | Write Cycle | | | S40 | 17-3 | S40 | 17 | ! | Conditions | |-----------------|---------------------------------|------|------|------|------|-------|---------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | | | twc | Write Cycle Time | 55 | ĺ | 70 | | ns | | | t <sub>CW</sub> | Chip Select to End of Write | 40 | | 50 | | ns | ] | | t <sub>AW</sub> | Address Valid to End of Write | 45 | | 55 | | ns | See A.C. Test | | $t_{AS}$ | Address Setup Time | 5 | | 5 | | ns | Conditions | | WP | Write Pulse Width | 35 | | 40 | | ns | and | | wr | Write Recovery Time | 10 | | 15 | | ns | Waveforms | | t <sub>DW</sub> | Data Valid to End of Write | 25 | | 30 | | ns | | | DH | Data Hold Time | 10 | | 10 | | ns | 1 | | twz | Write Enable to Output HZ | 0 | 25 | 0 | 30 | ns | | | tow | Output Active from End of Write | 0 | 25 | 0 | 30 | ns | 1 | - 1. A read occurs during the overlap of a LOW CS and a HIGH WE. - 2. A write occurs during the overlap of a LOW CS and a LOW WE. - twR is referenced to the positive transition of WE. - WE must be HIGH during all address transitions. - If the CS LOW transition occurs simultaneously with the WE LOW transition, then the output buffers remain in the high impedance state. # 16,384 BIT (2048 X 8) STATIC VMOS RAM #### Features - ☐ High Speed Operation: Access Time: 200ns Max. - ☐ Single +5V Power Supply - □ Pin Compatible with 16K EPROM/ROM - ☐ Fully Static Operation - Completely TTL Compatible - ☐ Common Data Input/Output: Three-State Outputs - Output Enable Function for Easy Control of Data Output ## General Description The AMI S4028 is a 16,384 bit fully static VMOS random access memory organized as 2048 words by 8 bits. The device is fully TTL compatible on all inputs and outputs and has a single +5V power supply. The common data input/output pins and output enable function facilitate interface with systems utilizing a bi-directional data bus. Data is read out non-destructively and is the same polarity as the input data. The S4028 is fully static requiring no clocks or refreshing for operation. This simplifies device operation as no address setup or hold times are required. The chip select and output enable functions facilitate memory expansion by allowing the input/output pins to be ORtied to other devices. The S4028 is fabricated using AMI's proprietary VMOS technology. This permits the manufacture of high performance memory devices suitable for high volume production. # 1024 BIT (256×4) STATIC CMOS RAM #### **Features** - ☐ Ultra Low Standby Power - □ Data Retention at 2V (L Version) - ☐ Single +5 Volt Power Supply - ☐ Completely Static Operation - Completely TTL Compatible Inputs - ☐ Three-State TTL Compatible Outputs ## General Description The AMI S5101 family of 256 x 4-bit ultra low power CMOS RAMs offers fully static operation with a single + 5 volt power supply. All inputs and outputs are directly TTL compatible. With data inputs and outputs on adjacent pins, either separate or common data I/O operations can easily be implemented for maximum design flexibility. The three-state outputs will drive one full TTL load and are disabled (high impedance state) by output disable (OD), either chip enable (CE1 or CE2), or in a write cycle (R/W = LOW). This facilitates the control of common data I/O systems. ## General Description (Continued) The stored data is read out nondestructively and is the same polarity as the original input data. The S5101 is totally static, making clocks unnecessary for a new address to be accepted. The device has two chip enable inputs ( $\overline{CE1}$ and $\overline{CE2}$ ) allowing easy system expansion. CE2 disables the entire device but $\overline{CE1}$ does not disable the address buffers and decoders. Thus, minimum power dissipation is achieved when CE2 is low. The L version of the S5101 has the additional feature of guaranteed data retention with the power supply as low as 2 volts. This makes the device an ideal choice when battery augmented non-volatile RAM storage is mandatory. The S5101 is fabricated using a silicon gate CMOS process suitable for high volume production of ultra low power, high performance memories. ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias10°C to 80°C | |--------------------------------------------| | Storage Temperature | | Voltage on Any Pin with Respect to Ground | | Maximum Power Supply Voltage | | Power Dissipation 1W | \*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at 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. ## D.C. Characteristics: $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ (Unless otherwise specified) | | | | | Limits | | | |-----------------------------------------|--------------------------|------------------|------|--------------|-------|-------------------------------------------------------------------------| | Symbol | Parameter | | Min. | Max. | Units | Conditions | | $I_{LI}$ | Input Leakage Current | | | 1 | μΑ | $V_{IN}$ = 0V to $V_{CC}$ | | lro | Output Leakage Current | | | 1 | μΑ | CEI = V <sub>IH</sub><br>V <sub>OUT</sub> = 0V to V <sub>CC</sub> | | $I_{CC}$ | Operating Supply Current | | | 22 | mA | Outputs = Open,<br>V <sub>IN</sub> = V <sub>IL</sub> to V <sub>CC</sub> | | | | S5101L1, S5101L | | 10 | μΑ | $V_{IN} = 0V$ to $V_{CC}$ | | $I_{CCL}$ | Standby Supply Current | S5101L3 | | 140 | μA | except | | | | S5101L8, S5101-8 | | 500 | μΑ | CE2 ≤0.2V | | $\overline{\mathrm{v}_{\mathrm{I\!L}}}$ | Input Low Voltage | | ~0.3 | 0.65 | V | | | $\overline{\mathrm{v}_{\mathrm{IH}}}$ | Input High Voltage | | | $V_{\rm CC}$ | v | | | $v_{ol}$ | Output Low Voltage | | | 0.4 | V | I <sub>OL</sub> = 2 mA | | V <sub>OH</sub> | Output High Voltage | | | | V | I <sub>OH</sub> = -1 mA | #### Capacitance | | | Lir | Limits | | | |----------|--------------------|------|--------|------------|-----------------------------------------| | Symbol | Parameter | Min. | Max. | Units | Conditions | | $C_{IN}$ | Input Capacitance | | 8 | p <b>F</b> | V <sub>IN</sub> = 0V, on all Input Pins | | Co | Output Capacitance | | 12 | рF | $V_O = 0V$ | A.C. Characteristics for Read Cycle: $T_A$ = 0°C to 70°C, $V_{CC}$ = 5V ± 5% (Unless otherwise specified) | Symbol | Parameter | S5101L1<br>Limits | | S5101L<br>S5101L3<br>Limits | | S5101L8<br>S5101-8<br>Limits | | Units | Conditions | |------------------|---------------------------------------------------------------------|-------------------|------|-----------------------------|------|------------------------------|------|-------|---------------------------------| | | | Mín, | Max. | Min. | Max. | Min. | Max. | 1 | | | $T_{RC}$ | Read Cycle Time | 450 | | 650 | | 800 | | ns | | | TACC | Access Time | | 450 | | 650 | | 800 | ns | | | T <sub>CO1</sub> | CEI to Output Delay | l | 400 | | 600 | | 800 | rıs | See A.C. Conditions of Test and | | T <sub>CO2</sub> | CE2 to Output Delay | | 500 | | 700 | | 850 | ns | | | $T_{OD}$ | Output Disable to Enabled<br>Output Delay | | 250 | | 350 | | 450 | ns | | | $T_{DF}$ | Output Disable to Output<br>II-Z State Delay | 0 | 130 | 0 | 150 | 0 | 200 | ns | A.C. Test<br>Load | | тоні | Output Data Valid Into Next<br>Cycle with respect to<br>Address | 0 | | , 0 | | 0 | | វាន | | | T <sub>OH2</sub> | Output Data Valid Into<br>Next Cycle with respect<br>to Chip Enable | 0 | | 0 | | 0 | | ns | | A.C. Characteristics for Write Cycle — Separate or Common Data I/O Using Output Disable $T_A = 0^{\circ} C$ to $70^{\circ} C$ , $V_{CC} = 5V \pm 5\%$ ( Unless otherwise specified) | Symbol | Parameter | S5101L1<br>Limits | | S5101L<br>S5101L3<br>Limits | | S5101L8<br>S5101-8<br>Limits | | Units | Conditions | |------------------|----------------------------------------------|-------------------|------|-----------------------------|------|------------------------------|------|-------|---------------------| | _ | | Min. | Max. | Min. | Max. | Min. | Max. | | | | Twc | Write Cycle Time | 450 | | 650 | | 800 | | ns | · · · · | | TAW | Address To Write Delay | 130 | | 150 | | 200 | | ns l | | | $T_{CW1}$ | CE1 to Write Delay | 350 | | 550 | | 650 | | ηs | See A.C. | | T <sub>CW2</sub> | CE2 to Write Delay | 350 | | 5 <b>50</b> | | 650 | | ns | Conditions | | TDW | Data Set-Up to End of<br>Write Time | 250 | | 400 | | 450 | · | ns | of Test<br>and A.C. | | TDH | Data Hold After End of<br>Write Time | 50 | | 100 | | 100 | | ns | Test Load | | $T_{WP}$ | Write Pulse Width | 250 | | 400 | | 450 | | ns | | | TWR | End of Write to New<br>Address Recovery Time | 50 | | 50 | | 100 | | ns | | | $T_{DS}$ | Output Disable to Data-In Set-Up Time | 130 | | 150 | | 200 | | ns | | Low VCC Data Retention Characteristics for S5101L, S5101L1, S5101L3 and S5101L8 $^{\{1\}}$ $\rm T_A$ = $\rm 0^{\circ}C$ to $\rm 70^{\circ}C$ | | · | | | Limits | | | |--------------------|----------------------------------|-------------------|----------------|--------|---------|---------------------| | Symbol | Parameter | | Min. | Max. | Units | Conditions | | $V_{DR}$ | V <sub>CC</sub> for Data Retent | ion | 2.0 | | v | CE2≤0.2V | | | Data Retention<br>Supply Current | S5101L1, S5101L | | 10 | μA | $V_{CC} = V_{DR}$ | | $I_{CCDR}$ | | S5101L3 | | 140 | μA | $T_R = T_F = 20$ ns | | | S5101L8 | | | 500 | $\mu$ A | CE2≤0.2V | | $T_{\mathrm{CRD}}$ | Chip Deselect to Dat | ta Retention Time | 0 | | ns | | | $T_{R}$ | Operation Recovery | Time | $T_{RC}^{[2]}$ | | ns | | #### Notes: - [1] For guaranteed low VCC Data Retention @ 2.0V, order must specify S5101L, S5101L1, S5101L3 or S5101L8. - [2] TRC = Read Cycle Time. # 1024 BIT (1024 x 1) STATIC CMOS RAM #### Features - ☐ Ultra Low Standby Power - □ S6508 Completely TTL Compatible - ☐ S6508A Completely CMOS Compatible - ☐ 4V to 11V Operation (\$6508A) - □ Data Retention at 2V - ☐ Three-State Output - ☐ Low Operating Power: 10mW @ 1MHz (5V) - ☐ Fast Access Time: 115ns @ 10V ## General Description The AMI \$6508 family of 1024x1 bit static CMOS RAMs offers ultra low power dissipation with a single power supply. The device is available in two versions. The basic part (S6508) operates on 5V and is directly TTL compatible on all inputs and the three-state output. The \$6508 "A" operates from 4V to 11V and is fully CMOS compatible. The data is stored in ultra low power CMOS static RAM cells (six transistor). The stored data is read out nondestructively and is the same polarity as the original input data. The address is buffered by on-chip address registers. These internal registers are latched by the HIGH to LOW transition of chip enable (CE). The write enable and chip enable functions are designed such that either separate or common data I/O operations can be easily implemented for maximum design flexibility. #### General Description (Continued) The S6508 is fabricated using a silicon gate CMOS process suitable for high volume production of high performance, ultra low power memories. When deselected ( $\overline{\text{CE}}$ = HIGH), the S6508-1 draws less than 10 microamps from the 5V supply. In addition, it offers guaranteed data retention with the power supply as low as 2 volts. This process makes the device an ideal choice where battery augmented nonvolatile RAM storage is mandatory. ## CMOS to TTL — S6508/S6508-1 Absolute Maximum Ratings | Supply Voltage | V | |-----------------------------------------|---| | Input or Output Voltage Supplied | V | | Storage Temperature Range65°C to 150°C | Ç | | Operating Temperature Range, Commercial | C | ## D.C. Characteristics ( $V_{CC} = 5.0V \pm 10\%$ , $T_A = 0^{\circ}C$ to $70^{\circ}C$ ) | Symbol | Parameter | | Min. | Max. | Units | Conditions | |------------------|------------------------------|-------|------------------------|----------|----------------------|---------------------------------------------| | $v_{IH}$ | Logical "1" Input Voltag | je | V <sub>CC</sub> - 2.0 | | V | | | $v_{IL}$ | Logical "0" Input Voltage | | <del>"</del> - | 0.8 | v | · | | 111 | Input Leakage | | -1.0 | 1,0 | μΑ | $ov < v_{IN} < v_{CC}$ | | V <sub>OH2</sub> | Logical "1" Output Voltage | | V <sub>CC</sub> - 0.01 | | V | I <sub>OUT</sub> = 0 | | V <sub>OH1</sub> | Logical "1" Output Voltage | | 2.4 | | v | $1_{OH} = -0.2 \mathrm{mA}$ | | $v_{\rm OL2}$ | Logical "0" Output Voltage | | | GND+0.01 | v | I <sub>OUT</sub> = 0 | | V <sub>OL1</sub> | Logical "0" Output Volt | age | | 0.45 | $-\overline{v}$ | I <sub>OL</sub> = 2.0mA | | $I_{O}$ | Output Leakage | | -1.0 | 1.0 | $\mu \mathbf{A}$ | $0V < V_O < V_{CC}, \overline{CE} = V_{IH}$ | | | Standby Supply Current | S6508 | | 100 | $\mu \mathbf{A}$ | V-v-= V | | ICCL | Standoy Supply Current S6508 | | | 10 | $\mu \mathbf{A}^{"}$ | $V_{IN} = V_{CC}$ | | $I_{CC}$ | Supply Current S6508/S6508-1 | | | 2.5 | mA | f = 1MHz | | $c_{IN}$ | Input Capacitance | | | 7.0 | pF | | | $c_{O}$ | Output Capacitance | | | 10.0 | pF | | ## A.C. Characteristics (VCC = 5.0V ± 10%, CL = 50pF (One TTL Load), TA = 0°C to 70°C) | Symbol | Parameter | S65 | S6508-1 | | S6508 | | C-natitions | | |------------------|-------------------------|------|---------|------|-------|-------|--------------------------|--| | Symbol | rarameter | Min. | Max. | Min. | Max. | Units | Conditions | | | tACC | Access Time from CE | | 300 | | 460 | ns | | | | tEN | Output Enable Time | | 180 | | 285 | ns | ] | | | tDIS | Output Disable Time | | 180 | | 285 | ns | ] | | | t <sub>CEH</sub> | CE HIGH | 200 | | 300 | | ns | | | | tCEL | CE LOW | 300 | | 460 | | ns | See A.C. conditions of | | | twp | Write Pulse Width (LOW) | 200 | | 300 | | ns | test and A.C. test load. | | | tAS | Address Setup Time | 7 | | 15 | | ns | | | | t <sub>AH</sub> | Address Hold Time | 90 | | 130 | | ns | ] | | | $t_{DS}$ | Data Setup Time | 200 | | 300 | | ns | ] | | | t <sub>DH</sub> | Data Hold Time | 0 | | 0 | | ns | | | | tMOD | Data Modify Time | 0 | | 0 | | ns | 1 | | ## CMOS to CMOS — S6508A/S6508A-1 Absolute Maximum Ratings | Supply Voltage 12.0V | |-----------------------------------------| | Input or Output Voltage Applied | | Storage Temperature Range65°C to 150°C | | Operating Temperature Range, Commercial | ## D.C. Characteristics (V $_{CC}$ = $4\rm V$ to $11\rm V,\,T_A$ = $0^{\circ}\rm C$ to $70^{\circ}\rm C)$ | Symbol | Parameter | | Міп. | Max. | Units | Conditions | |-----------------|---------------------------------------------------------------|---------------------|------------------|---------------------|---------------------------------|--------------------------------------------------------| | V <sub>IH</sub> | Logical "1" Input Voltag | 70% V <sub>CC</sub> | | _v - | | | | $v_{IL}$ | Logical "0" Input Voltage | | | 20% V <sub>CC</sub> | V | | | I <sub>IL</sub> | Input Leakage | | -1.0 | 1.0 | $\mu\Lambda$ | $\overline{\text{ov}} < v_{\text{IN}} < v_{\text{CC}}$ | | VOH | Logical "1" Output Voltage | | $v_{CC}^{-0.01}$ | | V | $I_{OUT} = 0$ | | $v_{OL}$ | Logical "0" Output Voltage | | | GND+0.01 | V | $I_{OUT} = 0$ | | IO | Output Leakage | | -1.0 | 1.0 | μA | $0V < V_{O} < V_{CC}, \overline{CE} = V_{IH}$ | | $I_{\rm CCL}$ | Standby Supply Current | S6508A<br>S6508A-1 | | 500<br>100 | $\frac{\mu\Lambda}{\mu\Lambda}$ | V <sub>IN</sub> = V <sub>CC</sub> | | $_{\rm ICC}$ | Supply Current $V_{CC} = 5V$ (S6508A/S6508A-1) $V_{CC} = 10V$ | | | 2.5<br>5.0 | mA<br>mA | f = 1MHz | | $c_{IN}$ | Input Capacitance | | | 7.0 | pF | | | $c_0$ | Output Capacitance | | | 10,0 | рF | | ## A.C. Characteristics (V<sub>CC</sub> = V<sub>CC</sub> $\pm$ 10%, T<sub>A</sub> = 0°C to 70°C) | 0 1 1 | D | Marc | 8650 | )8A-1 | S65 | 08A | Units | Conditions | | |-----------|----------------------------------------|-------|----------|----------|------|------------|--------|-----------------------|--| | Symbol | Parameter | VCC | Min. | Max. | Min. | Max. | Cilita | Conditions | | | | | 5V | | 275 | | 460 | ns | | | | $t_{ACC}$ | Access Time from $\overline{ ext{CE}}$ | 10V | | 115 | | 185 | ns | | | | t | Output Pachla Time | 5V_ | <u> </u> | 165 | | 285 | ns | | | | ten | Output Enable Time | 10V | | 75 | | 120 | ns_ | | | | +=== | Outrost Disable Times | 5V | | 165 | | 285 | ns | | | | tDIS | Output Disable Time | 10V | | 75 | | 120 | ns | | | | +~ | CE HIGH | 5V | 175 | | 300 | | ns | | | | tCEH | CE HIGH | 10V_ | 80_ | | 125 | [ | ns | 1<br>1<br>1 | | | tonr | ÇE LOW | 5V | 275 | İ | 460 | | ns | | | | tCEL | CELOW | 10V | 115 | | 185 | | ns | | | | +13175 | <br> Write Pulse Width (LOW) | 5V | 175 | | 300 | <u>l</u> | ns_ | See A.C. conditions | | | tWP | Write Filise Width (LOW) | 10V | 80 | | 125 | | ns | of test and A.C. test | | | tag | Address Setup Time | 5V | 7 | L | 15 | | ns | load. | | | tAS | Address Setup Time | 10V | 7 | <u></u> | 15 | | ns | | | | * * * * * | Address Hold Time | 5V | 80 | | 130 | | ns | | | | tAH | Address Hold Time | 10V | 40 | | 60 | ļ | ns | | | | t na | Data Setup Time | _ 5V_ | 175 | | 300 | <u>-</u> . | ns | <u> </u> | | | tDS | Data Setup Time | 10V | 80 | | 125 | | ns | <u> </u> | | | terr | Data Hold Time | 5V_ | _0_ | | 0 | | ns | | | | tDH | | 10V | 0 | | 0 | | ns | <u> </u> | | | treop | Data Modify Time | 5V | 0_ | | 0 | | ns | ] | | | tMOD | Data Mounty Time | 10V | 0 | <u> </u> | 0 | <u> </u> | ns | | | - 1. The write operation is terminated on any positive edge of Chip Enable ( $\overline{\text{CE}}$ ) or Write Enable ( $\overline{\text{WE}}$ ). 2. The data output will be in the high impedance state whenever $\overline{\text{WE}}$ is LOW. - WE is HIGH during a read operation. Rise and fall times of VCC equal 20ns. ## Low V<sub>CC</sub> Data Retention Characteristics ( $T_A$ = 0°C to 70°C) | Symbol | Parameter | Min. | Max. | Units | Conditions | | |-------------------|------------------------------------|--------------------------------------|------------------|-------|------------|-----------------------------------------------------| | $v_{\mathrm{DR}}$ | V <sub>CC</sub> for Data Retention | | | | V | $\overline{\text{CE}} = 2.0 \text{V}$ | | $I_{CCDR}$ | Data Retention<br>Supply Current | \$6508,\$6508A<br>\$6508-1,\$6508A-1 | | 1.0 | μ A<br>μ A | $V_{CC} = V_{DR} \text{ Min.}$<br>$V_{IN} = V_{CC}$ | | tCDR | Deselect Setup Time | | $t_{CEH}$ | | ns | | | $t_{ m R}$ | Recovery Time | | t <sub>CEH</sub> | | ns | | # 1024 BIT (1024x1) STATIC CMOS RAM #### **Features** - ☐ Ultra Low Standby Power - ☐ S6518 Completely TTL Compatible - ☐ S6518A Completely CMOS Compatible - ☐ 4V to 11V Operation (S6518A) - □ Data Retention at 2V - ☐ Three-State Output - ☐ Low Operating Power: 10mW @1MHz (5V) - ☐ Fast Access Time: 115ns @10V ## General Description The AMI \$6518 family of 1024x1 bit static CMOS RAMs offers ultra low power dissipation with a single power supply. The device is available in two versions. The basic part (S6518) operates on +5V and is directly TTL compatible on all inputs and the three-state output. The S6518 "A" operates from +4V to +11V and is fully CMOS compatible. The data is stored in ultra low power CMOS six transistor static RAM cells. The data is read out non-destructively (into a data latch) and is the same polarity as the original input data. The address is buffered by on-chip address registers. These internal registers are latched by the HIGH to LOW transition of chip enable $(\overline{CE})$ . In addition, there are two chip selects ( $\overline{CS1}$ and $\overline{CS2}$ ) which facilitate memory expansion. The write enable, chip enable and chip select functions are designed such that either separate or common data I/O operations can be easily implemented. ## Truth Table | | | Input | 5 | | Output | Mode | | |------|-----|-------|-----|-----------------|--------|--------------------------------|--| | CE · | CS1 | CS2 | WE | D <sub>IN</sub> | Dour | wode | | | L | L | Ĺ | L | L | Hi-Z | Write "0" | | | L | L | [ [ | _r_ | Н | Hi-Z | Write "1" | | | ī. | L | L | H | X | Dout | Read | | | X | Ħ | x | Х | ìx | Hi-Z | Deselected | | | _x _ | X | н | х | X | Hi-Z | Deselected | | | Н | х | X | L | X | Hi-Z | Deselected | | | Н | L | L | Н | х | рост | Output Latched<br>To Last Data | | ## General Description (Continued) The S6518 is fabricated using a silicon gate CMOS process suitable for high volume production of high performance, ultra low power memories. When deselected ( $\overline{CE}$ = HIGH, $\overline{CS1}$ or $\overline{CS2}$ = HIGH), the S6518-1 draws less than 10 microamps from the +5V supply. In addition, the S6518 family offers guaranteed data retention with the power supply as low as 2 volts. This makes the device an ideal choice when battery augmented non-volatile RAM storage is mandatory. ## CMOS to TTL - \$6518/\$6518-1 Absolute Maximum Ratings | Supply Voltage 8.0V | |-----------------------------------------| | Input or Output Voltage Supplied | | Storage Temperature Range65°C to 150°C | | Operating Temperature Range, Commercial | ## D.C. Characteristics (V<sub>CC</sub> = 0.5V $\pm$ 10%, T<sub>A</sub> = 0°C to 70°C) | Symbol | Parameter | | Min. | Max. | Units | Conditions | |----------------------------------------|----------------------------|----------|-----------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------| | $v_{lH}$ | Logical "1" Input Volt | tage | V <sub>CC</sub> -2.0 | i | V | | | V <sub>lL</sub> | Logical "0" Input Volt | tage | i | 0.8 | v | | | ll L | Input Leakage | | -1.0 | 1.0 | $\mu\Lambda$ | $0V \le V_{IN} \le V_{CC}$ | | $\overline{\mathrm{v}_{\mathrm{OH2}}}$ | Logical "1" Output Voltage | | V <sub>CC</sub> -0.01 | · | $ v^- $ | $I(\mathcal{H})\mathcal{T}=0$ | | V <sub>OH1</sub> | Logical "1" Output Voltage | | 2,4 | ·<br>i | v | I <sub>OH</sub> = -0,2mA | | $\overline{v_{\rm OL2}}$ | Logical "0" Output Voltage | | | GND +0.01 | V | IOUT = 0 | | VOL1 | Logical "0" Output Vo | oltage | | 0.45 | V | IOL = 2.0mA | | IO | Output Leakage | _ | -1.0 | 1.0 | $\mu A$ | $0\mathrm{V} < \mathrm{V_O} < \mathrm{V_{CC}}$ , $\overline{\mathrm{CS1}}$ or $\overline{\mathrm{CS2}}$ = $\mathrm{V_{JH}}$ | | | Standby | S6518 | | 100 | $\mu\Lambda$ | V <sub>IN</sub> = V <sub>CC</sub> | | 1CCL | Supply Current | S6518-1 | | 10 | $p\Lambda$ | VIN - VCC | | 1CC | Supply Current S6518 | /S6518-1 | | 2.5 | mΛ | f = 1MHz | | CIN | Input Capacitance | | | 7.0 | рF | | | CO | Output Capacitance | | | 10,0 | рF | | ## A.C. Characteristics (VCC = 5.0V $\pm$ 10%, CL = 50pF (One TTL Load), $T_A$ = 0°C to 70°C) | | | S6518-1 | | S6518 | | | 0 1111 | | |------------------|-------------------------|---------|------|-------|------|-------|--------------------------|--| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Conditions | | | tACC _ | Access Time from CE | T | 300 | | 460 | ns | | | | tEN | Output Enable Time | 1 | 180 | Ī | 285 | ns | | | | tDIS | Output Disable Time | | 180 | | 285 | ns | ] | | | <sup>L</sup> CEH | CE HIGH | 200 | | 300 | | ns | ) | | | tCEL | CE LOW | 300 | | 460 | i | ns | See A.C. conditions of | | | twp | Write Pulse Width (LOW) | 200 | | 300 | | ns | test and A.C. test load. | | | tAS | Address Setup Time | 7 | | 15 | | ns | ] | | | tAH | Address Hold Time | 90 | | 130 | _ | ns | | | | $t_{ m DS}$ | Data Setup Time | 200 | | 300 | | ns | ] | | | <sup>t</sup> DH | Data Hold Time | 0 | | 0 | | ns | | | | tMOD | Data Modify Time | 0 | | 0 | | ns | | | ## CMOS to CMOS - S6518A/S6518A-1 Absolute Maximum Ratings | Supply Voltage | .0V | |-----------------------------------------|-----| | Input or Output Voltage Applied | | | Storage Temperature Range65°C to 150 | υ°C | | Operating Temperature Range, Commercial | ე°C | ## D.C. Characteristics (V $_{CC}$ = 4V to 11V, $_{TA}$ = 0°C to 70°C) | Symbol | Parameter | | Min. | Max. | Units | Conditions | |------------------------------|------------------------------------|---------------|-----------------------|---------------------|---------|-----------------------------------| | V <sub>lH</sub> | Logical "1" Input V | oltage | 70% V <sub>CC</sub> | ì | V | | | $\overline{\mathrm{V_{JL}}}$ | Logical "0" Input V | oltage | | 20% V <sub>CC</sub> | V | | | IIL | Input Leakage | <u> </u> | -1.0 | 1.0 | μΑ | $0V < V_{IN} < V_{CC}$ | | VOH | Logical "1" Voltage | | V <sub>CC</sub> -0.01 | | V | 10UT = 0 | | VOL | Logical "O" Voltage | | | GND+0.01 | _ v_ | lour = 0 | | IO | Output Leakage | | - 1.0 | 1.0 | $\mu A$ | 0V < VO < VCC, CS1 or CS2 = VIH | | Lace | Standby | S6518A | | 500 | μΑ | Var Van | | ICCL | Supply Current | S6518A-1 | L | 100 | μΑ | V <sub>IN</sub> = V <sub>CC</sub> | | Ico | Supply Current | $V_{CC} = 5V$ | | 2.5 | mA | £ = 1840= | | ICC | $(S6518A/S6518A-1)$ $V_{CC} = 10V$ | | | 5.0 | mΛ | f = 1MHz | | CIN | Input Capacitance | | <del>-</del> | 7.0 | pF | | | CO | Output Capacitance | | | 10.0 | pF | | ## A.C. Characteristics (V<sub>CC</sub> = V<sub>CC</sub> $\pm$ 10%, T<sub>A</sub> = 0°C to 70°C) | | | <b>)</b> | S65 | 18A-1 | S65 | 18A | T724- | Conditions | |------------------|--------------------------|------------|----------|----------|------|----------|-------|-----------------------| | Symbol | Parameter | VCC | Min. | Max. | Min. | Max. | Units | | | | , m, 4 <del>an</del> | 5V | | 275 | | 460 | ns | | | $t_{ACC}$ | Access Time from CE | 10V | | 115 | | 185 | ns | | | | Output Enable Time | 5V | | 165 | | 285 | ns | | | tEN | | 10V | | 75 | | 120 | ns | ] | | tore | Output Disable Time | _5V_ | <u> </u> | 165 | | 285 | ns | | | tDIS | Output Disable Time | 10V | <u> </u> | 75 | | 120 | ns | | | torri | CE HIGH | <u>5</u> V | 175 | | 300 | <u> </u> | ns | | | tCEH | | 107 | 80 | | 125 | | ns | | | topr | CE LOW | 5V | 275 | | 460 | | ns | | | tCEL | | 10V | 115 | | 185 | | ns | | | tuurs | Write Pulse Width (LOW) | 5V | 175 | | 300 | <u> </u> | ns | See A.C. conditions | | tWP | Write I uise Width (LOW) | 10V | 80 | | 125 | | ns | of test and A.C. test | | t + 0 | Address Setup Time | 5V | 7_ | | 15 | <u> </u> | ns | load. | | tAS | Address Secup Time | 10V | 7 | | 15 | | ns | | | tAH | Address Hold Time | δV | 80 | | 130 | 1 | ns | i | | -AH | Address from Time | 10V | 40 | | 60 | | ns | 1 | | $t_{ m DS}$ | Data Setup Time | 5V | 175 | | 300 | | ns | 1 | | - GUS | | 10V | 80 | | 125 | | ns | | | $t_{ m DH}$ | Data Hold Time | 5V | 0 | | 0 | | ns | | | -DH | David 11014 11110 | 10V | 0 | | 0 | <u> </u> | ns | | | $t_{\text{MOD}}$ | Data Modify Time | 5V | 0 | <u> </u> | 0 | ļ | ns | 1 | | -MOD | | 10V | 0 | L | 0 | <u> </u> | ns | | #### Notes: - The write operation occurs when \(\overline{CE} = \overline{CS1} = \overline{CS2} = \overline{WE} = LOW\). The write operation is terminated on any positive edge of \(\overline{CS1}\), \(\overline{CS2}\), \(\overline{CE}\) or \(\overline{WE}\). - 2. The data output will be in the high impedance state whenever $\overline{WE}$ is LOW - 3. $\overline{WE}$ is HIGH during a read operation. - 4. Rise and fall times of VCC equal 20ns. # AMI ## Low $V_{CC}$ Data Retention Characteristics $(T_A = 0^{\circ} C \text{ to } 70^{\circ} C)$ | Symbol | Parameter | | Min. | Max. | Units | Conditions | |-------------------|------------------------------------|------------------------------------|------------------|------------------|------------|-----------------------------------------------------| | $v_{\mathrm{DR}}$ | V <sub>CC</sub> for Data Retention | | 2.0 | | v | <u>CE</u> = 2.0V | | $l_{\rm CCDR}$ | Data Retention<br>Supply Current | S6518, S6518A<br>S6518-1, S6518A-1 | | $\frac{10}{1.0}$ | μ A<br>μ A | $V_{CC} = V_{DR} \text{ Min.}$<br>$V_{IN} = V_{CC}$ | | $t_{\rm CDR}$ | Deselect Setup Time | | t <sub>CEH</sub> | | ns | | | t <sub>R</sub> | Recovery Time | | t <sub>CEH</sub> | | ns | | # 16,384 BIT (2048 x 8) STATIC VMOS ROM #### **Features** - ☐ Fast Access Time: 250ns Maximum - ☐ Fully Static Operation - ☐ Single +5V ± 10% Power Supply - ☐ Directly TTL Compatible Inputs - ☐ Three-State TTL Compatible Outputs - ☐ Three Programmable Chip Selects - EPROM Pin Compatible - $\Box$ Fan-Out of 5 TTL: $I_{OL} = 8mA @ 0.4V$ ## General Description The AMI S4216B is a 16,384 bit static mask programmable VMOS ROM organized as 2048 words by 8 bits. The device is fully TTL compatible on all inputs and outputs and has single + 5V power suply. The three-state outputs facilitate memory expansion by allowing the outputs to be OR-tied to other devices. The S4216B is fully compatible with 16K UV EPROMs (+5V version) making system development much easier and more cost effective. It is fully static, requiring no clocks for operation. The three chip selects are mask programmable, the active level for each being specified by the user. The S4216B is fabricated using AMI's proprietary N-Channel VMOS technology. This permits the manufacture of very high density, high performance mask programmable ROMs. ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias10°C to 80°C | |--------------------------------------------| | Storage Temperature65°C to 150°C | | Output or Supply Voltage0.5V to 7V | | Input Voltage0.5V to 5.5V | | Power Dissipation 1W | #### \*Comment: 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 at 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. D.C. Characteristics: $T_A$ = 0°C to 70°C, $V_{CC}$ = 5V ± 10% | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |-----------------|------------------------|----------|----------|----------|-------|---------------------------------------------------------------| | Vol | Output LOW Voltage | | | 0.4 | V | I <sub>OL</sub> = 8 mA | | V <sub>OH</sub> | Output HIGH Voltage | 2.4 | | | v | $I_{OH} = -800 \mu A$ | | V <sub>IL</sub> | Input LOW Voltage | - 0.3 | | 0.8 | v | | | V <sub>IH</sub> | Input HIGH Voltage | 2.2 | | $V_{CC}$ | V | | | I <sub>LI</sub> | Input Leakage Current | <u> </u> | | 10 | μA | $V_{IN} = 0 \text{ to } 5.5V$ | | $I_{LO}$ | Output Leakage Current | | <u> </u> | 10 | μA | V <sub>O</sub> = 0.4 to 5.5V, Chip<br>Deselected | | $I_{CC}$ | Power Supply Current | | | 90 | mA | V <sub>CC</sub> = Max., T <sub>A</sub> = 0°C,<br>Outputs Open | ## Capacitance: $T_A = 25^{\circ}C$ , f = 1Mhz | Symbol | Parameter | Min. | Тур, | Max. | Units | Conditions | |----------|--------------------|------|------|------|-------|----------------| | $C_{IN}$ | Input Capacitance | | | 8 | рF | $V_{IN} = 0V$ | | COUT | Output Capacitance | | | 10 | рF | $V_{OUT} = 0V$ | ## A.C. Characteristics: $T_A$ = 0 to $70^{\circ}C,\,V_{CC}$ = $5\,V\,\pm\,10\%$ | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |------------------|---------------------------|------|------|------|-------|---------------| | t <sub>AA</sub> | Address Access Time | | | 250 | ns | See A.C. Test | | t <sub>ACS</sub> | Chip Select Access Time | | | 100 | ns | Conditions | | t <sub>OFF</sub> | Chip Select Turn-off Time | | | 100 | ns | & Waveforms | #### A.C. Test Conditions Input Pulse Levels Input Rise and Fall Times Input/Output Timing Levels 0.8V to 2.2V 10ns 1.5V A.C. Test Load 1027318 ## **Custom Programming** The preferred method of pattern submission is the AMI Hex format as described below, with its built-in address space mapping and error checking. This is the format produced by the AMI Assembler. The format is as follows and may be on paper tape, punched cards or other media readable by AMI. | Position<br>1<br>2 | Description Start of record (Letter S) Type of record 0 — Header record (comments) 1 — Data record | |--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3,4 | 9 — End of file record Byte Count Since each data byte is represented as two hex characters, the byte count must be multiplied by two to get the number of characters to the end of the record. (This includes checksum and address data.) Records may be of any length defined in each record by the byte count. | | 5, 6, 7, 8 | Address Value The memory location where the first data byte of this record is to be stored. Addresses should be in ascending order. | | 9, , N | Data Each data byte is represented by two hex characters. Most significant character first. | | N+1, N+2 | Checksum The one's complement of the additive summation (without carry) of the data bytes, the address, and the byte count. | | Example: | S 1 1 3 0 0 0 0 4 9 E 9 F 1 0 3 2 0 F 0 4 9 3 1 3 9 F 7 2 0 0 0 F 5 E 0 F 0 0 1 2 6 S 9 0 3 0 0 0 0 F C | | | Start of Record Start of Record Start of Record Start Address O 0 0 0 4 9 8 9 F 1 0 3 2 0 F 0 4 9 3 1 3 9 F 7 2 0 0 0 0 F 5 E 0 F 0 0 1 2 6 | - Only positive logic formats for E<sub>0</sub>, E<sub>1</sub>, E<sub>2</sub> are accepted. 1 = V<sub>HIGH</sub>; 0 = V<sub>LOW</sub> A "0" indicates the chip is enabled by a logic 0. A "1" indicates the chip is enabled by a logic 1. - 3. Paper tape format is the same as the card format above except: - a. The record should be a maximum of 80 characters. - b. Carriage return and line feed after each record followed by another record. - c. There should NOT be any extra line feed between records at all. - d. After the last record, four (4) \$\$\$\$ (dollar) signs should be punched with carriage return and line feed indicating end of file, ## 65,536 BIT (8192 x 8) STATIC VMOS ROM #### Features - ☐ Single +5V ± 10% Power Supply - ☐ High Performance: Maximum Access Time: 350ns - □ EPROM Compatible for Cost Effective System Development - ☐ Completely Static Operation - □ Directly TTL Compatible Inputs - ☐ Three-State TTL Compatible Outputs - $\square$ Fan-out of 5 TTL: $I_{OL} = 8mA @ 0.4V$ ## General Description The AMI S4264 is a 65,536 bit fully static VMOS mask programmable ROM organized as 8192 words by 8 bits. The device is fully TTL compatible on all inputs and outputs and has a single +5V power supply. The three-state outputs facilitate memory expansion by allowing the outputs to be OR-tied to other devices. The S4264 is fully static requiring no clocks for operation. Data access is simple as no address setup times are required. The byte organization of the S4264 makes it ideal for microprocessor applications. The S4264 is fabricated using AMI's proprietary VMOS technology. This permits the manufacture of very high density, high performance mask programmable ROMs. ## Pin Names $A_0$ - $A_{12}$ Address Inputs $\overline{CS}$ Chip Select $O_1$ - $O_8$ Data Outputs $V_{CC}$ +5V Power ## Truth Table | Input | Outputs | Mode | |-------|-----------|--------------| | CS | 01-08 | Mode | | L | $D_{OUT}$ | Read | | H | Hi-Z | Deselected . | ## Absolute Maximum Ratings\* | Ambient Temperature Under Bias | |------------------------------------------------------| | Storage Temperature $-65^{\circ}C$ to $150^{\circ}C$ | | Output or Supply Voltages | | Input Voltages0.5V to 5.5V | | Power Dissipation 1W | \*COMMENT: Stresses above those listed under "Absolute Maximum Rating" 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. D.C. Characteristics: $T_A = 0^{\circ} \, \mathrm{C} \ \mathrm{to} \ 70^{\circ} \, \mathrm{C}, \, V_{CC} = \pm 5 \, \mathrm{V} \pm 10 \%.$ | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |---------------------|------------------------|------|----------|-----------------|---------|-----------------------------------------------------------------------------------------------| | $\overline{v_{ol}}$ | Output LOW Voltage | 1 | | 0.4 | V | I <sub>OL</sub> = 8 mA | | $\overline{v_{OH}}$ | Output HIGH Voltage | 2.4 | | | v | $l_{OH} = -400\mu A$ | | V <sub>IL</sub> | Input LOW Voltage | -0.3 | | 0.8 | v | | | $\overline{v_{IH}}$ | Input HIGH Voltage | 2.2 | | V <sub>CC</sub> | v | | | I <sub>LI</sub> | Input Leakage Current | | | 10 | μΑ | $V_{IN} = 0 \text{ to } 5.5V$ | | $I_{LO}$ | Output Leakage Current | | <u> </u> | 50 | $\mu$ A | $\overline{\text{CS}} \ge 2.4 \text{V}, \text{ V}_{\text{O}} = 0.4 \text{V to } 5.5 \text{V}$ | | $I_{CC}$ | Power Supply Current | | | 145 | mΛ | $V_{\rm CC}$ = Max., $T_{\rm A}$ = 0°C, Outputs<br>Open | Capacitance: $T_A = 25^{\circ}C$ , f = 1 MHz. | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------------------------------------|--------------------|------|------|------|-------|-----------------------| | CIN | Input Capacitance | | | 8 | рF | V <sub>IN</sub> = 0V | | $\overline{\mathrm{C}_{\mathrm{OUT}}}$ | Output Capacitance | | | 10 | рF | V <sub>OUT</sub> = 0V | A.C. Characteristics: $T_A$ = 0°C to 70°C, $V_{CC}$ = +5V $\pm$ 10%. | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |------------------|-------------------------|------|------|------|-------|------------------| | $t_{AA}$ | Address Access Time | | | 350 | ns | Sec Test Circuit | | tACS | Chip Select Access Time | | | 150 | ns | & | | t <sub>OFF</sub> | Chip Deselect Time | 0 | | 150 | nş | Waveforms | ## Wave Forms ## A.C. Test Conditions Input Pulse Levels 0.8V to 2.2V Input Rise and Fall Times 10ns Input/Output Timing Levels 1.5V ## A.C. Test Load ## **Custom Programming** The preferred method of pattern submission is the AMI Hex format as described below, with its built-in address space mapping and error checking. This is the format produced by the AMI Assembler. The format is as follows and may be on paper tape, punched cards or other media readable by AMI. Position 1 Start of record (Letter S) 2 Type of record 0 — Header record (comments) 1 — Data record 9 — End of file record 3, 4 Byte Count Since each data byte is represented as two hex characters, the byte count must be multiplied by two to get the number of characters to the end of the record. (This includes checksum and address data.) Records may be of any length defined in each record by the byte count. 5, 6, 7, 8 Address Value The memory location where the first data byte of this record is to be stored. Addresses should be in ascending order. 9, . . . , N Data Each data byte is represented by two hex characters. Most significant character first. N+1, N+2 Checksum The one's complement of the additive summation (without carry) of the data bytes, the address, and the byte count. #### Example: S 1 1 3 0 0 0 0 4 9 E 9 F 1 0 3 2 0 F 0 4 9 3 1 3 9 F 7 2 0 0 0 F 5 E 0 F 0 0 1 2 6 S 9 0 3 0 0 0 0 F C - 1. Paper tape format is the same as the card format above except: - a. The record should be a maximum of 80 characters. - b. Carriage return and line feed after each record followed by another record. - c. There should NOT be any extra line feed between records at all. - d. After the last record, four (4) \$\$\$\$ (dollar) signs should be punched with carriage return and line feed indicating end of file. # 16,384 BIT (2048x8) STATIC NMOS ROM #### Features - ☐ Single +5V Power Supply - Directly TTL Compatible Inputs - ☐ Three-State TTL Compatible Outputs - ☐ Three Programmable Enables - Access Time: 450ns Maximum - ☐ S6831A: Intel 2316A Pin Compatible - S6831B: 2716 EPROM Pin Compatible - ☐ Low Power: Supply Current is 80mA Maximum ## General Description The AMI 6831 family of 16,384 bit mask programmable Read-Only-Memories offers fully static operation with a single +5V power supply. The device is fully TTL compatible on all inputs and three-state outputs. The three enables are mask programmable, the active level is specified by the user. The S6831 family is available in two pin configurations. One of these, the S6813A, is the pin configuration of a popular ROM: the Intel 2316A. The second pin configuration, the S6813B, is pin compatible with the 2708 and 2716 EPROMs. Software developed in EPROMs can be put in low cost ROM for high volume production. The device is organized as 2048 words by 8 bits, a configuration particularly suitable for microprocessors. The S6831 family is manufactured with an N-channel silicon gate depletion load technology. #### Absolute Maximum Ratings\* | Ambient Temperature Under Bias, -10°C to 80°C | |-----------------------------------------------| | Storage Temperature65°C to 150°C | | Output or Supply Voltage0.5V to 7V | | Input Voltage0.5V to 5.5V | | Power Dissipation | <sup>\*</sup>Comment: 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 at 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. # D.C. Characteristics: $V_{CC}$ = +5V ± 5%; $T_A$ = 0°C to +70°C | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |---------------------|------------------------|------|------|-----------------|-------|-----------------------------------------------------------| | V <sub>OL</sub> | Output LOW Voltage | | | 0.4 | v | $I_{OL} = 2.1 \text{ mA}$ | | Voн | Output HIGH Voltage | 2.4 | 1 | - | v | $I_{QH} = -100\mu A$ | | $v_{\rm IL}$ | Input LOW Voltage | -0.5 | | 0.8 | V | | | $\overline{v_{IH}}$ | Input HIGH Voltage | 2,0 | | V <sub>CC</sub> | v | | | $I_{LI}$ | Input Leakage Current | | | 10 | μΑ | $V_{IN} = 0 \text{ to } 5.25 \text{V}$ | | I <sub>LO</sub> | Output Leakage Current | | | 10 | μΑ | V <sub>OUT</sub> = 0.4 to 2.4V,<br>Chip Deselected | | lcc | Samuel Court of Court | | | 70 | mA | $V_{\rm CC} = {\rm Max.} \ {\rm T_A} = 25^{\circ}{\rm C}$ | | | Power Supply Current | | | 80 | mA | $V_{CC} = Max. T_A = 0^{\circ}C$ | ## Capacitance: f = 1.0 MHz; $T_A = 25^{\circ} \text{C}$ | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |--------|--------------------|------|------|------|-------|-----------------------| | CiN | Input Capacitance | | | 7.5 | рF | $V_{IN} = 0V$ | | COUT | Output Capacitance | Ţ | | 10 | рF | V <sub>OUT</sub> = 0V | # A.C. Characteristics: $V_{CC}$ = +5V ± 5%; $T_A$ = 0°C to +70°C | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |-------------------|---------------------|------|----------|------|-------|------------------| | t <sub>CYC</sub> | Read Cycle Time | 450 | | | ns | | | $\mathbf{t_{AA}}$ | Address Access Time | • | | 450 | ns | See Test Circuit | | tAE | Enable Access Time | • | | 200 | ns | & Waveforms | | toff | Output Disable Time | 10 | <u> </u> | 150 | ns | | 0.8V and 2.0V #### A.C. Test Conditions | Output Load | 1 TTL Gate and $C_L = 100 \text{ pF}$ | |----------------------------------------|---------------------------------------| | Input Rise and Fall Times (10% to 90%) | 20 ns | | Timing Measurement Reference Level | | | 7 1 | 1 V and 9 9 V | #### **Custom Programming** Description Output **Position** The preferred method of pattern submission is the AMI Hex format as described below, with its built-in address space mapping and error checking. This is the format produced by the AMI Assembler. The format is as follows and may be on paper tape, punched cards or other media readable by AMI. | Start of record (Letter S) Type of record 0 — Header record (comments) 1 — Data record 9 — End of file record Byte Count Since each data byte is represented as two bex characters, the byte count must be multiplied | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0—Header record (comments) 1—Data record 9—End of file record Byte Count | | 1 — Data record<br>9 — End of file record<br>Byte Count | | 9 — End of file record<br>Byte Count | | Byte Count | | v | | Since each data hate is represented as two her characters, the hate count must be multiplied. | | by two to get the number of characters to the end of the record. (This includes checksum and address data.) Records may be of any length defined in each record by the byte count. | | Address Value | | The memory location where the first data byte of this record is to be stored. Addresses should be in ascending order. | | Data | | Each data byte is represented by two hex characters. Most significant character first. | | Checksum | | The one's complement of the additive summation (without carry) of the data bytes, the address, and the byte count. | | te zrit I t ( ) | #### Example: S113000049E9F10320F0493139F72000F5E0F00126 89030000 FC #### NOTES: - 1. Only positive logic formats for $E_0$ , $E_1$ , $E_2$ are accepted. $1 = V_{HIGH}$ ; $0 = V_{LOW}$ 2. A "0" indicates the chip is enabled by a logic 0. A "1" indicates the chip is enabled by a logic 1. - 3. Paper tape format is the same as the card format above except: - a. The record should be a maximum of 80 characters. - b. Carriage return and line feed after each record followed by another record. - c. There should NOT be any extra line feed between records at all. - d. After the last record, four (4) \$\$\$\$ (dollar) signs should be punched with carriage return and line feed indicating end of file. # **32,768 BIT (4096x8) STATIC NMOS ROM** #### Features - ☐ Fast Access Time: 450ns Maximum - ☐ Fully Static Operation - ☐ Single +5V ± 10% Power Supply - ☐ Directly TTL Compatible Inputs - ☐ Three-State TTL Compatible Outputs - ☐ Two Programmable Chip Selects - ☐ EPROM Pin Compatible #### General Description The AMI S68332 is a 32,768 bit static mask programmable NMOS ROM organized as 4096 words by 8 bits. The device is fully TTL compatible on all inputs and outputs and has a single +5V power supply. The three state outputs facilitate memory expansion by allowing the outputs to be OR-tied to other devices. The S68332 is pin compatible with UV EPROMs making system development much easier and more cost effective. It is fully static, requiring no clocks for operation. The two chip selects are mask programmable, the active level for each being specified by the user. The S68332 is fabricated using AMI's N-Channel MOS technology. This permits the manufacture of very high density, high performance mask programmable ROMs. #### Absolute Maximum Ratings\* | Ambient Temperature Under Bias10°C to 80°C | |--------------------------------------------| | Storage Temperature65°C to 150°C | | Output or Supply Voltages0.5V to 7V | | Input Voltages0.5V to 5.5V | | Power Dissipation | <sup>\*</sup>COMMENT: Stresses above those listed under "Absolute Maximum Rating" 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. # D.C. Characteristics: $T_A = 0^{\circ} C$ to $70^{\circ} C$ , $V_{CC} = +5V \pm 10\%$ . | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |---------------------|------------------------|------|------|----------|---------|---------------------------------------------| | $\overline{v_{ol}}$ | Output LOW Voltage | | | 0.4 | v | $I_{OL} = 2.1 \text{mA}$ | | V <sub>OH</sub> | Output HIGH Voltage | 2.4 | | | V | $I_{OH} = -200\mu A$ | | VIL | Input LOW Voltage | -0.5 | _ | 0.8 | V | | | V <sub>IH</sub> | Input HIGH Voltage | 2.0 | | $V_{CC}$ | v | | | $I_{LI}$ | Input Leakage Current | | | 10 | μΑ | $V_{IN} = 0$ to $5.5V$ | | $I_{LO}$ | Output Leakage Current | | | 50 | $\mu A$ | $V_{\rm O}$ = 0.4V to 5.5V, Chip Deselected | | $I_{CC}$ | Power Supply Current | | | 100 | mA | $V_{CC} = Max, T_A = 0^{\circ}C$ | # Capacitance: $T_A = 25^{\circ} C$ , f = 1 MHz. | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |---------------------------------------|--------------------|------|------|------|-------|-----------------------| | $\overline{\mathrm{c}_{\mathrm{IN}}}$ | Input Capacitance | | | 7 | рF | $V_{IN} = 0V$ | | Cout | Output Capacitance | | | 10 | рF | V <sub>OUT</sub> = 0V | # A.C. Characteristics: $T_A = 0^{\circ} C$ to $70^{\circ} C$ , $V_{CC} = +5V \pm 10\%$ . | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |------------------|-------------------------|------|------|------|-------|------------------| | t <sub>AA</sub> | Address Access Time | | | 450 | ns | See Test Circuît | | t <sub>ACS</sub> | Chip Select Access Time | | | 150 | ns | & | | t <sub>OFF</sub> | Chip Deselect Time | 0 | | 150 | ns | Waveforms | #### A.C. Test Conditions | Input Pulse Levels | | |----------------------------|----------| | Input Rise and Fall Times | 10ns | | Input/Output Timing Levels | 1.5V | | Output Load | nd 100pF | #### **Custom Programming** The preferred method of pattern submission is the AMI Hex format as described below, with its built-in address space mapping and error checking. This is the format produced by the AMI Assembler. The format is as follows and may be on paper tape, punched cards or other media readable by AMI. | Position | Description | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Start of record (Letter S) | | 2 | Type of record | | | 0 — Header record (comments) | | | 1 — Data record | | | 9 — End of file record | | 3, 4 | Byte Count | | | Since each data byte is represented as two hex characters, the byte count must be multiplied by two to get the number of characters to the end of the record. (This includes checksum and address data.) Records may be of any length defined in each record by the byte count. | | 5, 6, 7, 8 | Address Value | | | The memory location where the first data byte of this record is to be stored. Addresses should be in ascending order. | | 9,, N | Data | | | Each data byte is represented by two hex characters. Most significant character first. | | N+1, N+2 | Checksum | | | The one's complement of the additive summation (without carry) of the data bytes, the address, and the byte count. | | | | ### Example: S 1 1 3 0 0 0 0 4 9 E 9 F 1 0 3 2 0 F 0 4 9 3 1 3 9 F 7 2 0 0 0 F 5 E 0 F 0 0 1 2 6 S 9 0 3 0 0 0 0 F C #### NOTES: - 1. Only positive logic formats for CS<sub>1</sub> and CS<sub>2</sub> are accepted. 1 = V<sub>HIGH</sub>; 0 = V<sub>LOW</sub> 2. A "0" indicates the chip is enabled by a logic 0. - 2. A "0" indicates the chip is enabled by a logic 0. A "1" indicates the chip is enabled by a logic 1. - 3. Paper tape format is the same as the card format above except: - a. The record should be a maximum of 80 characters. - b. Carriage return and line feed after each record followed by another record. - c. There should NOT be any extra line feed between records at all. - d. After the last record, four (4) \$\$\$\$ (dollar) signs should be punched with carriage return and line feed indicating end of file. # 32, 768 BIT (4096 X 8) UV ERASABLE VMOS EPROM #### Features - ☐ Single +5 Volt Power Supply - ☐ Fast Access Time: 250ns Maximum - Automatic Power Down - ☐ Pin Compatible with AMI's 32K ROM: S68332 - ☐ Fully TTL Compatible During Read and Program - + 15V Programming Power Supply: Easy On-Board Programming #### General Description The S4532 is a 32,768 bit ultraviolet light erasable, electrically programmable read-only memory (EPROM) organized as 4096 words by 8 bits. It is fabricated using AMI's proprietary N-channel VMOS technology. The device is fully static requiring no clocks for operation. All the inputs and outputs are fully TTL compatible during both the read and program modes. The S4532 operates from a single +5V supply (read mode) and has a static power down feature that significantly reduces power dissipation. The S4532 is pin compatible with $\Lambda$ MI's 32K ROM, the S68332. Thus for volume production, the user can switch to lower cost ROM. The S4532 requires a +15V supply for programming but all the programming signals are TTL compatible. This considerably eases on board programming. # 16,384 BIT (2048 X 8) UV ERASABLE VMOS EPROM #### Features - ☐ Single + 5 Volt Power Supply - ☐ Fast Access Time: 250ns Maximum - ☐ Pin Compatible with AMI's 16K, 32K and 64K ROMs - ☐ Low Power Dissipation 525mA Maximum Active Power 132mW Maximum Standby Power - ☐ Fully TTL Compatible During Read and Program - +15V Programming Power Supply: Easy On-Board Programming #### **General Description** The S4716 is a 16,384 bit ultraviolet light erasable, electrically programmable read-only memory (EPROM) organized as 2048 words by 8 bits. It is fabricated using AMI's proprietary N-Channel VMOS technology. The device is fully static requiring no clocks for operation. All the inputs and outputs are fully TTL compatible during both the read and program modes. The S4716 operates from a single +5V power supply and has a static power down feature that significantly reduces power dissipation. The S4716 is fully pin compatible with the S4216B and S6831B 16K ROMs, the S68332 32K ROM and the S4264 64K ROM. Thus for volume production, the user can switch to a lower cost ROM. The S4716 requires a +15V supply for programming but all the programming signals are TTL. This considerably eases on-board programming. # $512 \times 8$ BIT ERASABLE AND ELECTRICALLY REPROGRAMMABLE READ ONLY MEMORY #### **Features** - ☐ On-Board Programmability - Fast Access Time 750ns Max. - ☐ High Speed Programming Less than 1 Minute for all 4096 Bits - □ Programmed with R/W, CS and V<sub>PROG</sub> Pins □ Completely TTL Compatible Excluding the - VPROG Pin during Read or Write - ☐ Ultraviolet Light Erasable Less than 10 Minutes - ☐ Static Operation No Clocks Required - □ Three-State Data I/O - ☐ Standard Power Supplies +5V and -12V - ☐ Mature P-Channel Process #### General Description The S5204A is a high speed, static, 512x8 bit, erasable and electrically programmable read only memory designed for use in bus-organized systems. Both input and output are TTL compatible during both read and write modes. Packaged in a 24-pin hermetically sealed dual in-line package, the bit pattern can be erased by exposing the chip to an ultraviolet light source through the transparent lid, after which a new pattern can be written. #### ABSOLUTE MAXIMUM RATINGS | Voltage on any pin relative to VSS except the VPROG pin | n. | | | | | | | | , | | | +0.3 to -20V | |---------------------------------------------------------|----|---|---|----|--|--|---|---|---|--|---|---------------| | Voltage on the VPROG pin relative to VSS | | | , | ⁺. | | | | | | | | +0.3 to -60V | | Operating Temperature | - | | | | | | | | : | | | | | Storage Temperature (programmed) | | | | | | | , | , | | | | 55°C to +85°C | | Storage Temperature (unprogrammed) | - | - | | - | | | , | | | | _ | 55°C to 150°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. DC (STATIC) CHARACTERISTICS ( $V_{CC}$ = +5.0V $\pm$ 5%, $V_{GG}$ = -12.0V $\pm$ 5% $T_A$ = 0 - 70 °C unless otherwise noted). | SYMBOL | CHARACTERISTIC | MIN | MAX | UNIT | |-----------------------|--------------------------------|-----------------------|---------------------|------| | $v_{IL}$ | INPUT VOLTAGE LOW | | 0.8 | v | | $v_{lH}$ | INPUT VOLTAGE HIGH | V <sub>CC</sub> -2.25 | V <sub>CC</sub> +.3 | ) v | | $v_{OL}$ | OUTPUT VOLTAGE LOW | | 0,4 | v | | | I <sub>OL</sub> = 1.6 ma | | ) | | | $v_{\mathrm{OH}}$ | OUTPUT VOLTAGE HIGH | 2.4 | | V | | | $I_{OH} = 200\mu A$ | | <u> </u> | • | | l <sub>LI</sub> | INPUT LEAKAGE CURRENT | | 10 | μa | | $1_{LO}$ | OUTPUT LEAKAGE CURRENT | | 20 | μia | | | CS = 5V | | | | | $\iota_{\mathrm{GG}}$ | V <sub>GG</sub> SUPPLY CURRENT | | 45 | ma | | 1 <sub>CC</sub> | V <sub>CC</sub> SUPPLY CURRENT | | 50 | ma | | $P_{\mathbf{D}}$ | POWER DISSIPATION | | 750 | mw | NOTE: Program input $V_{\mbox{\footnotesize{PROG}}}$ may be tied to $V_{\mbox{\footnotesize{CC}}}$ during the Read. AC (DYNAMIC) CHARACTERISTICS (Loading is as shown in Figure 1 unless otherwise noted). | SYMBOL | CHARACTERISTIC | MIN | MAX | UNIT | |---------------------|--------------------------------|------------|-----|------| | T <sub>ACC</sub> | ACCESS TIME | | 750 | пѕ | | $ au_{\mathrm{CO}}$ | CHIP SELECT TO<br>OUTPUT DELAY | | 400 | ns | | $ au_{ extsf{DD}}$ | CHIP DESELECT TO OUTPUT DELAY | !<br> <br> | | ns | #### FIGURE 1 - TEST CONDITIONS FIGURE 2-READ CYCLE TIMING WAVEFORMS **PROGRAM CHARACTERISTICS** (R/W $G_{nd}$ , Program pulse rise and fall time (10% to 90%) are both at 1 $\mu s$ max). | SYMBOL | CHARACTERISTICS | MIN | MAX | UNIT | |--------------------|-----------------------------|-----|------|--------------------| | TAS | ADDRESS SET UP TIME | 10 | | μς | | TCSS | CHIP SELECT SET UP TIME | 10 | | μs | | TDS | DATA SET UP TIME | 10 | | μs | | TAH | ADDRESS HOLD TIME | 10 | | μs | | T <sub>CSH</sub> | CHIP SELECT HOLD TIME | 10 | | μs | | T <sub>DH</sub> | DATA HOLD TIME | 10 | | μs | | T <sub>PWL</sub> | PROGRAM PULSE WIDTH<br>LOW | 3 | 5 | ms | | T <sub>PWH</sub> | PROGRAM PULSE WIDTH<br>HIGH | 500 | | $\mu_{\mathbb{S}}$ | | V <sub>PROG*</sub> | PROGRAM AMPLITUDE | 55 | - 50 | V | | I <sub>PROG</sub> | PROGRAM CURRENT | | 35 | ma | | TWS | WRITE SET UP TIME | 10 | | μς | | $\tau_{ m WH}$ | WRITE HOLD TIME | 5 | | μs | | T <sub>RS</sub> | READ SET UP TIME | 10 | | $\mu_{\rm S}$ | <sup>\*</sup>Note that in the WRITE mode the MIN value of VPROG should not be exceeded and that chip select, address, and data lines may remain at TTL level, as in the READ mode #### FIGURE 3 - PROGRAMMING CYCLE TIMING WAVEFORMS #### FIGURE 4 - READ/PROGRAM/READ CYCLE TIMING WAVEFORM #### INTERFACE DESCRIPTION | 'in | Label | Function | |---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (15) | D0 | Data Lines — with the R/W line selected for Read (VIL), the Data Lines (D0 through D7) are | | (16) | DI | set to reflect the contents of the selected memory location. When the R/W line is set for | | (17) | D2 | Write (VIH), the Data Lines are stored at the addressed location of the 5204A when VPROG | | (18) | D3 | is present. The Data Bus output drivers are three-state devices that remain in the high im- | | (19) | D4 | pedance (off) state whenever CS is in the VIH state or when R/W is in the VII, state. | | (20) | D5 | | | (21) | D6 | | | (22) | D7 | | | (2) | R/W | Read/Write — When this input line is set to $V_{IH}$ , the device is in the Write mode, a low $(V_{IL})$ signal puts it into the Read mode. | | (3) | cs | Chip Select – This input line must be set to $V_{IL}$ for a Read or Write operation to be performed. When it is High ( $V_{IH}$ ) the output data bus is set to a high-impedance three-state condition. | | 4) \ | PROG | <b>Program</b> – In the Write mode, a 50Volt programming pulse at this input causes the data at the Data Lines to be stored in the selected address location. This pin should be tied to $V_{\rm CC}$ for normal Read operations. | | (5) | A0 | Address Lines - These lines select the 8 bit word in memory for Read or Write operation. | | | Al | The state of s | | 7) [ , | A2 | | | | A3 | | | 9) 1 | A4 | | | 10) | A5 | | | 11) . | A6 | | | 13) | A7 | | | | A8 | | #### CONTROL FUNCTION TRUTH TABLE | CS | R/W | V <sub>PROG</sub> | MODE | OUTPUTS | |----|-----|-------------------|---------|--------------------| | 0 | 1 | V <sub>PROG</sub> | Write | Active Data Inputs | | 0 | 0 | $v_{\rm CC}$ | Read | Active | | 1 | х | x | Standby | Floating | #### **OPERATION** Initially, and after each erasure, all bits of the 5204A are in the LOW state (output 0 volts). Data is stored by selectively programming a HIGH into the desired bit locations. The R/W input (pin 2) is used to select the desired mode of operation. When the R/W input is HIGH the chip is in the write enable mode of operation. The outputs $(D_0 - D_7)$ are disabled (floating) with the corresponding pins becoming the data inputs. The word address is selected in the same manner as in the Read mode. Data to be programmed is presented 8 bits in parallel and after the address and data are set up a programming pulse $(V_P = -50 \text{ volts})$ is applied. $V_{PROG}$ electrically writes the data into the memory array. Writing may be inhibited by deselecting the chip with the CS input at a HIGH during the write cycle. This feature allows true "on board" programming in bus organized systems where the R/W and VPROG inputs are common and the device to be programmed is selected by means of the chip select input as during read operations. The amount of program energy required to insure memory retention may be defined as a function of the number of program pulses (N) times the program pulse width $(t_{pw})$ (N x $t_{pw} \ge 60$ msec). This means if a 3 ms pulse is used, 20 program pulses are required, and if a 5 ms pulse is used 12 program pulses are required. The read operation is accomplished by a LOW at the R/W input with the program input connected to $V_{SS}$ potential. True data (data out = date in) is valid after the address is stable. The CS input will disable (float) the outputs when HIGH to allow capability with bus organized systems. Erasure is accomplished by exposing the array to a 2537Å ultra-violet light source (such as Ultra-Violet Products, Inc. Lamp Model S52 or UVS-54, Turner Designs PROM Eraser, Model 30 or equivalent) for a period of 7 to 10 minutes. The clear optical lid should be approximately one inch away from the lamp tubes. # ERASABLE AND ELECTRICALLY REPROGRAMMABLE READ ONLY MEMORY #### **Features** - On-Board Programmability - $\square$ Fast Access Time 575ns Typ. - ☐ Pin Configuration Similar to the S6830 1K x 8 Bit ROM - ☐ High Speed Programming Less than 1 Minute for All 4096 Bits - □ Programmed with R/W, CS and V<sub>PROG</sub> Pins □ Completely TTL Compatible Excluding the - VPROG Pin - ☐ Ultraviolet Light Erasable Less than 10 Minutes - ☐ Static Operation No Clocks Required - ☐ Three-State Data I/O - ☐ Standard Power Supplies +5V and -12V - ☐ Mature P-Channel Process #### General Description The S6834 is a high speed, static, $512 \times 8$ bit, erasable and electrically programmable read only memory designed for use in bus-organized systems. Both input and output are TTL compatible during both read and write modes. Packaged in a 24 pin hermetically sealed dual in-line package the bit pattern can be erased by exposing the chip to an ultra-violet light source through the transparent lid, after which a new pattern can be written. #### ABSOLUTE MAXIMUM RATINGS | Voltage on any pin relative to VSS except the | ٠V | PR | റദ | pin | | | | | | - | | | | , | +0.3 to -20V | |-----------------------------------------------|----|----|----|-----|--|---|--|--|---|---|--|---|---|----|---------------| | Voltage on the VPROC pin relative to VSS | | | | | | | | | | | | | | | +0.3 to -60V | | Operating Temperature | | | | | | | | | | | | : | | | 0°C to +70°C | | Storage Temperature (programmed) | | | | | | | | | | | | | | | 55°C to +85°C | | Storage Temperature (unprogrammed) . | | | | - | | , | | | ٠ | | | | , | -5 | 55°C to 150°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. DC (STATIC) CHARACTERISTICS ( $V_{CC}$ = +5.0V ± 5%, $V_{GG}$ = -12.0V ± 5% $T_A$ = 0 - 70°C unless otherwise noted). | SYMBOL | CHARACTERISTIC | MIN | MAX | UNIT | |------------------|-----------------------------------|-----------------------|---------------------|------| | $v_{jL}$ | INPUT VOLTAGE LOW | | 0.8 | V | | $v_{lH}$ | INPUT VOLTAGE HIGH | V <sub>CC</sub> -2.25 | V <sub>CC</sub> +.3 | V | | $v_{OL}$ | OUTPUT VOLTAGE LOW 1OL = 1.6 ma | | 0.4 | V | | $v_{OH}$ | OUTPUT VOLTAGE HIGH IOH = 200µA | 2.4 | ! | V | | 1 <sub>LI</sub> | INPUT LEAKAGE CURRENT | | 10 | μa | | ILO | OUTPUT LEAKAGE CURRENT<br>CS = 5V | | 20 | μa | | $^{1}$ GG | V <sub>GG</sub> SUPPLY CURRENT | | 45 | ma | | I <sub>CC</sub> | V <sub>CC</sub> SUPPLY CURRENT | | 50 | ma | | $P_{\mathbf{D}}$ | POWER DISSIPATION | | 750 | mw | NOTE: Program input $V_{\mbox{\footnotesize{PROG}}}$ may be tied to $V_{\mbox{\footnotesize{CC}}}$ during the Read. #### AC (DYNAMIC) CHARACTERISTICS (Loading is as shown in Figure 1 unless otherwise noted). | | CVIADA CONTRACTOR | | N | <b>LAX</b> | I I I I I I I I I I I I I I I I I I I | |---------------|----------------------------------|---------|--------|------------|---------------------------------------| | SYMBOL | CHARACTERISTIC | MIN | (6834) | (6834–1) | UNIT | | TACC | ACCESS TIME | | 575 | 750 | ns ns | | $T_{CO}$ | CHIP SELECT TO OUTPUT DELAY | | 300 | 400 | ns | | $ au_{ m DD}$ | CHIP DESELECT TO<br>OUTPUT DELAY | <u></u> | 250 | 325 | ns | #### FIGURE 1 - TEST CONDITIONS #### FIGURE 2-READ CYCLE TIMING WAVEFORMS PROGRAM CHARACTERISTICS (R/W $G_{nd}$ , Program pulse rise and fall time (10% to 90%) are both at 1 $\mu$ s max). | SYMBOL | CHARACTERISTICS | MIN | MAX | UNIT | |--------------------|-----------------------------|-----|-----|--------------| | T <sub>AS</sub> | ADDRESS SET UP TIME | 10 | | μs | | T <sub>CSS</sub> | CHIP SELECT SET UP TIME | 10 | | $\mu_{ m S}$ | | T <sub>DS</sub> | DATA SET UP TIME | 10 | | $\mu$ s | | T <sub>AH</sub> | ADDRESS HOLD TIME | 10 | | μs | | T <sub>CSH</sub> | CHIP SELECT HOLD TIME | 10 | | μs | | T <sub>DH</sub> | DATA HOLD TIME | 10 | | μs | | T <sub>PWL</sub> | PROGRAM PULSE WIDTH<br>LOW | 3 | 5 | ms | | T <sub>PWH</sub> | PROGRAM PULSE WIDTH<br>HIGH | 500 | | μs | | V <sub>PROG*</sub> | PROGRAM AMPLITUDE | -55 | -50 | V | | 1 <sub>PROG</sub> | PROGRAM CURRENT | ! | 35 | ma | | Tws | WRITE SET UP TIME | 10 | | μs | | T <sub>WH</sub> | WRITE HOLD TIME | 5 | i | μs | | TRS | READ SET UP TIME | 10 | | μѕ | <sup>\*</sup>Note that in the WRITE mode the MIN value of VpROG should not be exceeded and that chip select, address, and data lines may remain at TTL level, as in the READ mode FIGURE 3 - PROGRAMMING CYCLE TIMING WAVEFORMS FIGURE 4 - READ/PROGRAM/READ CYCLE TIMING WAVEFORM #### INTERFACE DESCRIPTION | 'in | Labei | Function | |-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2) | D0 | Data Lines – with the R/W line selected for Read (V <sub>IL</sub> ), the Data Lines (D0 through D7) | | 3) | DI | are set to reflect the contents of the selected memory location. When the R/W line is set | | 4) | <b>D</b> 2 | for Write (VIH), the Data Lines are stored at the addressed location of the 5204A when | | (5) | D3 | VPROG is present. The Data Bus output drivers are three-state devices that remain in the | | (6) | D4 ] | high impedance (off) state whenever CS is in the V <sub>IH</sub> state or when R/W is in the V <sub>IL</sub> | | 7) | D5 | state. | | 8) | D6 | | | 9) | D7 | | | 14) | R/W | $\mbox{Read/Write}-\mbox{When this input line is set to $V_{1H}$, the device is in the Read mode, a low $(V_{1L})$ signal puts it into the Write mode.$ | | 15) | CS | Chip Select — This input line must be set to $V_{IL}$ for a Read or Write operation to be performed. When it is HIGH ( $V_{IH}$ ) the output data bus is set to a high-impedance three-state condition and disables the Write operation. | | 11) | VPROG | <b>Program</b> — In the Write mode, a $-50V$ programming pulse at this input causes the data at the Data Lines to be stored in the selected address location. This pin should be tied to $V_{CC}$ for normal Read operations. | | 24) | A0 | Address Lines - These lines select the 8 bit word in memory for Read or Write operation. | | 23) | A1 | | | 22) | A2 | | | 21) | A3 ] | | | 20) 🕴 | A4 | | | 19) | A5 | | | .8) | A6 | | | (7) | A7 | | | 16) | A8 | | #### CONTROL FUNCTION TRUTH TABLE | cs | R/W | V <sub>PROG</sub> | MODE | OUTPUTS | |----|-----|-------------------|---------|--------------------| | 0 | 0 | V <sub>PROG</sub> | Write | Active Data Inputs | | 0 | i | v <sub>cc</sub> | Read | Active | | 1 | X | X | Standby | Floating | #### OPERATION Initially, and after each erasure, all bits of the 6834 are in the LOW state (output 0 volts) Data is stored by selectively programming a HIGH into the desired bit locations. The R/W input pin 14 is used to select the desired mode of operation. When the R/W input is LOW, the chip is in the write enable mode of operation. The outputs $(0_1 - 0_8)$ are disabled (floating) with the corresponding pins becoming the data inputs $(0_1 \rightarrow D_{[N]})$ etc.). The word address is selected in the same manner as in the read mode. Data to be programmed is presented 8 bits in parallel and after the address and data are set up a programming pulse (Vp = -50 volts) is applied. VPROGwrites the data into the memory array. Writing may be inhibited by deselecting the chip with the CS input at a LOW during the write cycle. This feature allows true "on board" programming in bus organized systems where the R/W and VPROG inputs are common and the device to be programmed is selected by means of the chip select input as during read operations. The amount of program energy required to insure memory retention may be defined as a function of the number of program pulses (N) times the program pulse width $(t_{pw})$ (N x $t_{pw} \ge 60$ msec). This means if a 3 ms pulse is used, 20 program pulses are required, and if a 5 ms pulse is used 12 program pulses are required. The read operation is accomplished by a HIGH at the R/W input with the program input connected to VSS potential. True data (data out = data in) is valid after the address is stable. The CS input will disable (float) with the outputs when HIGH to allow capability with bus organized systems. Erasure is accomplished by exposing the array to a high intensity ultra-violet light source (such as, Ultra-Violet Products, Inc. Lamp Model S52 or UVS-54) for a period of 7 to 10 minutes. The clear optical lid should be approximately one inch away from the lamp tubes. # S6800 Family ## THE AMI S6800 MICROCOMPUTER SYSTEMS FAMILY | DESCRIPTION | POWER SUPPLIES | INPUT/OUTPUT | PACKAGES | |----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 8-Bit Microprocessor (1.0MHz Clock Rate) | + 5V | TTL | 40 Pin | | 8-Bit Microprocessor (1.5MHz Clock Rate) | + 5V | TTL | 40 Pin | | 8-Bit Microprocessor (2.0MHz Clock Rate) | + 5V | TIL | 40 Pin | | 8-Bit Microcomputer | +5V | TTL | TBA | | 1024 Bit (128x8) Microprocessor | | TTL | 40 Pin | | High Performance Monolithic Microprocessor | +5V | TTL | TBA | | 1024 Bit (128x8) Static Read/Write Memory | | | 24 Pin | | (450ns Access Time) | + 5 <b>V</b> | DTL/TTL | 40 Pin | | 1024 Bit (128x8) Static Read/Write Memory | | | | | (350ns Access Time) | +5V | TTL/CMOS | 24 Pin | | 1024 Bit (128x8) Static Read/Write Memory | | | | | (360ns Access Time) | +5V | TTL/CMOS | 24 Pin | | 1024 Bit (128x8) Static Read/Write Memory | | | | | (250ns Access Time) | +5V | TTL | 24 Pin | | Peripheral Interface Adapter (PIA) | +5٧ | TTL | 40 Pin | | Peripheral Interface Adapter (PIA) | +5V | TTL | 40 Pin | | Peripheral Interface Adapter (PIA) | +5٧ | TTL/CMOS | 40 Pin | | Peripheral Interface Adapter (PIA) | + 5V | TTL/CMO\$ | 40 Pin | | 16,384 Bit (2048x8) ROM | + 5V | TŢĮ, | 24 Pin | | 16,384 Bit (2048x8) ROM | +5V | TTL | 24 Pin | | 4096 Bit (512x8) EPROM | + 5V, -12V | Three-State | 24 Pin | | Programmable Timer | +5V | TTL | 28 Pin | | NMOS Combination ROM, I/O, Timer | +5٧ | TTL | 40 Pin | | Asynchronous Communication Interface Adapter | +5V | TTL | 24 Pin | | Asynchronous Communication Interface Adapter | +57 | TTL | 24 Pin | | Asynchronous Communication Interface Adapter | + 5V | TTL | 24 Pin | | Synchronous Serial Data Adapter (SSDA) | +57 | TTL | 24 Pin | | Advanced Data Link Controller | +5V | TTL | 24 Pin | | Advanced Data Link Controller | + 5V | TTL | 24 Pin | | Video Display Generator | + 5V | TTL | 40 Pin | | General Purpose Interface Adapter (GPIA) | - + 5V | | 40 Pin | | | 8-Bit Microprocessor (1.0MHz Clock Rate) 8-Bit Microprocessor (2.0MHz Clock Rate) 8-Bit Microprocessor (2.0MHz Clock Rate) 8-Bit Microprocessor (2.0MHz Clock Rate) 8-Bit Microprocessor (2.0MHz Clock Rate) 8-Bit Microprocessor 1024 Bit (128x8) Microprocessor 1024 Bit (128x8) Static Read/Write Memory (450ns Access Time) 1024 Bit (128x8) Static Read/Write Memory (350ns Access Time) 1024 Bit (128x8) Static Read/Write Memory (360ns Access Time) 1024 Bit (128x8) Static Read/Write Memory (250ns Access Time) 1024 Bit (128x8) Static Read/Write Memory (250ns Access Time) Peripheral Interface Adapter (PIA) Peripheral Interface Adapter (PIA) Peripheral Interface Adapter (PIA) Peripheral Interface Adapter (PIA) 16,384 Bit (2048x8) ROM 16,384 Bit (512x8) ERDM Programmable Timer NMOS Combination ROM, I/O, Timer Asynchronous Communication Interface Adapter Asynchronous Communication Interface Adapter Asynchronous Communication Interface Adapter Synchronous Serial Data Adapter (SSDA) Advanced Data Link Controller Video Display Generator | 8-Bit Microprocessor (1.0MHz Clock Rate) +5V 8-Bit Microprocessor (2.0MHz Clock Rate) +5V 8-Bit Microprocessor (2.0MHz Clock Rate) +5V 8-Bit Microcomputer +5V 1024 Bit (128x8) Microprocessor +5V 1024 Bit (128x8) Microprocessor +5V 1024 Bit (128x8) Static Read/Write Memory (450ns Access Time) +5V 1024 Bit (128x8) Static Read/Write Memory (350ns Access Time) +5V 1024 Bit (128x8) Static Read/Write Memory (360ns Access Time) +5V 1024 Bit (128x8) Static Read/Write Memory (260ns Access Time) +5V 1024 Bit (128x8) Static Read/Write Memory (260ns Access Time) +5V Peripheral Interface Adapter (PIA) Asynchronous Communication Interface Adapter +5V Asynchronous Communication Interface Adapter +5V Asynchronous Communication Interface Adapter +5V Asynchronous Communication Interface Adapter +5V Synchronous Communication Interface Adapter +5V Advanced Data Link Controller +5V Advanced Data Link Controller +5V Video Olsplay Generator +5V | 8-Bit Microprocessor (1.0MHz Clock Rate) | 8-BIT MICROPROCESSOR #### **FEATURES** - Eight-Bit Parallel Processing - Bi-Directional Data Bus - Sixteen-Bit Address Bus 65536 Bytes of Addressing - 72 Instructions Variable Length - Seven Addressing Modes Direct, Relative, Immediate, Indexed, Extended, Implied and Accumulator - Variable Length Stack - Vectored Restart - 2 Microsecond Instruction Execution - Maskable Interrupt Vector - Separate Non-Maskable Interrupt Internal Registers Saved in Stack - Six Internal Registers Two Accumulators, Index Register, Program Counter, Stack Pointer and Condition Code Register - Direct Memory Access (DMA) and Multiple Processor Capability - Clock Rates − \$6800 − 1.0 MHz \$68A00 - 1.5 MHz S68B00 - 2.0 MHz - Simple Bus Interface Without TTL - Halt and Single Instruction Execution Capability #### ABSOLUTE MAXIMUM RATINGS | Supply Voltage V <sub>CC</sub> Input Voltage V <sub>IN</sub> - 0.3 to + 7.0V | Operating Temperature Range T <sub>A</sub> 0°C to + 70°C Industrial Temperature Range -40°C to +85°C Military Temperature Range -55°C to +125°C Storage Temperature Range T <sub>Stg</sub> -55°C to +150°C | |------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| #### ELECTRICAL CHARACTERISTICS $(V_{CC} = 5.0 \text{ V}, \pm 5\%, V_{SS} = 0, T_A \text{ unless otherwise noted.})$ | SYMBOL | CHARACTERISTICS | MIN | TYP | MAX | UNIT | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------------------|------------------------------------------------|------| | V <sub>IH</sub><br>V <sub>IHC</sub> | Input High Voltage (Normal Operating Levels) Logic φ1, φ2 | V <sub>SS</sub> + 2.0<br>V <sub>CC</sub> - 0.6 | _<br>_ | V <sub>CC</sub><br>V <sub>CC</sub> + 0.3 | Vdc | | V <sub>IL</sub><br>V <sub>ILC</sub> | Input Low Voltage (Normal Operating Levels) Logic φ1, φ2 | V <sub>SS</sub> - 0.3<br>V <sub>SS</sub> - 0.3 | _<br>_ | V <sub>SS</sub> + 0.8<br>V <sub>SS</sub> + 0.4 | Vdc | | līN | Input Leakage Current | _<br>_<br>_ | 1.0 | 2.5<br>100 | μAdc | | l <sub>TSI</sub> | Three-State (Off State) Input Current $D0 - D7$<br>$V_{IN} = 0.4$ to 2.4V, $V_{CC} = Max$ $A0 - A15$ , R/W | - | 2.0 | 10<br>100 | μAde | | Voн | Output High Voltage<br>$(1_{LOAD} = -205\mu\text{Adc}, \text{V}_{CC} = \text{Min})$ D0 - D7<br>$(1_{LOAD} = -145\mu\text{Adc}, \text{V}_{CC} = \text{Min})$ A0 - A15,<br>R/W, VMA | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | - | _ | Vác | | | $(I_{LOAD} = -100\mu Ade, V_{CC} = Min)$ BA | V <sub>SS</sub> + 2.4 | | <u> </u> | | | VOL | Output Low Voltage<br>(LLOAD = 1.6mAdc, VCC = Min) | | | V <sub>SS</sub> + 0.4 | Vdc | | $P_{\mathrm{D}}$ | Power Dissipation | - | 0.5 | 1.0 | W | | CIN | Capacitance # $(V_{\rm IN}=0,T_{\rm A}\approx 25^{\circ}{\rm C},{\rm f}=1.0~{\rm MHz}) \qquad \qquad \phi 1 \\ \phi 2 \\ {\rm D0-D7} \\ {\rm Logic~Jinputs}$ | -<br><br> | -<br>-<br>10<br>6.5 | 35<br>70<br>12.5 | рF | | COUT | A0 - A15, R/W, VMA | _ : | _ | 12 | рF | | f | Frequency of Operation S68A00<br>S68B00 | 0.1 | _ | 1.5<br>2.0 | MHz | | †CYC | Clock Timing (Figure 1) \$68A00 Cycle Time \$68B00 | 0.666<br>0.50 | _<br>_ | 10<br>10 | μş | | ₽₩øH | Clock Pulse Width $\phi 1, \phi 2 = $68A00$<br>Measured at $V_{CC} = 0.6V$ $\phi 1, \phi 2 = $68B00$ | 230<br>180 | <u>-</u> | 9500<br>9500 | ns | | <sup>t</sup> UT | Total \$\phi_1\$ and \$\phi_2\$ Up Time S68 A00 S68 B00 | 600<br>440 | _<br>_ | - <br> - | ns | | tφr, tφf | $$\operatorname{Rise}$ and Fall Times Measured between VSS + 0.4 and VCC – 0.6 | 5.0 | _ | 100 | ns | | <sup>†</sup> d | Delay Time or Clock separation Measured at VOV = VSS + 0.6V | 0 | _ | 9100 | пs | <sup>\*</sup>Except $\overline{IRQ}$ and $\overline{NMI}$ , which require $K\Omega$ pullup load resistor for wire-OR capability at optimum operation. #Capacitances are periodically sampled rather than 100% tested. #### READ/WRITE TIMING | | | S6800 | | | S68A00 | | S68B00 | | | T | | |----------------------|------------------------------------------------------------------------------------|-------|------|-------|---------------|------|--------------|-----------|------|------------|-------| | Symbol | Parameter | Min. | Typ. | Max. | Min. | Typ. | Max. | Min. | Typ. | Max. | Units | | t <sub>AD</sub> | Address Delay | | | | † <del></del> | | | | | _ | ns | | | C = 90pF<br>C = 30pF | | 100 | 300 | | | 180<br>165 | į | | 150<br>135 | | | tACC | Peripheral Read Access Time $t_{\rm AC} = t_{\rm UT} - (t_{\rm AD} + t_{\rm DSR})$ | | | 575 | | | 360 | | | 250 | ns | | t <sub>DSR</sub> | Data Setup Time (Read) | 100 | | | 60 | | | 40 | | | пѕ | | t <sub>J1</sub> | Input Data Hold Time | 10 | 30 | | 10 | | i | 10 | | | пs | | t <sub>H</sub> — | Output Data Hold Time | 10 | 25 | i — — | 10 | 25 | <del> </del> | 10 | 25 | | ns. | | r <sub>AH</sub> | Address Hold Time<br>(Address, R/W, VMA) | | | | 10 | 75 | | 10 | 75 | | ns | | $t_{EH}$ | Enable High Time for<br>DBE Input | 470 | | | 280 | | | 220 | | | пѕ | | toow | Data Delay Time (Write) | | | | | 165 | 200 | | | 160 | ns | | $t_{PCS}$ | Processor Controls Processor Control Setup Time | | | 200 | 200 | | | 200 | | | ns | | $t_{PC_p}; t_{PC_p}$ | Processor Control<br>Rise and Fall Time | | | | | | 100 | ļ | | 100 | ns | | $t_{BA}$ | Bus Available Delay | | | | | | 270 | ļ | ļ | 270 | ns | | $t_{TSE}$ | Three-State Enable | | | | | | 40 | I | ļ | 40 | ns | | t <sub>TSD</sub> | Three-State Delay | | | | | | 270 | | ļ | 270 | ns | | t <sub>DBE</sub> | Data Bus Enable Down<br>Time During of Up Time | | | | 150 | | | l<br>[ 70 | | | ns | | torr, | Data Bus Enable | | | | | | 25 | İ | | 25 | ns | | t <sub>DBE</sub> | Rise and Fall Times | | } | 1 | İ | | Ì | <u> </u> | } | | | #### INTERFACE DESCRIPTION | Label | Pin | |----------|-------------| | Ø1<br>Ø2 | (3)<br>(37) | | RESET | (40) | Function Clocks Phase One and Phase Two - Two pins are used for a two-phase non-overlapping clock that runs at the VCC voltage level. 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. If a positive edge is detected on the input, this will signal the MPU to begin the restart sequence. This will start execution 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 IRO. Reset must be held low for at least eight clock periods after VCC reaches 4.75 volts (Figure 4). If Reset goes high prior to the leading edge of \$\phi2\$, on the next \$\phi1\$ the first restart memory vector address (FFFE) will appear on the address lines. This location should contain the higher order eight bits to be stored into the program counter. Following, the next address FFFF should contain the lower order eight bits to be stored into the program counter. FIGURE 5 INITIALIZATION OF MPU AFTER RESTART (5) VMA Valid Memory Address - 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 30 pF may be directly driven by this active high signal. | Label | Pin | Function | |------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A0<br>• | (9) | Address Bus — Sixteen pins are used for the address bus. The outputs are three-state bus drivers capable of driving one standard TTL load and 130 pF. When the output is turned off, it is essentially an open circuit. This permits the MPU to be used in DMA applications. | | A15 | (25) | | | TSC | (39) | Three-State Control — This input causes all of the address lines and the Read/Write line to go into the off or high impedance state. This state will occur 500 ns after TSC = 2.4 V. The Valid Memory Address and Bus Available signals will be forced low. The data bus is not affected by TSC and has its own enable (Data Bus Enable). In DMA applications, the Three-State Control line should be brought high on the leading edge of the Phase One Clock. The $\phi1$ clock must be held in the high state and the $\phi2$ in the low state for this function to operate properly. The address bus will then be available for other devices to directly address memory. Since the MPU is a dynamic device, it can be held in this state for only 5.0 $\mu$ s or destruction of data will occur in the MPU. | | D0<br>• | (33) | Data Bus — Eight pins are used for the data bus. It is bi-directional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load at 130 pF. | | <b>D</b> 7 | (26) | · | | DBE | (36) | Data Bus Enable — This input is the three-state control signal for the MPU data bus and will enable the bus drivers when in the high state. This input is TTL compatible; however in normal operation, it can be driven by the phase two clock. During an MPU read cycle, the data bus drivers will be disabled internally. When it is desired that another device control the data bus such as in Direct Memory Access (DMA) applications, DBE should be held low. | | R/W | (34) | Read/Write — 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). Three-State Control going high will turn Read/Write to the off (high-impedance) state. Also, when the processor is halted, it will be in the off state. This output is capable of driving one standard TTL load and 130 pF. | | HALT | (2), | 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 instruction, Bus Available will be at a one level, Valid Memory Address will be at a zero, and all other three-state lines will be in the three-state mode. Transition of the Halt line must not occur during the last 250 ns of phase one. To insure single instruction operation, the Halt line must go high for one Phase One Clock cycle. | | ВА | (7) | Bus Available — 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. This will occur if the $\overline{\text{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 $I = 0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF. | | Label | Pin | Function | |-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ĪRQ | (4) | Interrupt Request - This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will wait until it completes the current instruction that is being executed 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 address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations causes the MPU to branch to an interrupt routine in memory. The Halt line must be in the high state for interrupts to be recognized. | | | | The IRQ has a high impedance pullup device internal to the chip; however a 3 k $\Omega$ external resistor to VCC should be used for wire-OR and optimum control of interrupts. | | ÑМÏ | (6) | Non-Maskable Interrupt — A low-going edge on this input requests that a non-mask 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 NMI signal. The interrupt mask bit in the Condition Code Register has no effect on $\overline{\text{NMI}}$ . The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away in the stack. At the end of the cycle, a 16-bit address will be loaded that points to a vectoring address which is located in memory locations FFFC and FFFD. An address loaded at these locations causes the MPU to branch to a non-maskable interrupt routine in memory. NMI has a high impedance pullup resistor internal to the chip; however a 3 k $\Omega$ external resistor to VCC should be used for wire-OR and optimum control of interrupts. | | | | Inputs ! $\overline{RQ}$ and $\overline{NM}$ ! are hardware interrupt lines that are acknowledged during $\phi$ 2 and will | start the interrupt routine on the $\phi 1$ following the completion of an instruction. INTERRUPTS — As outlined in the interface description the S6800 requires a 16-bit vector address to indicate the location of routines for Restart, Non-maskable Interrupt, and Maskable Interrupt. Additionally an address is required for the Software Interrupt Instruction (SWI). The processor assumes the uppermost eight memory locations, FFF8 — FFFF, are assigned as interrupt vector addresses as defined in Figure 6. After completing the current instruction execution the processor checks for an allowable interrupt request via the IRQ or NMI inputs as shown by the simplified flow chart in Figure 7. Recognition of either external interrupt request or a Wait for Interrupt (WAI) or Software Interrupt (SWI) instruction causes the contents of the Index Register, Program Counter, Accumulators and Condition Code Register to be transferred to the stack as shown in Figure 8. #### FIGURE 6 MEMORY MAP FOR INTERRUPT VECTORS | Vec | tor | Description | |------|------|------------------------| | MS | LS | Description | | FFFE | FFFF | Restart | | FFFC | FFFD | Non-maskable Interrupt | | FFFA | FFFB | Software Interrupt | | FFF8 | FFF9 | Interrupt Request | FIGURE 7 MPU FLOW CHART FIGURE 8 SAVING THE STATUS OF THE MICROPROCESSOR IN THE STACK #### MPU REGISTERS The MPU has three 16-bit registers and three 8-bit registers available for use by the programmer. **Program Counter** – The program counter is a two byte (16-bits) 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 sixteen 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 the 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 9 PROGRAMMING MODEL OF THE MICROPROCESSOR #### \$6800/\$68A00/\$68B00 #### MPU ADDRESSING MODES The S6800 eight-bit microprocessing unit has 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 Figure 9 along with the associated instruction execution time that is given in machine cycles. With a clock frequency of I MHz, these times would be microseconds. #### ACCUMULATOR ADDRESSING (ACCX) OP CODE A single byte instruction addressing operands only in accumulator A or accumulator B. #### IMPLIED ADDRESSING OP CODE Single byte instruction where the operand address is implied by the instruction definition (i.e., Stack Pointer, Index Register or Condition Register). #### IMMEDIATE ADDRESSING Two or three byte instructions with an eight or sixteen bit operand respectively. For accumulator operations the eight bit operand is contained in the second byte of a two byte instruction. For Index Register operations (e.g. LDX) sixteen bit operand is contained in the second and third byte of a three byte instruction. #### DIRECT ADDRESSING | OP CODE ADDRESS<br>0-255 | OP CODE | 1 | |--------------------------|---------|---| |--------------------------|---------|---| Two byte instructions with the address of the operand contained in the second byte of the instruction. This format allows direct addressing of operands within the first 256 memory locations. #### EXTENDED ADDRESSING | OP CODE | ADDRESS<br>HIGHER | ADDRESS<br>LOWER | |---------|-------------------|------------------| |---------|-------------------|------------------| Three byte instructions with the higher eight bits of the operand address contained in the second byte and the lower eight bits of address contained in the third byte of the instruction. This format allows direct addressing of all 65,536 memory locations. #### INDEXED ADDRESSING | OP CODE | INDEX | | |---------|---------|--| | | ADDRESS | | Two byte instructions where the 8 bit unsigned address contained in the second byte of the instruction is added to the sixteen bit Index Register resulting in a sixteen bit effective address. The effective address is stored in a temporary register and the contents of the Index Register are unchanged. #### RELATIVE ADDRESSING | OP CODE | RELATIVE<br>ADDRESS | |---------|---------------------| Two byte instructions where the relative address contained in the second byte of the instruction is added to the sixteen bit program counter plus two. The relative address is interpreted as a two's complement number allowing relative addressing within a range of -126 to +129 bytes of the present instruction. FIGURE 10 S6800 INSTRUCTION SET | | | Addressing Mode | | | | | | | Condition Reg | |-----------------------------------|--------------|------------------|--------------------|------------------|------------------|-------------------|----------|----------------------------------------------------|-----------------------------------------| | | ] | Impled | Immediate | Direct | Extended | Judexed | Relative | Boolean/Arith | 5 4 3 2 1 0 | | Instruction | Mnemonic | OP MC PB | OP MC PB | OP MC PB | OP MC PB | OP MC PB | OP MC PB | Operation | HITMZIVIC | | Load accumulator | LDAA | | 86 2 2 | 96 3 2 | B6 4 3 | A6 5 2 | | M + A | 1 1 R | | Load stack pointer | LDAB<br>LDS | | (6 2 2<br> XE 3 3 | D6 3 2<br>9E 4 2 | F6 4 3<br>BE 5 3 | 66 5 2<br>Al: 6 2 | | M → B<br>M → SP <sub>H</sub> , (M + 1) | • • • • • • • • • • • • • • • • • • • | | Load index | LDX | | CE 3 3 | DE 4 2 | HE 5 3 | bE 6 2 | | ] → SP <sub>L</sub><br>M → X <sub>H×</sub> (M + 1) | • • • t R • | | register | | | 1 | | | 1 | | ·- X <sub>L</sub> | | | Store accomulator | STAA<br>STAB | | ļ. | 97 4 ± D7 4 ± | B7 5 3<br>17 5 3 | A7 6 2<br>E7 6 2 | | A ··· M<br>B → M | • • t t R • | | Store stack | STS | | Ì | UF 5 | BF 6 3 | AF 7 2 | | SP <sub>H</sub> M. SP <sub>1</sub> | - 9 0 0 R | | pointer<br>Store index | STX | | } | DF 5 2 | FF 6 3 | EF 7 2 | | (M + 1)<br>$X_H \rightarrow M, X_L \rightarrow$ | • • • t R • | | register | 377 | | | " , - | '' ' ' | ] - ' - | | (M+1) | | | Transfer accumu-<br>lators | TAB | 16 2 1 | | ] | | ļ | | A → B | - 1 1 R | | III (O/S | TBA | 17 2 1 | | | | 1 | | B - A | • • 1 1 R | | Transfer Acc. to | TAP | 06 2 1 | | 1 | | <b>(</b> | | A→CCR | Note 12 | | cond. reg.<br>Transfer cond. reg. | IAF | 06 2 1 | | 1 | | | | 2-44 | 111 | | to Acc. | TPA | 07 2 1 | | 1 | l<br>İ | | | CCR - A | - - - - | | Transfer stok pti to<br>index | TSX | 30 4 1 | 1 | | } | | | SP+1 → X | | | Transfer index to | 7110 | | | 1 | | | | X 1 → SP | | | stek ptr<br>Pull data | TXS<br>PULA | 35 4 1<br>32 4 1 | | J | | 1 | | SP+1→SP.MSP | | | <i>.,,</i> - <b>.</b> | PULB | 33 4 1 | | ] | | | | → A<br>SP + → SP. | . . . . | | | | | | ] | | | | MSP → B | | | Push data | PSHA | 36 4 1 | | j | | 1 | | A +M <sub>SP</sub> ,5P 1<br>→SP | | | | PSHB | 37 4 1 | | <u> </u> | | ] | | B → M <sub>SP</sub> , SP I<br>→ SP | • • • • • | | Add accumulators | ABA | 1B 2 1 | | | | 1 1 | | A+B-+A | 10-11-11 | | Add | ADDA<br>ADDB | | 88 2 2<br>CB 2 2 | 9B 3 2<br>DB 3 2 | BB 4 3<br>FB 4 3 | AB 5 2<br>EB 5 2 | | A + M → A<br>B + M → B | 1 0 1 1 1 1 | | Add with carry | ADCA | | 89 2 2 | 99 3 2 | B9 4 3 | A9 5 2 | | A+M+C+A | t • 11111 | | Subtract | ADCB | | C9 2 2 | D9 3 2 | F9 4 3 | E9 5 2 | | B+M+C→B | 1 1 1 1 1 1 | | accumulators | SBA | 10 2 1 | 1 | 1 | - | | | A – B → A | • • : : : : | | Subtract | SUBA<br>SUBB | | 80 2 2<br>C0 2 2 | 90 3 2<br>D0 3 2 | BO 4 3<br>FO 4 3 | A0 5 2<br>E0 5 2 | | A · M · A<br>B – M · B | | | Subtract with | 31,60 | | C0 2 2 | 1 20 3 2 | 10 4 3 | E0 5 2 | | ļ | | | carry | SBCA<br>SBCB | | 82 2 2<br>C2 2 2 | 92 3 2<br>D2 3 2 | B2 4 3<br>F2 4 3 | A2 5 2 | | A M · C → A<br>B M C → B | • • † † † † † • • † † † 5 • • † † † 5 • | | Increment | INCA | 4C 2 1 | | 10232 | FZ 4 3 | E2 5 2 | | A+1-A | • • • • • • | | | INCB | 5C 2 1 | 1 | | <b>.</b> | 1 | | B + 1 → B<br>M + 1 → M | • • 1 1 5 • | | Increment stack | INC. | | 1 | | 7C 6 3 | 6C 7 2 | | | - - - - - - | | pointer | INS | 31 4 L | 1 | İ | 1 | | | SP+ + → SP | | | Increment index reg. | 1NX | 08 4 1 | ( | 1 | | | | X+1→X | • • • • • | | Decrement | DECA | 4A 2 I | 1 | 1 | ļ | ] | | A - 1 + A | 0 0 0 1 0 0<br>0 0 1 4 0 | | | DECB | 5A 2 1 | ] | į | 7A 6 3 | 6A 7 2 | | B 1 + B<br>M ~ 1 → M | | | Decrement stack | ļ | l | ] | ) | | | | | | | pointer<br>Decrement index | DES | 34 4 1 | 1 | | | 1 | | SP 1 → SP | | | register | DEX | 09 4 1 | | | | | | X - 1 - X | | | Complement (1's) | COMA<br>COMB | 43 2 1<br>53 2 1 | 1 | | | | | A → A<br>B → B | • • 1 1 RS | | | СОМ | | 1 | | 73 6 3 | 63 7 2 | | M→M | • • ‡ ‡ R S | | Complement (2's) | NEGA | 40 2 1 | | 1 | į. | j | | 00 – A → A | | | | NEGB<br>NEG | 50 2 1 | ] | | 70 6 3 | 60 7 2 | | 00 - B → B<br>00 - M → M | 0 0 1 1 1 2 | | Decimal adjust | | | ] | ! | | | | | | | accumulator | DAA | 19 2 1 | 1 | 1 | Ī | į į | | | ¦ •l•l∓l∓βः∣₃ | OP = Operation Code MC = Number of MPU Cycles PB = Number of Program Bytes FIGURE 10 S6800 INSTRUCTION SET (CONT'D.) | | | ] | | Addressi | ng Mude | | | | Condition Reg | |---------------------------------------------------|---------------------|------------------|------------------|------------------|------------------|------------------|------------------|---------------------------------------------------------------|-------------------------------------| | | | Implied | Immediate | Direct | Extended | Indexed | Relative | Boolean/Arith | 5 4 3 2 1 0 | | Instruction | Mnemunic | OP MC PB | OP MC PB | ОР МС РВ | ОР МС РВ | ОР МС РВ | ор мс рв | Operation | HJ1 NZVC | | Logical and | ANDA | | 84 2 3<br>C4 2 2 | 94 3 2<br>D4 3 2 | B4 4 3<br>F4 4 3 | A4 5 2<br>E4 5 3 | | A ◆ M → A<br>B ◆ M → B | | | Inclusive or | ANDB<br>ORAA | | 8A 2 2 | 9A 3 2 | BA 4 3 | AA 5 2 | ! | A + M - A | l alaititi Riu | | | ORAB | | CA 2 2 | DA 3 2 | FA 4 3 | EA 5 2 | | B + M → B | │ ■ ● ₺ ₺ ₽ ● | | Exclusive or | LORB | | 88 2 2<br>C8 2 2 | 08 3 2<br>D8 3 2 | 88 4 3<br>F8 4 3 | AS 5 2<br>ES 5 2 | j | A ⊕ M → A<br>B ⊕ M → B | • • ÷ ; R • | | Shift left arithmetic | ASLA<br>ASLB<br>ASL | 48 2 t<br>58 2 t | ! | ! | 78 6 3 | 68 7 2 | | A B C + 107 100 - 0 | • • ‡ ‡ 6 †<br>• • ‡ ‡ 6 † | | Shift right | ., | | | | | <u> </u> | | | 1 1.1.1.1.1. | | authmetic | ASRA | 47 2 1 | | | l | i | ļ | A | 1 1 6 1 | | | ASRB<br>ASR | 57 2 1 | | | 77 6 3 | 67 7 2 | i | M 67 60 C | | | Shift right logical | LSRA | 44 2 1 | , | | - | 1 | | A) | - R 1 6 1 | | | 1.5₹₺ | 54 2 1 | | | 1 | ] | 1 | B 0 → 11111111 → 0 | | | | L.S.R | | | | 74 6 3 | 64 7 2 | ] | M) 67 80 C | • R 1 6 1 | | Rotate left | ROLA | 49 2 I<br>59 2 I | | | ļ | | ļ | B □ | l alalifilala [ | | | R(H | | | | 79 6 3 | 69 7 2 | | -M C 67 60 | 1 + + + | | Rotete right | RORA | 46 7 7 | | | <u> </u> | 1 | 1 | A) La - mmna | • # # 6 #<br>• # # 6 #<br>• # # 6 # | | | RORB<br>ROR | 56 2 1 | | | 76 6 3 | 66 7 2 | | M C 67 - 60 | 0 1 1 6 1 | | Compare accumu- | | | | | } | į<br> | <u> </u> | A · · B | <br> • • : : : : | | lators | CBA<br>CMPA | 11 3 : | 81 2 2 | 91 3 2 | B) 4 J | A1 5 2 | • | A - M | | | Compare | CMPB | | C1 2 2 | D: 3 2 | FI 4 3 | EI 5 2 | i | B – M | • • ; : : : | | Compare index<br>register | CPX | | 8C 3 3 | 9C 4 2 | BC 5 3 | AC 6 2 | İ | $\mathbf{x}_H - \mathbf{M}_* \mathbf{x}_L - (\mathbf{M} + 1)$ | 7 t s | | Test (zero ur | 70704 | 40. 3. 1 | | | İ | | | A - 00 | • • ‡ ‡ R ] | | minus) | TSTA<br>TSTB | 4D 2 1<br>5D 2 1 | | | , | ſ | İ | B = 00 | • • ‡ ‡ R | | | TST | 35 | | | 7D 6 3 | 6D 7 2 | | м - 00 | I 이어되되R | | Bit test | BITA | | 85 2 2 | 95 3 2 | B5 4 3 | A5 5 2 | | A = M | • • ‡ ‡ R | | Dit test | BITB | | CS 2 Z | D5 3 2 | F5 4 3 | ES 5 2 | j | B ◆ M<br>TEST | 1 | | Branch<br>Branch of carry | BRA | | | | | } | 20 4 2 | | | | clear | BCC | 1 | | | | 1 | 24 4 2 | C = 0 | / • • •}• • | | Branch if carry<br>set | BCS | | | | | | 25 4 2 | C=1 | - - - - - | | Branch if overflow<br>clear<br>Branch if overflow | BVC | | | | ŀ | } | 28 4 2 | V-0 | • • • • • | | sel | BVS | | ļ | • | 1 | }<br>1 | 29 4 2 | V=1 | <b>! • • • • </b> • | | Branch if equal to<br>zero<br>Branch if greater | BEQ | | | | | } | 27 4 2 | Z = | • • • • • <u> </u> | | or equal to zero<br>Branch if greater | ₿ĠĔ | | | | | ) | 2C 4 2 | N⊕ V = 0 | • • • • • | | than zero<br>Branch if less | ₿GT | | 1 | | | ] | 2E 4 2 | Z+(N ⊕ V) = 0 | • • • • • | | than zero<br>Branch if less than | RI.T | | | | | į | 2D 4 2 | N⊕ V= I | | | or equal to zero<br>Branch if not equal | BTE | | | į | | Į | 2F 4 2 | Z+(N ⊕ V) = 1 | | | to zero | BNE | | | 1 | | J | 26 4 2 | Z = 0 | | | Branch if minus | BM1<br>BPL | | | } | | 1 | 2B 4 2<br>2A 4 2 | N = 0<br>N = 1 | | | Branch if plus Branch if higher | BPL<br>BH) | | | • | | Į | 22 4 2 | C+Z=0 | | | Branch if lower | | 1 | | 1 | | | | | ! !]]!! | | or same | BLS | | | l | l | 4 | 23 4 2 | C+Z=1 | •]•[•[•]• • | OP = Operation Code MC = Number of MPU Cycles PB = Number of Program Bytes #### FIGURE 10 S6800 INSTRUCTION SET (CONT'D.) | | | | | Addressi | ing Modes | | | | Condition Re | | | |---------------------|----------|------------|----------|-----------|-----------|----------------|----------|---------------|--------------|-----------|--------| | · <u></u> - <u></u> | | Implied | Direct | Immediate | Estended | Indexed | Relative | Boolean/Arith | 5 4 3 2 1 6 | | | | Instruction | Mnemonic | n Mnemorie | Mnemonie | ор ме рв | ор мс рв | OP MC PB | OP MC PB | ОР МС РВ | ор мерв | Operation | HIINZV | | Branch to | | | | | | | | I . | 11111 | | | | subroutine | BSR | i | | ļ | | | 8D 8 2 | I ) | - - - - - - | | | | Jump to | | 1 | | 1 | | | - | See | 1 | | | | subroutine | JSR | | | ļ | BD 9 3 | A <b>D</b> 8 2 | | Special | | | | | Jump | IMP. | ì | | 1 | 7E 3 3 | 61. 4 3 | ļ | Operations | | | | | Return from | | | | ł | | | i | li' | 1 [ ] [ [ | | | | substatine | R15 | 39 3 1 | | , | | | | | | | | | Return from | | ' ' ' | | ì | | | 1 | : | 1 11111 | | | | interrupt | kТI | l 313 in i | | ļ | | | | Li | Note 10 | | | | Software interrupt | SWI | 3F 12 1 | | í | | | | / | • S[• • • • | | | | Wait for interrupt | W-51 | i 31: 9 1 | l . | ļ | | | | | | | | | No operation | NOP | 02 2 1 | | | | | | PC+1 + PC | • • • • • • | | | | Clear | CIRA | 417 2 1 | | 1 | | | | 00 → A | - RSR | | | | | CLRB | 5H 2 T | | 1 | | | | 00 · · B | + + RSRI | | | | | CLR | ] | | ļ | 7F 6 3 | 6F 7 2 | | 00 - M | I •I•IRISIRI | | | | Clear catcy | cuc | 00.2 1 | | ì | | | i | 0 - (* | • • • • • | | | | Clear interrupt | 1 | | | 1 | | | | ļ | 1 | | | | mask | (1.1 | 01: 2 1 | 1 | ĺ | | i | | 11 - 1 | | | | | Clear overflow | CLV | 0A 2 1 | | 1 | | | | 0 - V | + + + + R | | | | Set carry | src | 012 (2) 1 | | l | 1 | i. | | · • C | | | | | Set interrupt | | | l | 1 | | ļ | | | | | | | mask | SH | 10E 2 | ļ | | į. | j | | 1 -1 | • 8 • • • | | | | Set averillaw | SEV | 0B 2 1 | | 1 | | | | 1 → ∀ | | | | #### CONDITION CODE SYMBOLS: | | | _ | | | |---|------------|------|-------|--| | н | Half-carry | from | bit 3 | | - I Interrupt mask - N Negative (sign bit) - Z Zero (byte) - V Overflow, 2's complement - C Carry from bit 7 - R Reset Always - S Set Always - t Test and set if true, cleared otherwise - Not Affected #### LEGEND: - OP Operation Code (Hexadecimal): - MC Number of MPU Cycles; - PB Number of Program Bytes; - Arithmetic Plus; Arithmetic Minus; - Boolean AND: - MSP Contents of memory location pointed to by Stack Pointer; - Boolean Inclusive OR; - ⊕ Boolean Exclusive OR; - M Complement of M; - · Transfer Into; - 0 Bit = Zero; - 00 Byte Zero; Note - Accumulator addressing mode instructions are included in the IMPLIED addressing. #### CONDITION CODE REGISTER NOTES: (Bit set if test is true and cleared otherwise) - 1 (Bit V) Test: Result = 100000000? 2 (Bit C) Test: Result = 000000000? - 3 (Bit C) Test: Decimal value of most significant BCD Character greater than nine? (Not cleared if previously set.) - 4 (Bit V) Test: Operand = 10000000 prior to execution? - 5 (Bit V) Test: Operand = 01111111 prior to execution? - 6 (Bit V) Test: Set equal to result of N C after shift 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) - 0 (All) Load Condition Code Register from Stack. (See Special Operations) - 11 (Bit 1) Set when interrupt occurs, if previously set, a Non-Maskable Interrupt is required to exit the wait state. - 12 (ALL) Set according to the contents of Accumulator A # \$6800/\$68A00/\$68B00 #### SPECIAL OPERATIONS ## \$6800/\$68A00/\$68B00 ## SPECIAL OPERATIONS ## S6800/S68A00/S68B00 #### SYSTEMS OPERATION To demonstrate the great versatility of the functional building block concept, a typical system configuration is shown. This configuration will demonstrate how easily a basic system may be upgraded and expanded for a number of different applications. The Microprocessing Unit (MPU) may be configured with a Read Only Memory (ROM), Random Access Memory (RAM), a Peripheral Interface Adapter (PIA), restart circuitry and clock circuitry to form a minimum functional system (Figure 10). Such a system can easily be adapted for a number of small scale applications by simply changing the content of the ROM. TWO-PHASE CLOCK CIRCUITRY AND TIMING - The MPU requires a two-phase non-overlapping clock which has a frequency range as high as 1 MHz for the S6800, 1.5 MHz for the S68A00, and 2.0 MHz for the S68B00. In addition to the two phases, this circuit should also generate an enable signal E, and its complement $\overline{E}$ , to enable ROMs, RAMs, PIAs and ACIAs. This Enable signal and its complement is obtained by ANDing $\phi 2$ and VMA (Valid Memory Address). CHIP SELECTION AND ADDRESSING The minimum system configuration permits direct selection of the ROM, RAM, ACIA and PIA without the use of special TTL select logic. This is accomplished by simply wiring the address tines A13 and A14 to the Enable or chip select lines on the memories and PIA. This permits the devices to be addressed as follows: | Device | A14 | A13 | Hex Addresses | |--------|-----|-----|-----------------------| | RAM | 0 | 0 | 0000-007F | | PIA | 0 | 1 | 2004-2007 (Registers) | | ROM | 1 | 1 | 6000 63FF | Other addressing schemes can be utilized which use any combination of two of the lines A10 through A14 for chip selection. PERIPHERAL CONTROL. All control and timing for the peripherals that are connected to the PIA is accomplished by software routines under the control of the MPU. RESTART AND NON-MASKABLE INTERRUPT—Since this basic system does not have a nonvolatile RAM, special circuitry to handle loss of power using NMI is not required. Circuitry is, however, required to insure proper initialization of the MPU when power is turned on. This circuit should insure that the Restart signal is held low for eight of clock cycles after the VCC power supply reaches a voltage of approximately 4.75 volts DC. Also, in order to insure that a PIA or ACIA is not inadvertently selected during the power-on sequence, Three-State Control (TSC) should be held high until the positive transition of Restart. HÅLT-The Halt line is tied to $V_{CC}$ and will automatically place the MPU in the run state when power is turned on. This signal may be used to halt the MPU if a switch is used to tie the line to ground for HALT and to $V_{CC}$ for RUN. ## \$6800/\$68A00/\$68B00 ## FIGURE 11 MINIMUM SYSTEM CONFIGURATION # MICROCOMPUTER UNIT (MCU)\* #### Features - Expanded S6800 instruction set - Object code compatible with \$6800 - Single chip or expandable to 65K words. - 2K bytes of ROM - 128 bytes of RAM (64 bytes retainable) - 31 parallel I/O lines - Internal Clock/Divide-by-Four mask option (S6801) - External Clock/Divide-by-One mask option (S6801E) - TTL compatible inputs and outputs - Interrupt capability - Hardware Multiply ## **General Description** The `S6801 MCU is an 8-bit microcomputer system which is expandable, using the S6800 microprocessor family. The S6801 MCU is object code compatible with the S6800 instruction set with improved execution times of key instructions plus several new 16-bit and 8-bit instructions. The S6801 MCU can operate single chip or be expanded to 65K words. The S6801 MCU is TTL compatible and requires one +5.0 volt power supply. The S6801 MCU has 2K bytes of ROM and 128 bytes of RAM on board. In addition, the S6801 MCU has on board serial and parallel I/O and three 16 stage timer function. \*Available 1st Quarter 1979 # MICROPROCESSOR WITH CLOCK AND RAM #### Features - On-Chip Clock Circuit - ☐ 128 x 8 Bit On-Chip RAM - □ 32 Bytes of RAM Are Retainable - ☐ Software-Compatible with the \$6800 - □ Expandable to 65K Words - ☐ Standard TTL-Compatible Inputs and Outputs - 8-Bit Word Size - ☐ 16-Bit Memory Addressing - ☐ Interrupt Capability ## General Description The S6802 is a monolithic 8-bit microprocessor that contains all the registers and accumulators of the present S6800 plus an internal clock oscillator and driver on the same chip. In addition, the S6802 has 128 bytes of RAM on board located at hex addresses 0000 to 007F. The first 32 bytes of RAM, at hex addresses 0000 to 001F, may be retained in a low power mode by utilizing $V_{\rm CC}$ standby, thus facilitating memory retention during a power-down situation. The S6802 is completely software compatible with the S6800 as well as the entire S6800 family of parts. Hence, the S6802 is expandable to 65K words. When the S6802 is interfaced with the S6846 ROM - I/O - Timer chip, as shown in the Block Diagram below, a basic 2-chip microcomputer system is realized. This is advance information and specifications are subject to change without notice ## Absolute Maximum Ratings | Supply Voltage | | |-----------------------------|--------------------| | | | | Input Voltage | ., -0.3V to + 7.0V | | Operating Temperature Range | | | Storage Temperature Range | -55°C to + 150°C | | Thermal Resistance | | <sup>\*</sup>COMMENT: 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. ## D.C. Electrical Characteristics ( $V_{CC}$ = 5.0V ± 5%, $V_{SS}$ = 0, $T_A$ = 0°C to +70°C unless otherwise noted.) | Symbol | Parameter | | Min. | Тур. | Max. | Unit | |------------------------------|---------------------------------------------------|-------------------------------------|----------------------------------------------|-------|---------------------------|------| | V <sub>IH</sub> | Input High Voltage | Logic, EXtal<br>Reset | V <sub>SS</sub> +2.0<br>V <sub>SS</sub> +4.0 | | $V_{\rm CC} \ V_{\rm CC}$ | V | | $v_{IL}$ | Input Leakage Voltage | Logic, EXtal, Reset | V <sub>SS</sub> - 0.3 | | $V_{SS} + 0.8$ | V | | IIN | Input Leakage Current | Logic* | _ | 1.0 | 2.5 | μΑ | | | $(V_{IN} = 0 \text{ to } 5.25V, V_{CC} = Max)$ | | | 1 | ] | | | $v_{oh}$ | Output High Voltage | | | 1 | " | v | | | $(I_{LOAD} = -205 \mu A, V_{CC} = Min)$ | D0 - D7 | $V_{SS} + 2.4$ | [ – | _ ( | V | | | $(I_{LOAD} = -145\mu A, V_{CC} = Min)$ | A0-A15, $R/\widetilde{W}$ , VMA,E | $V_{SS} + 2.4$ | - | l – i | v | | | $(I_{LOAD} = -100\mu A, V_{CC} = Min)$ | BA | $V_{SS} + 2.4$ | ļ — | - | V | | $\overline{\mathrm{V_{OL}}}$ | Output Low Voltage | | <u> </u> | | $V_{SS} + 0.4$ | V | | | $(I_{LOAD} = 1.6 \text{mA}, V_{CC} = \text{Min})$ | | Ī | | | | | P <sub>D</sub> ** | Power Dissipation | | ! – | 0.600 | 1.2 | W | | $\overline{\mathrm{C_{IN}}}$ | Capacitance # | | ] | | | рF | | | $(V_{IN} = 0, T_A = 25^{\circ}C, f = 1.0MHz)$ | D0 - D7 | - | 10 | 12.5 | | | | | Logic Inputs, EXtal | - | 6.5 | 10 | | | $C_{OUT}$ | | $A0 - A15$ , $R/\overline{W}$ , VMA | _ | _ | 12 | pF | ## Clock Timing ( $V_{CC}$ = 5.0V ± 5%, $V_{SS}$ = 0, $T_A$ = 0° C to +70° C unless otherwise noted) | Symbol | Parameter | | Min. | Typ. | Max. | Unit | |---------------------------------------|--------------------------------------------|-------------------|------|------|------|------| | f | Frequency of Operation | Input Clock÷4 | 0.1 | - | 1.0 | MHz | | $\mathbf{f}_{\mathbf{X}\mathbf{tal}}$ | | Crystal Frequency | 1.0 | - | 4.0 | | | $t_{\rm CYC}$ | Cycle Time | | 1.0 | | 10 | μs | | $\overline{PW_{\phi Hs}}$ | Clock Pulse Width | | 450 | T - | 4500 | ns | | $PW_{\phi L}$ | Measured at 2.4V | | | ! | | | | $t_{\phi}$ | Fall Time | | | | 25 | ns | | | Measured between VSS + 0.4V and VSS - 2.4V | | | | | | <sup>\*</sup>Except IRQ and NMI, which require 3KΩ pullup load resistors for wire-OR capability at optimum operation. Does not include EXtal and Xtal, which are crystal inputs. <sup>\*\*</sup>In power-down mode, maximum power dissipation is less than 40mW. <sup>#</sup>Capacitances are periodically sampled rather than 100% tested. Read/Write Timing (Figures 1 through 5; Load Circuit of Figure 3). ( $V_{CC}$ = 5.0V ± 5%, $V_{SS}$ = 0, $T_A$ = 0°C to + 70°C unless otherwise noted.) | Symbol | Parameters | Min. | Typ. | Max. | Unit | |-------------------------------------|------------------------------------------------------------|------|----------|------|----------| | $t_{AD}$ | Address Delay | | | 270 | ns | | $t_{ACC}$ | Peripheral Read Access Time $t_{ACC} = t_{ut} - t_{DSR}$ ) | _ | - | 530 | ns | | $t_{ m DSR}$ | Data Setup Time (Read) | 100 | ] | | ns | | t <sub>H</sub> | Input Data Hold Time | 10 | i – | | ns | | $t_{AH}$ | Address Hold Time (Address, R/W, VMA) | 20 | <u> </u> | _ | ns | | $t_{\mathrm{DDW}}$ | Data Delay Time (Write) | | 165 | 225 | ns | | | Processor Controls: | | | | <u> </u> | | $t_{PCS}$ | Processor Control Setup Time | 200 | _ | _ | ns | | t <sub>PCr</sub> , t <sub>PCf</sub> | Processor Control Rise and Fall Time | i – | - | 100 | ns | | | (Measured between 0.8V and 2.0V) | İ | | | 1 | ## **Functional Description** ## MPU Registers A general block diagram of the S6802 is shown in Figure 6. As shown, the number and configuration of the registers are the same as for the S6800. The 128 x 8 bit RAM has been added to the basic MPU. The first 32 bytes may be operated in a low power mode via a V<sub>CC</sub> standby. These 32 bytes can be retained during power-up and power-down conditions via the RE signal. 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-bits) 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 sixteen-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 used bits of the Condition Code Register (b6 and b7) are ones. Figure 8 shows the order of saving the microprocessor status within the stack. Figure 7. Programming Model of the Microprocessing Unit ACRA ACCUMULATOR A ACCE ACCUMULATOR B ΙX INDEX REGISTER PROGRAM COUNTER PC Q. STACK POINTER **CONDITION CODES** REGISTER CARRY (FROM BIT 7) OVERFLOW ZERO NEGATIVE INTERRUPT HALF CARRY (FROM BIT 3) ## S6802 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 for the S6802 are identical to those of the S6800 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) VCC Standby Enable $\phi$ 2 Output (E) The following is a summary of the S6802 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 130pF. Data Bus (D0 - D7) — Eight pins are used for the data bus. It is bi-directional, 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 130pF. 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 instruction, Bus Available will be at a high state, Valid Memory Address will be at a low state, and all other three-state lines will be in the three-state mode. The address bus will display the address of the next instruction. To insure single instruction operation, transition of the Halt line must not occur during the last 250ns of E and the Halt line must go high for one Clock cycle. Read/ $\overline{\text{Write}}$ (R/ $\overline{\text{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 logical one state. This output is capable of driving one standard TTL load and 90pF. 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 90pF 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. This will occur if the $\overline{\text{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 I = 0) or non-maskable interrupt. This output is capable of driving one standard TTL load and 30pF. Interrupt Request (IRQ) - This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will wait until it completes the current instruction that is being executed 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 address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations 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. The $\overline{IRQ}$ has a high impedance pull-up device internal to the chip; however a $3k\Omega$ external resistor to $V_{CC}$ should be used for wire-OR and optimum control of interrrupts. 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 informa- tion 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 execution 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{\text{IRQ}}$ . Power-up and reset timing and power-down sequences are shown in Figures 9 and 10, respectively. Non-Maskable Interrupt (NMI) — A low-going edge on this input requests that a non-mask-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 NMI signal. The interrupt mask bit in the Condition Code Register has no effect on NMI. The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. At the end of the cycle, a 16-bit address will be loaded that points to a vectoring address which is located in memory locations FFFC and FFFD. An address loaded at these locations caused the MPU to branch to a non-maskable interrupt routine in memory. $\overline{\text{NMI}}$ has a high impedance pull-up resistor internal to the chip; however a $3k\Omega$ external resistor to $V_{CC}$ should be used for wire-OR and optimum control of interrupts. Inputs $\overline{IRQ}$ and $\overline{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 flow chart describing the major decision paths and interrupt vectors of the microprocessor. Table 1 gives the memory map for interrupt vectors. RAM Enable (RE) — A TTL-compatible RAM enable input controls the on-chip RAM of the S6802. When placed in the high state, the on-chip 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 power-down situation. RAM enable must be low three $\mu s$ before $V_{CC}$ goes below 4.75V during power-down. EXtal and Xtal — The S6802 has an internal oscillator that may be crystal controlled. These connections are for a series resonant fundamental crystal. (AT out.) A divide-by four circuit has been added to the S6802 so that a 4MHz crystal may be used in lieu of a 1MHz crystal for a more cost effective system. Pin 38 of the S6802 may be driven externally by a TTL input signal if a separate clock is required. Pin 39 is to be left open in this mode. Memory Ready (MR) — MR is a TTL compatible input control signal which allows stretching of E. When MR is high, E will be in normal operation. When MR is low, it may be stretched integral multiples of half periods, thus allowing interface to slow memories. Memory Ready timing is shown in Figure 12. 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 Ready Signal. This is equivalent to $\phi 2$ on the S6800. V<sub>CC</sub> Standby — 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 5.25V is 8mA. Table 1. Memory Map for Interrupt Vectors | VEC | TOR | o Eccolption | | |------|------|------------------------|--| | MS | LS | DESCRIPTION | | | FFFE | FFFF | RESTART | | | FFFC | FFFD | NON-MASKABLE INTERRUPT | | | FFFA | FFFB | SOFTWARE INTERRUPT | | | FFF8 | FFF9 | INTERRUPT REQUEST | | # HIGH PERFORMANCE MICROPROCESSOR\* #### Features - Upward source compatible with S6800 - Bus compatible with \$6800 family - 2MHz Bus operation - Pin-out compatible with S6800/S6802 - On-chip Oscillation/Clock Driver - TTL compatible I/O - 3 priority Interrupts - Fast Interrupt Cuts Response Time - Interrupt acknowledge allows vectoring by device - Memory Ready Signal for slow memory - +5V Power Supply - Expandable to 64 K words ## General Description The S6809 is a monolithic microprocessor that contains all the registers of the S6800 plus an additional clock oscillator and driver on chip. The S6809 gives the user 8- and 16-bit word capability, while retaining software compatibility with the basic S6800 family. Four 8-bit-wide registers and five 16-bit-wide ones process the data, with the 8-bit accumulators supplying routing computation. The S6809 is compatible with the complete set of S6800 peripheral and memory devices. It is designed for the middle and high end of the microprocessor scale. <sup>\*</sup>Available 1st Quarter 1979 ## 128x8 STATIC READ/WRITE MEMORY ## **Features** - ☐ Organized as 128 Bytes of 8 Bits - ☐ Static Operation - ☐ Bi-Directional Three-State Data Input/Output - ☐ Six Chip Enable Inputs (Four Active Low, Two Active High) - ☐ Single 5-Volt Power Supply - □ TTL Compatible - ☐ Maximum Access Time = 450ns for S6810A 350ns for S6810A - 1 ## General Description The S6810A is a static 128 x 8 Read/Write Memory designed and organized to be compatible with the S6800 Microprocessor. Interfacing to the S6810A consists of an 8-Bit Bidirectional Data Bus, Seven Address Lines, a single Read/Write Control line, and six Chip Enable lines — four negative and two positive. For ease of use, the S6810A is a totally static memory requiring no clocks or cell refresh. The S6810A is fabricated with N-channel silicon gate depletion mode technology to be fully DTL/TTL compatible with only a single +5 volt power supply required. ## **Absolute Maximum Ratings** #### NOTES: - Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to RECOMMENDED OPERATING CONDITIONS. Exposure to higher than recommended voltages for extended periods of time could affect device reliability. - 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. | Supply Voltage V <sub>CC</sub> - 0.3 to +7.0V | |------------------------------------------------------------------| | Input Voltage V <sub>IN</sub> 0.3 to +7.0V | | Operating Temperature Range $T_A$ $0^{\circ}C$ to $+70^{\circ}C$ | | Storage Temperature Range T <sub>stg</sub> -55°C to +150°C | ## DC (Static) Characteristics $V_{CC}$ = 5.0V ± 5%; $T_A$ = 0°C to +70°C unless otherwise noted | Symbol | Parameter | Min. | Тур. | Max. | Unit | Condition | |---------------------|-------------------------------------------------------------------------------------------------|------------------|------|------|----------------|--------------------------------| | V <sub>IH</sub> | Input High Voltage | 2.0 | : – | 5.25 | v | | | $V_{lL}$ | Input Low Voltage | - 0.3 | | 0.8 | $\overline{v}$ | | | I <sub>IN</sub> | Input Current $(A_n, R/W, E_n, \overline{E}_n)$<br>$(V_{IN} = 0 \text{ to } 5.25V)$ | _ | - | 2.5 | μΑ | | | V <sub>OH</sub> | Output High Voltage ( $I_{OH} = 205 \mu A$ ) | 2.4 | | | | | | $\overline{v_{ol}}$ | Output Low Voltage (IOL = 1.6mA) | | | 0.4 | V | | | $I_{LIH}$ | Output Leakage Current (D0 - D7)<br>(V <sub>0</sub> = 2.4V, E = 0.8V, $\overline{E}$ = 2.0V) | _ | | 10 | μA | i | | $I_{LOL}$ | Output Leakage Current (D0 - D7)<br>( $V_0 = 0.4V$ , $E = 0.8V$ , $\overrightarrow{E} = 2.0V$ ) | _<br> | _ | 10 | μA | | | $I_{CC}$ | Supply Current $(V_{CC} = 5.25V, T_A = 0^{\circ}C)$ | | | | | | | | S6810A | _ | _ | 70 | mA | + | | | S6810A 1 | | _ | 80 | mA | | | $C_{IN}$ | Input Capacitance* | [ <del>-</del> - | | 7.5 | рF | f=1.0MHz,TA=25°C | | $C_{OUT}$ | Output Capacitance* | - | - | _ | - | f=1.0MHz, T <sub>A</sub> =25°C | <sup>\*</sup>This parameter periodically sampled rather than 100% tested. ## AC (Dynamic) Characteristics $V_{CC} = 5.0V \pm 5\%, T_A = 0^{\circ}C \text{ to } +70^{\circ}C$ | Symbol | Parameter | | Min. | Max. | Unit | |-------------|-------------------------|------------|------|----------|------| | $t_{AS}$ | Address Setup Time | | 20 | | ns | | $t_{ m AH}$ | Address Hold Time | | | <u> </u> | ns | | $t_{CS}$ | Chip Enable Pulse Width | S6810A | 230 | _ | ns | | | | S6810A - 1 | 180 | _ | ns | Read Cycle (All timing with low input pulse 0.8V, high input pulse 2.0V, $t_r = t_f = 20ns$ , Load of Figure 1) | Symbol | Parameter | | Min. | Max. | Unit | |----------------------|----------------------------|------------|------|----------|------| | , | Post Colombia | S6810A | 450 | | ns | | t <sub>CYC</sub> (R) | Read Cycle Time | 86810A - 1 | 350 | _ | ns | | _ | Outunt Direkto Delea Dire | S6810A | 10 | _ | ns | | t <sub>DD</sub> | Output Disable Delay Time | S6810A - 1 | 10 | _ | ns | | | Dead Assessment | S6810A | T | 450 | ns | | tACC | Read Access Time | S6810A - 1 | _ | 350 | ns | | | Dead to Colort Dalor Circo | S6810A | 0 | _ | ns | | trcs | Read to Select Delay Time | S6810A - 1 | 0 | <u> </u> | ns | ## Write Cycle (All timing with low input pulse 0.80, high input pulse 2.0V, $t_f$ = $t_f$ = 20ns, Load of Figure 1) | Symbol | Parameter | | Min. | Max. | Unit | |-----------------|----------------------------|-------------|------|--------------|------| | | We'r C I O' | S6810A | 450 | | ns | | tCYC (W) | Write Cycle Time | S6810A 1 | 350 | | ns | | | TET-24 - Th. 1 - TTC 341. | S6810A | 300 | | ns | | tWP | Write Pulse Width | S6810A - 1 | 250 | - | ns | | | Data Catala mina | S6810A | 190 | _ | ns | | <sup>t</sup> DS | Data Setup Time | \$6810A - 1 | 150 | _ | ns | | | West to Colont Delay Disco | S6810A | 0 | | ns | | twcs | Write to Select Delay Time | S6810A - 1 | 0 | <b>–</b> . 1 | ns | ## **Timing Characteristics** ## **Ordering Information** | Order No. | No.<br>Pins | Package | Temp,<br>Range | Description | |-----------|-------------|---------|----------------|---------------------------------------------| | S6810AP | 40 | Plastic | 0 - 70°C | NMOS 128 x 8 Static<br>RAM, TAA = 450ns Max | | S6810A | 24 | Ceramic | 0 - 70°C | NMOS 128 x 8 Static<br>RAM, TAA = 450ns Max | | S6810A-1P | 24 | Plastic | 0 - 70°C | NMOS 128 x 8 Static<br>RAM, TAA=350ns Max | | S6810A-1 | 24 | Ceramic | 0 — 70°C | NMOS 128 x 8 Static<br>RAM, TAA = 350ns Max | # $128 \times 8$ STATIC READ/WRITE MEMORY ## **Features** - ☐ Organized as 128 Bytes of 8 Bits - □ Static Operation - ☐ Bidirectional Three-State Data Input/Output - Six Chip Enable Inputs (Four Active Low, Two Active High) - ☐ Single 5 Volt Power Supply - ☐ TTL Compatible - ☐ Maximum Access Time: - -360ns for S68A10 - -250ns for \$68B10 ## General Description The S68A10 and S68B10 are static 128x8 Read/Write Memories designed and organized to be compatible with the S68A00 and S68B00 Microprocessors. Interfacing to the S68A10 and S68B10 consists of an 8-bit bidirectional data bus, seven address lines, a single Read/Write control line, and six chip enable lines, four negative and two positive. For ease of use, the S68A10 and S68B10 are a totally static memory requiring no clocks or cell refresh. The S68A10 and S68B10 are fabricated with N-channel silicon gate depletion load technology to be fully DTL/TTL compatible with only a single +5 volt power supply required. Pin Configuration ## **Absolute Maximum Ratings** | Supply Voltage | -0.3V to +7.0V | |------------------------------|-----------------| | Input Voltage | -0.3V to +7.0V | | Operating Temperature Range | 0°C to +70°C | | Industrial Temperature Range | -40°C to +85°C | | Military Temperature Range | -55°C to +125°C | | Storage Temperature Range | -55°C to +150°C | DC Characteristics ( $V_{CC}$ = +5.0V ±5%, $V_{SS}$ = 0, $T_A$ = 0°C to +70°C unless otherwise noted.) | Symbol | Parameter | Min, | Тур. | Max. | Units | Conditions | |-----------------|---------------------------------------------------|------|------|------|-------|-------------------------------------------------------------------------| | I <sub>IN</sub> | Input Current $(A_n, R/W, CS_n, \overline{CS}_n)$ | | | 2.5 | μAde | V <sub>IN</sub> = 0V to 5.25V | | $v_{OR}$ | Output High Voltage | 2.4 | | | Vdc | $I_{OH} = -205 \mu A$ | | $v_{\rm QL}$ | Output Low Voltage | | | 0.4 | Vdc | I <sub>OL</sub> = 1.0mA | | ILO | Output Leakage Current<br>(Three-State) | | | 10 | μAdc | $CS = 0.8V \text{ or } \overline{CS} = 2.0V, V_{OUT} = 0.4V$<br>to 2.4V | | I <sub>CC</sub> | Supply Current | | | 80 | mAde | $V_{CC} = 5.25 V$ , all other pins grounded,<br>$T_A = 0$ °C | ## AC Characteristics Read Cycle (V $_{CC}$ = +5.0V ±5%, V $_{SS}$ = 0, T $_{A}$ = 0°C to +70°C unless otherwise noted.) | | | S68. | A10 | S68 | ] | | |------------------|---------------------------|------|------|------|------|-------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | | teyc(R) | Read Cycle Time | 360 | ! | 250 | T | ns | | tacc | Access Time | İ | 360 | | 250 | ns | | tas _ | Address Setup Time | 20 | | 20 | | ns | | ${ m t_{AH}}$ | Address Hold Time | 0 | | 0 | | ns | | $t_{ m DDR}$ | Data Delay Time (Read) | | 220 | | 180 | ns | | tRCS | Read to Select Delay Time | 0 | | 0 | | ns | | t <sub>DHA</sub> | Data Hold from Address | 10 | | 10 | | ns | | t <sub>H</sub> | Output Hold Time | 10 | 1 | 10 | | ns | | t <sub>DHW</sub> | Data Hold from Write | 10 | 60 | 10 | 60 | ns | Write Cycle (V $_{CC}$ = +5.0V +5%, V $_{SS}$ = 0, T $_{A}$ = 0°C to +70°C unless otherwise noted.) | | | S68. | A10 | S68 | | | |---------------------|---------------------------------|------|------|------|------|-------| | Symbol | Parameter | Min. | Max. | Mîn. | Max. | Units | | t <sub>cyc(W)</sub> | Write Cycle Time | 360 | | 250 | | ns | | t <sub>AS</sub> | Address Setup Time | 20 | | 20 | I | ns | | t <sub>AH</sub> | Address Hold Time | 0 | | 0 | | ns | | $^{ m t}_{ m CS}$ | Chip Select Pulse Width | 250 | | 210 | | ns | | twcs | Write to Chip Select Delay Time | 0 | | 0 | | ns | | t <sub>DSW</sub> | Data Setup Time (Write) | 80 | | 60 | | ns | | tH | Input Hold Time | 10 | | 10 | | ns | Note: CS and $\overline{\text{CS}}$ can be enabled for consecutive write cycles provided R/W is strobed to VIH before or coincident with the Address change, and remains high for time $t_{AS}$ . # PERIPHERAL INTERFACE ADAPTER (PIA) ## **Features** - 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 Compatible Peripheral Lines ## General Description The S6821/S68A21/S68B21 are peripheral Interface Adapters that provide the universal means of interfacing peripheral equipment to the S6800, S68A00 and S68B00 Microprocessing Units (MPU). 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. The PIA interfaces to the \$6800/\$68A00/\$68B00 MPUs with an eight-bit bidirectional data bus, three ## S6821/S68A21/S68B21 ## General Description (Continued) chip select lines, two register select lines, two interrupt request lines, read/write line, enable line and reset line. These signals, in conjunction with the S6800/S68A00/S68B00 VMA output, permit the MPU to have complete control over the PIA. VMA may be utilized to gate the input signals to the PIA. ## Absolute Maximum Ratings | Supply Voltage | -0.3V to +7.0V | |------------------------------|------------------| | Input Voltage | -0.3V to +7.0V | | Operating Temperature Range | 0°C to +70°C | | Industrial Temperature Range | -40°C to +85°C | | Military Temperature Range | -55°C to +125°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. ## Electrical Characteristics ( $V_{CC} = \pm 5.0V \pm 5\%$ , $V_{SS} = 0$ , $T_A = 0^{\circ}C$ to $\pm 70^{\circ}C$ unless otherwise noted.) | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |---------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------|-------|----------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------| | $\overline{v_{\rm III}}$ | Input High Voltage | VSS+2.0 | _ | $v_{cc}$ | Vdc | | | $\overline{\mathrm{v}_{\mathrm{1L}}}$ | Input Low Voltage | V <sub>SS</sub> - 0.3 | | $v_{SS} + 0.8$ | Vde | | | l <sub>in</sub> | Input Leakage Current R/W, Reset, RS0, RS1, CS0, CS2, CS1, CA1, CB1, Enable | | 1.0 | 2.5 | μAde | V <sub>in</sub> = 0Vde to +5.25Vde | | $\overline{I_{TSI}}$ | Three-State (Off State) Input Current D0-D7, PB0-PB7, CB2 | | 2.0 | 10 | μAdc | $V_{in} = 0.4 \text{Vdc} \text{ to } 2.4 \text{Vdc}$ | | I <sub>IH</sub> | Input High Current PAO-PA7, CA2 | - 200 | - 400 | | μAdc | $V_{IH} = 2.4 \text{Vdc}$ | | l <sub>IL</sub> | Input Low Current PAO-PA7, CA2 | | -1.3 | - 2.4 | m Adc | V <sub>1L</sub> = 0.4Vdc | | V <sub>OH</sub> | Output High Voltage D0-D7 Other Outputs | V <sub>SS</sub> +2.4<br>V <sub>SS</sub> +2.4 | | | Vdc<br>Vdc | l <sub>Load</sub> = +205μ Ade<br>l <sub>Load</sub> = -200μ Ade | | V <sub>OL</sub> | Output Low Voltage D0 · D7 Other Outputs | | | V <sub>SS</sub> +0.4<br>V <sub>SS</sub> +0.4 | Vdc<br>Vdc | I <sub>Load</sub> = 1.6mAdc<br>I <sub>Load</sub> = 3.2mAdc | | IOH | Output High Current (Sourcing) D0-D7 Other Outputs PB0-PB7, CB2 | - 205<br>- 100<br>- 1,0 | - 2.5 | - 10 | μAde<br>μAde<br>mAde | V <sub>OH</sub> = 2.4Vdc<br>V <sub>O</sub> = 1.5Vdc, the current<br>for driving other than TTL,<br>e.g., Darlington Base | | [LOH | Output Leakage Current (Off State) IRQA, IRQB | | 1.0 | 10 | μAdc | $V_{OH} = 2.4 Vdc$ | | PD | Power Dissipation | | 1 | 550 | mW | | | Cin | Capacitance D0-D7 PA0-PA7, PB0-PB7, CA2, CB2 Enable, R/W, Reset, RS0, RS1, CS0, CS1, CS2, CA1, CB1 | | | 12.5<br>10<br>7.5 | pF<br>pF<br>pF | V <sub>in</sub> = 0, T <sub>A</sub> = +25°C,<br>f = 1.0MHz | | $c_{\rm out}$ | IRQA, IRQB | | | 5.0 | рF | | Note: The PAO-PA7 Peripheral Data lines and the CA2 Peripheral Control line can drive two standard TTL loads. In the input mode, the internal pullup resistor on these lines represents a maximum of 1.5 standard TTL loads. A.C. (Dynamic) Characteristics Loading = 30pF and one TTL load for PA0-PA7, PB0-PB7, CA2, CB2 = 130pF and one TTL load for D0-D7, $\overline{IRQA}$ , $\overline{IRQB}$ ( $V_{CC}$ = +5.0V ±5%, $T_A$ = 0°C to +70°C unless otherwise noted.) Read Timing Characteristics (Figure 1) Timing Characteristics ( $V_{CC}$ = + 5.0V ± 5%, $V_{SS}$ = 0, $T_A$ = 0°C to + 70°C unless otherwise noted.) | | | S6821 | | S68A21 | | S68B21 | | | | |---------------------------------|-----------------------------------------------------------------------------------------|-------|------|--------|-------|--------|------|-------|-------------------------------------------------------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units | Conditions | | $t_{PDSU}$ | Peripheral Data Setup Time | 200 | | 135 | | 100 | | ns | <u> </u> | | t <sub>PDH</sub> | Peripheral Data Hold Time | 0 | | 0 | | 0 | | ns | | | t <sub>CA2</sub> | Delay Time, Enable Negative Transition<br>to CA2 Negative Transition | | 1.0 | | 0.670 | | 0.5 | μS | | | t <sub>RS1</sub> | Delay Time, Enable Negative Transition<br>to CA2 Positive Transition | | 1.0 | | 0,670 | | 0.5 | μs | | | t <sub>r</sub> , t <sub>f</sub> | Rise and Fall Times for CA1 and CA2 Input Signals | - | 1.0 | | 1.0 | | 1.0 | μS | i | | t <sub>RS2</sub> | Delay Time from CA1 Active Transition<br>to CA2 Positive Transition | | 2.0 | | 1.35 | | 1.0 | μS | | | t <sub>PDW</sub> | Delay Time, Enable Negative Transition<br>to Peripheral Data Valid | | 1.0 | | 0.670 | | 0.5 | μS | | | t <sub>CMOS</sub> | Delay Time, Enable Negative Transition<br>to Peripheral CMOS PA0-PA7, CA2<br>Data Valid | | 2.0 | | 1.35 | | 1.0 | μS | V <sub>CC</sub> - 30% V <sub>CC</sub> ;<br>Figure 6, Load C | | t <sub>CB2</sub> | Delay Time, Enable Positive Transition<br>to CB2 Negative Transition | | 1.0 | | 0.670 | | 0.5 | μS | | | toc | Delay Time, Peripheral Data Valid to<br>CB2 Negative Transition | 20 | | 20 | | 20 | | ns | | | t <sub>RS1</sub> | Delay Time, Enable Positive Transition<br>to CB2 Positive Transition | | 1.0 | | 0.670 | | 0.5 | μS | | | PW <sub>CT</sub> | Peripheral Control Output Pulse Width,<br>CA2/CB2 | 550 | | 550 | | 550 | | ns | | | t <sub>r</sub> , t <sub>f</sub> | Rise and Fall Time for CB1 and CB2 Input Signals | | 1.0 | | 1.0 | | 1.0 | μS | | | t <sub>RS2</sub> | Delay Time, CB1 Active Transition to<br>CB2 Positive Transition | | 2.0 | | 1.35 | | 1.0 | μ8 | | | tir | Interrupt Release Time, IRQA and IRQB | | 1.6 | | 1.1 | | 0.85 | μS | | | $t_{RS3}$ | Interrupt Response Time | | 1.0 | | 1.0 | | 1.0 | μs | | | PWI | Interrupt Input Pulse Width | 500 | | 500 | | 500 | | ns | | | t <sub>RL</sub> | Reset Low Time* | 1.0 | i - | 0.66 | | 0.5 | | μS | | <sup>\*</sup>The Reset line must be high a minimum of $1.0\mu s$ before addressing the PIA. ## S6821/S68A21/S68B21 Bus Timing Characteristics ( $V_{CC}$ = + 5.0V ± 5%, $V_{SS}$ = 0V, $T_A$ = 0°C to + 70°C unless otherwise noted.) ## Read | | | S6 | 821 | S68A21 | | S68B21 | | | |-----------------|--------------------------------------------------------------------|------|------|--------|------|--------|------|-------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units | | $t_{\rm eyeE}$ | Enable Cycle Time | 1.0 | | 0.666 | | 0.50 | | μS | | $PW_{EH}$ | Enable Pulse Width, High | 0.45 | | 0.280 | | 0.22 | | μѕ | | $PW_{EL}$ | Enable Pulse Width, Low | 0.43 | | 0.280 | | 0.21 | | μS | | t <sub>AS</sub> | Setup Time, Address and R/W Valid to<br>Enable Positive Transition | 160 | | 140 | | 70 | | ns | | $t_{ m DDR}$ | Data Delay Time | | 320 | | 220 | | 180 | ns | | t <sub>H</sub> | Data Hold Time | 10 | | 10 | | 10 | | ns | | t <sub>AH</sub> | Address Hold Time | 10 | | 10 | | 10 | | ns | | ter, tef | Rise and Fall Time for Enable Input | | 25 | | 25 | | 25 | ns | | | IL | 1 | 1 | 1 | 1 | , | 1 | 1 | ## Write | | | S6 | 821 | S68A21 | | S68B21 | | | |----------------------------------------------|--------------------------------------------------------------------|------|------|--------|--------------|--------|------|-------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units | | t <sub>cyeE</sub> | Enable Cycle Time | 1.0 | | 0.666 | | 0.50 | | μS | | $\frac{\mathrm{t_{eyeE}}}{\mathrm{PW_{EH}}}$ | Enable Pulse Width, High | 0.45 | | 0.280 | | 0.22 | | μs | | $PW_{EL}$ | Enable Pulse Width, Low | 0.43 | | 0.280 | | 0.21 | | μS | | t <sub>AS</sub> | Setup Time, Address and R/W Valid to<br>Enable Positive Transition | 160 | | 140 | · | 70 | | ns | | tosw | Data Setup Time | 195 | | 80 | | 60 | | ns | | t <sub>H</sub> | Data Hold Time | 10 | | 10 | | 10 | | ns | | t <sub>AH</sub> | Address Hold Time | 10 | | 10 | † <i>– –</i> | 10 | | ns | | ter, tef | Rise and Fall Time for Enable Input | | 25 | | 25 | | 25 | ns | Figure 3. CA2 Delay Time (Read Mode; CRA-5 = 1, CRA-3 = CRA-4 = 0) Figure 4. Peripheral CMOS Data Delay Times (Write Mode: CRA-5 = CRA-3 = 1, CRA-4 = 0) Figure 5. Peripheral Data and CB2 Delay Times (Write Mode; CRB.5 = CRB.3 = 1, CRB.4 = 0) CB2 Note: CB2 goes low as a result of the positive transition of Enable, Figure 6. CB2 Delay Time (Write Mode; CRB-5 = CRB-3 = 1, CRB-4 = 0) \*Assumes part was deselected during the previous E-pulse. 877260 Figure 7. CB2 Delay Time (Write Mode; CRB-5 = 1, CRB-3 = CRB-4 = 0) \*Assumes part was deselected during any previous E pulse. B7/266 Figure 8. IRQ Release Time Figure 9. RESET Low Time 871765 077207 \*The Reset line must be a VIH for a minimum of 1.0µs before addressing the PIA. ENABLE Figure 10. Bus Read Timing Characteristics (Read Information from PIA) E17718 ## Interface Description ## MPU/PIA Interface | Pin | Label | Function | |--------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (33)<br>(32)<br>(31)<br>(30)<br>(29)<br>(28)<br>(27)<br>(26) | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7 | Bidirectional Data — 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. | | (25) | E | Enable — 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. This signal will normally be a derivative of the S6800 $\phi$ 2 Clock. | | | | The E pulse is used to condition the interrupt/control lines CA1, CA2, CB1 and CB2. At least one E pulse must occur from the inactive edge to the active edge of the input signal to set the interrupt flag, when the lines are used as inputs. | | (21) | R/W | Read/Write — 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. | | (34) | RESET | Reset — The active low 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. | | (22)<br>(24)<br>(23) | CS0<br>CS1<br>CS2 | Chip Select — These three input signals are used to select the PIA. CSO and CS1 must be high and $\overline{\text{CS2}}$ 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. | | (36)<br>(35) | RSO<br>RS1 | PIA Register Select — 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 select lines should be stable for the duration of the E pulse while in the read or write cycle. | | (38) | ĪRQA | |------|-------------| | (37) | <u>IRQB</u> | Interrupt Request — The active low Interrupt Request lines ( $\overline{\text{IRQA}}$ and $\overline{\text{IRQB}}$ ) act to interrupt the MPU either directly or through interrupt priority circuitry. These lines are "open source" (no load device on the chip) and are capable of sinking a current of 1.6mA from an external source. 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 will 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 is 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 Flag is cleared (zeroed) as a result of an MPU Read Peripheral Data Operation. Function ## PIA/Peripheral Interface Label Pin (16) (17) PB6 PB7 | | Lubei | i witowon | |------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (2)<br>(3) | PA0<br>PA1 | Section A Peripheral Data — 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 | | (4) | PA2 | Data Direction Register bit for those lines which are to be outputs. A "0" in a bit of | | (5) | PA3 | the Data Direction Register causes the corresponding peripheral data line to act as an | | (6) | PA4 | input. During an MPU Read Peripheral Data Operation, the data on peripheral lines | | (7) | PA5 | programmed to act as inputs appears directly on the corresponding MPU Data Bus | | (8) | PA6 | lines. In the input mode the internal pullup resistor on these lines represents a maxi- | | (9) | PA7 | mum of one standard TTL load. | | | | 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" operation 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 volts 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. | | (10) | PB0 | Section B Peripheral Data — The peripheral data lines in the B Section of the PIA can | | (11) | PB1 | be programmed to act as either inputs or outputs in a similar manner to PAO-PA7. | | (12) | PB2 | However, the output buffers driving these lines differ from those driving lines PAO-PA7. | | (13) | PB3 | They have three-state capability, allowing them to enter a high impedance state when | | (14) | PB4 | the peripheral data line is used as an input. In addition, data on the peripheral data | | (15) | P <b>B</b> 5 | lines PBO-PB7 will be read properly from those lines programmed as outputs even if | to directly drive the base of a transistor switch. the voltages are below 2.0 volts for a "high." As outputs, these lines are compatible with standard TTL and may also be used as a source of up to 1 milliampere at 1.5 volts ## S6821/S68A21/S68B21 | (40)<br>(18) | CA1<br>CB1 | <b>Interrupt</b> Input — 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. | |--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (39) | CA2 | Peripheral Control — 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 one standard TTL load. The function of this signal line is programmed with Control Register A. | | (19) | CB2 | Peripheral Control — 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. | | (1) | GND | Ground | | (20) | $v_{\rm CC}$ | +5Volts ±5% | ## Application Information #### Initialization A low reset line has the effect of zeroing all PIA registers. This will set PAO-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. ## Register Addressing 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 RSO and RS1 inputs together with bit 2 in the Control Register, as shown in Table 1. Table 1. Internal Addressing | | | Control<br>Register Bit | | | |-----|-----|-------------------------|---|---------------------------| | RS1 | RS0 | CRA-2 CRB-2 | | Location Selected | | 0 | 0 | 1 | X | Peripheral Register A | | 0 | 0 | υ | X | Data Direction Register A | | 0 | 1 | x | x | Control Register A | | . 1 | 0 | x | 1 | Peripheral Register B | | 1 | 0 | х | 0 | Data Direction Register B | | 1 | _1 | .x | X | Control Register B | X = Don't Care ## Data Direction Registers (DDRA and DDRB) The two Data Direction Registers allow the MPU to control the direction of data through each corresponding peripheral data line. All Data Direction Register bits set at "0" configure the corresponding peripheral data line as an input; all "1's" result in an output. ## 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 Table 2. Table 2. Control Word Format | | 7 | 6 | 5_ | 4 | 3 | 2 | 1 | 0 | |-----|-------|-------|-------------|---|----------------|-------------|---------|---| | CRA | IRQA1 | IRQA2 | CA2 Control | | DDRA<br>Access | CA1 Control | | | | | | | | | _ | 1100000 | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CUR | IRQB1 | IRQB2 | CB2 Control | | DDRB | CB1 | Control | | Data Direction Access Control Bit (CRA-2 and CRB-2) — Bit 2 in each Control Register (CRA and CRB) allows selection of either a Peripheral Interface Register or the Data Direction Register when the proper register select signals are applied to RSO and RS1. 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{IRQA}$ and $\overline{IRQB}$ , respectively. Bits CRA-1 and CRB-1 determine the active transition of the interrupt input signals CA1 and CB1 (Table 3). 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 (CBR-5) is low, CA2 (CB2) is an interrupt input line similar to CA1 (CB1) (Table 4). 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 characteristics (Tables 5 and 6). 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 Status lines when those lines are programmed to be interrupt 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. Table 3, Control of Interrupt Inputs CA1 and CB1 | CRA-1<br>(CRB-1) | CRA-0<br>(CRB-0) | Interrupt Input CA1<br>(CB1) | Interrupt Flag CRA-7<br>(CRB-7) | MPU Interrupt Request<br>IRQA (IRQB) | |------------------|------------------|------------------------------|---------------------------------|--------------------------------------------------------------------| | 0 | 0 | ↓ Active | Set high on ↓ of CA1 (CB1) | Disabled — IRQ remains high | | 0 | 1 | ↓ Active | Set high on ; of CA1 (CB1) | Goes low when the interrupt<br>flag bit CRA-7 (CRB-7) goes<br>high | | 1 | 0 | ↑ Active | Set high on f of CA1 (CB1) | Disabled $-\overline{1 ext{RQ}}$ remains high | | 1 | 1 | ↑ Active | Set high on † of CA1 (CB1) | Goes low when the interrupt<br>flag bit CRA-7 (CRB-7) goes<br>high | #### Notes: - 1. † indicates positive transition (low to high). - 2. + indicates negative transition (high to low). - 3. The Interrupt flag bit CRA-7 is cleared by an MPU Read of the A Data Register, and CRB-7 is cleared by an MPU Read of the B Data Register. - 4. If CRA-0 (CRB-0) is low when an interrupt occurs (Interrupt disabled) and is later brought high, IRQA (IRQB) occurs on the positive transition of CRA-0 (CRB-0). Table 4. Control of CA2 and CB2 as Interrupt Inputs CRA-5 (CRB-5) is Low | CRA-5<br>(CRB-5) | CRA-4<br>(CRB-4) | CRA-3<br>(CRB-3) | Interrupt Input<br>CA2 (CB2) | Interrupt Flag CRA-6<br>(CRB-6) | MPU Interrupt Request<br>IRQΛ (IRQB) | |------------------|------------------|------------------|------------------------------|---------------------------------|--------------------------------------------------------------------| | 0 | 0 | 0 | ↓ Active | Set high on 1 of CA2 (CB2) | Disabled $-\overline{ ext{IRQ}}$ remains high | | 0 | 0 | 1 | ↓ Active | Set high on ↓ of CA2 (CB2) | Goes low when the interrupt<br>flag bit CRA-6 (CRB-6) goes<br>high | | 0 | 1 | 0 | ^ Active | Set high on † of CA2 (CB2) | Disabled — IRQ remains high | | 0 | 1 | 1 | ↑ Active | Set high on † of CA2 (CB2) | Goes low when the interrupt<br>flag bit CRA-6 (CRB-6) goes<br>high | #### Notes: - 1. † indicates positive transition (low to high). - 2. 1 indicates negative transition (high to low). - 3. The Interrupt flag bit CRA-6 is cleared by an MPU Read of the A Data Register and CRB-6 is cleared by an MPU Read of the B Data Register. - 4. If CRA-3 (CRB-3) is low when an interrupt occurs (Interrupt disabled) and is later brought high, IRQA (IRQB) occurs on the positive transition of CRA-3 (CRB-3). Table 5. Control of CA2 as an Output CRA-5 is High | | | | CA | A2 | |-------|-------|-------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | CRA-5 | CRA-4 | CRA-3 | Cleared | Set | | 1 | 0 | 0 | Low on negative transition of E after an MPU Read "A" Data operation. | High on an active transition of the CA1 signal. | | 1 | 0 | 1 | Low immediately after an MPU Read "A" Data operation. | High on the negative edge of the next "E" pulse. | | 1 | 1 | 0 | Low when CRA-3 goes low as a result<br>of an MPU Write in Control Register<br>"A." | Always low as long as CRA-3 is low. | | 1 | 1 | 1 | Always high as long as CRA-3 is high. | High when CRA-3 goes high as a result of a Write in Control Register "A." | Table 6. Control of CB2 as an Output CRB-5 is High | | | | CB2 | | | | | | |-------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--| | CRB-5 | CRB-4 | CRB-3 | Cleared | Set | | | | | | 1 | 0 | 0 | Low on the positive transition of the first E pulse following an MPU Write "B" Data Register operation. | High when the interrupt flag bit CRB-7 is set by an active transition of the CB1 signal. | | | | | | 1 | 0 | 1 | Low on the positive transition of the first E pulse following an MPU Write "B" Data Register operation. | High on the positive transition of the next "E" pulse. | | | | | | 1 | 1 | 0 | Low when CRB-3 goes low as a result of an MPU Write in Control Register "B." | Always low as long as CRB-3 is low. Will go high on an MPU Write in Control Register "B" that changes CRB-3 to "one." | | | | | | 1 | 1 | 1 | Always high as long as CRB-3 is high<br>Will be cleared when an MPU Write<br>Control Register "B" results in<br>clearing CRB-3 to "zero." | High when CRB-3 goes high as a result of an MPU write into Control Register "B." | | | | | ## **Basic System Configuration** The Microprocessing Unit (MPU) may be configured with a Read Only Memory (ROM), Random Access Memory (RAM), a Peripheral Interface Adapter (PIA), restart circuitry and clock circuitry to form a minimum functional system (Figure 16). Such a system can easily be adapted for a number of small scale applications by simply changing the content of the ROM. Two-Phase Clock Circuitry and Timing — The MPU requires a two-phase non-overlapping clock which has a frequency range as high as 1MHz. In addition to the two phases, this circuit should also generate an enable Signal E, and its complement E, to enable ROMs, RAMs, PIAs and ACIAs. This Enable signal and its complement are obtained by ANDing $\phi 2$ and VMA (Valid Memory Address). Chip Selection and Addressing — The minimum system configuration permits direct selection of the ROM, RAM, ACIA and PIA without the use of special TTL select logic. This is accomplished by simply wiring the address lines A13, A14 to the Enable or chip select lines on the memories and PIA. This permits the devices to be addressed as follows: | Device | A14 | A13 | Hex Addresses | |--------|-----|-----|-----------------------| | RAM | 0 | 0 | 0000-007F | | PIA | 0 | 1 | 2004-2007 (Registers) | | ROM | 1 | 1 | 6000-63FF | Other addressing schemes can be utilized which use any combination of two of the lines A10 through A14 for chip selection. Peripheral Control — All control and timing for the peripherals that are connected to the PIA is accomplished by software routines under the control of the MPU. ## S6821/S68A21/S68B21 ## PROGRAMMABLE TIMER ## Features - Operates from a Single 5 Volt Power Supply - ☐ Fully TTL Compatible - ☐ Single System Clock Required (Enable) - ☐ Selectable Prescaler on Timer 3 Capable of a 4MHz Input - ☐ Programmable Interrupts (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 ## General Description The S6840 is a programmable subsystem component of the S6800 family designed to provide variable system time intervals. The S6840 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 S6840 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. ### Absolute Maximum Ratings | Supply Voltage V <sub>CC</sub> - 0.3 to +7.0V | |-----------------------------------------------------------| | Input Voltage $V_{\rm IN}$ - 0.3 to +7.0V | | Operating Temperature Range T <sub>A</sub> | | Storage Temperature Range T <sub>stg</sub> 55°C to +150°C | | Thermal Resistance $\theta_{AA}$ | | | 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. # Electrical Characteristics ( $V_{CC} = 5.0V \pm 5\%$ , $V_{SS} = 0$ , $T_A = 0^{\circ}C$ to $+70^{\circ}C$ unless otherwise noted) | Symbol | Characteri | stie | Min. | Тур. | Max. | Unit | Condition | |----------------------------|-----------------------------------------|------------------------------|-----------------------|--------------|-----------------------|--------------|-------------------------------------------| | V <sub>IH</sub> | Input High Voltage | | V <sub>SS</sub> +2.0 | | $v_{cc}$ | v | | | $\overline{v_{\text{IL}}}$ | Input Low Voltage | | V <sub>SS</sub> - 0.3 | | V <sub>SS</sub> + 0.8 | $\mu A$ | T | | I <sub>IN</sub> | Input Leakage Current | | | 1.0 | 2.5 | μΑ | V <sub>IN</sub> =0 to 5.25V | | $I_{TSI}$ | Three-State (Off State) | | · | | | Ţ | | | | Input Current | D0 - D7. | | 2.0 | 10 | $\mu\Lambda$ | $V_{IN} = 0.4 \text{ to } 2.4 \text{ V}$ | | VoH | Output High Voltage | | } | Τ | T | | | | | | D0 - D7 | $V_{SS} + 2.4$ | | | } | $I_{LOAD} = -205\mu A$ | | | (<br> | Other Outputs | $V_{SS} + 2.4$ | | | } | l <sub>LOAD</sub> = -200μA | | $V_{OL}$ | Output Low Voltage | | 1 | 1 | | V | i | | | ļ | D0 - D7 | | | $V_{SS} + 0.4$ | ļ | $I_{LOAD} = 1.6 \text{mA}$ | | | ļ<br>i | $01 - 03$ , $\overline{IRQ}$ | | } | V <sub>SS</sub> +0.4 | } | $l_{LOAD} = 3.2 \text{mA}$ | | ILOH | Output Leakage Current<br> (Off State) | IRQ | | 1.0 | 10 | $\mu$ A | V <sub>OH</sub> = 2.4V | | P <sub>D</sub> | Power Dissipation | | | <del>}</del> | 550 | mW | !<br>! | | C <sub>IN</sub> | Input Capacitance | | 1 | 1 | | pF | V <sub>IN</sub> =0, T <sub>A</sub> =25°C, | | | | D0 - D7 | | ) | 12.5 | 1 | f = 1.0MHz | | | <u> </u> | All Others | | Ì | 7.5 | | 1 | | COUT | Output Capacitance | | | | | рF | 1 | | | | $\overline{\text{IRQ}}$ | | 1 | 5.0 | | $V_{\rm IN}$ =0, $T_{\rm A}$ =25°C, | | | | 01, 02, 03 | | 1 | 10 | | f = 1.0MHz | #### Bus Timing Characteristics Read (See Figures 1 and 7) | Symbol | Characteristic | Min. | Max. | Unit | Condition | |-----------------------------------|---------------------------------------------|------|------|------|--------------| | tCYCE | Enable Cycle Time | 1.0 | 1.0 | μs | † | | $PW_{EH}$ | Enable Pulse Width, High | 0.45 | 4.5 | μs | | | $PW_{EL}$ | Enable Pulse Width, Low | 0.43 | | μs | | | tas | Setup Time, Address and R/W valid to enable | | | | | | | positive transition | 160 | | ns | | | toor | Data Delay Time | | 320 | ns | | | t <sub>H</sub> | Data Hold Time | 10 | | ns | | | $t_{ m AH}$ | Address Hold Time | 10 | ı | ns | | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable input | | 25 | ns | <del> </del> | # Bus Timing Characteristics (Continued) Write (See Figures 2 and 7) | ymbol | Characteristic | Min. | Max. | Unit | Condition | |--------------------|-----------------------------------------------------------------|------|------|------|-----------| | $t_{CYCE}$ | Enable Cycle Time | 1.0 | 10 | μs | | | $PW_{EH}$ | Enable Pulse Width, High | 0.45 | 4.5 | μs | | | $PW_{\mathrm{EL}}$ | Enable Pulse Width, Low | 0.43 | | μs | | | $t_{AS}$ | Setup Time, Address and R/W valid to enable positive transition | 160 | | ns | | | $t_{\mathrm{DSW}}$ | Data Setup Time | 195 | | ns | | | t <sub>H</sub> | Data Hold Time | 10 | | ns | | | $t_{AH}$ | Address Hold Time | 10 | | ns | | | ter, tef | Rise and Fall Time for Enable input | | 25 | ns | <u> </u> | ### **AC Operating Characteristics** | Symbol | Characteristic | Min. | Max. | Unit | Condition | |---------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------|------|--------------------------------| | t <sub>r</sub> , t <sub>f</sub> | Input Rise and Fall Times C. G and Reset | | 1.0* | μs | | | PW <sub>L</sub> | Input Pulse Width Low (Figure 3) | | | μ3 | | | | C, G and Reset | t <sub>CYCE</sub> +t <sub>su</sub> +t <sub>hd</sub> | | ns | <u> </u> | | ₽W <sub>H</sub> | Input Pulse Width High (Figure 4) $\overline{C}$ , $\overline{G}$ | t <sub>CYCE</sub> +t <sub>su</sub> +t <sub>hd</sub> | ,<br>j | ns | | | $t_{\mathbf{su}}$ | Input Setup Time (Figure 5) (Synchronous Mode) $\overline{C}$ , $\overline{G}$ and $\overline{Reset}$ | 200 | | ns | i | | | C3 (÷8 Prescaler Mode only) | į | | | | | <sup>t</sup> hd | Input Hold Time (Figure 5)<br>(Synchronous Mode) $\overline{C}$ , $\overline{G}$ and $\overline{Reset}$ | 50 | | ns | | | | C3 (÷8 Prescaler Mode only) | | | | | | $t_{eo}$ | Load A TTL | | 700 | ns | V <sub>OH</sub> =2.4 V | | tem | Load C MOS | | 450 | ns | V <sub>OH</sub> =2.4V | | $t_{ m emos}$ | Load C CMOS | | 2.0 | μs | $V_{\rm OH}$ =0.7 $V_{\rm DD}$ | | $\mathbf{t}_{IR}$ | Interrupt Release Time | | 1,6 | μ8 | | <sup>\*</sup>t\* and $t_f \leqslant 1$ x Pulse Width or 1,0as, whichever is smaller. #### Device Operation The three timers in the S6840 may be independently programmed to operate in modes which fit a wide variety of applications. The device is fully bus compatible with \$6800 systems and is accessed by load and store operations from the MPU in much the same manner as a memory device. 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. The counter decrements on each subsequent clock period which may be an external clock or Enable (System $\phi$ 2) 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 MPU program, and accessible by the MPU at any time. #### **Bus Interface** The Programmable Timer Module (PTM) interfaces to the S6800 Bus with an eight-bit bidirectional data bus, two Chip Select lines, a Read/Write line, an Enable (System $\phi$ 2) line, an Interrupt Request line, an external Reset line, and three Register Select lines. These signals, in conjunction with the S6800 VMA output, permit the MPU to control the PTM. VMA should be utilized in conjunction with an MPU address line into a Chip Select of the PTM. Bidirectional Data (D0 - D7) - The bidirectional data lines (D0 - 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{\text{CS0}}$ , CS1) — These two signals are used to activate the Data Bus interface and allow transfer of data from the PTM. With $\overline{CS0}=0$ and CS1=1, the device is selected and data transfer will occur. Read/Write $(R/\overline{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/\overline{W}$ line enables the input buffers and data is transferred from the MPU to the PTM on the trailing edge of the Enable (System $\phi 2$ ) signal. Alternately, (under the same conditions) $R/\overline{W} = 1$ and Enable high allows data in the PTM to be read by the MPU. Enable (System $\phi$ 2) — This 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 (IRQ) — The active low Interrupt Request signal is normally tied directly (or through priority interrupt circuitry) to the IRQ 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{IRQ}$ 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{IRQ}$ line is activated are discussed in conjunction with the Status Register. External Reset — A low level at this input is clocked into the PTM by the Enable (System $\phi 2$ ) 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 Reset signal is asynchronous, an additional 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. causes the following action to occur: - a. All counter latches are preset to their maximal count values. - b. All Control Register bits are cleared with the exception of CR10 (internal reset bit) which is set. - All counters are preset to the contents of the - d. All counter outputs are reset and all counter clocks are disabled. - e. All Status Register bits (interrupt flags) are cleared. Recognition of a low level at this input by the PTM Register Select Lines (RS0, RS1, RS2) - These inputs are used in conjunction with the R/W line to select the internal registers, counters and latches as shown in Table 1. > It has been previously stated that the PTM is accessed via MPU Load and Store operations in much the same manner as a memory device. The instructions available with the S6800 family of MPUs which perform operations directly 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 used the $R/\overline{W}$ line as an additional register select input, the modified data may not be restored to the same register if these instructions are used. Table 1. Register Selection | s | REGISTER<br>ELECT INPU | TS | OPERATIO | vs | |------|------------------------|-----|-----------------------------------------------------------------------|--------------------------| | R\$2 | RS1 | RS0 | R/W = 0 | R/W = 1 | | 0 | 0 | 0 | CR20 = 0 WRITE CONTROL REGISTER #3 CR20 = 1 WRITE CONTROL REGISTER #1 | NO OPERATION | | 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 | WRITE MSB BUFFER REGISTER | READ TIMER #2 COUNTER | | 1 | 0 | 1 | WRITE TIMER #2 LATCHES | READ LS8 BUFFER REGISTER | | 1 | 1 | Ô | WRITE MSB BUFFER REGISTER | READ TIMER #3 COUNTER | | 1 | . 1 | ī | WRITE TIMER #3 LATCHES | READ LSB BUFFER REGISTER | #### **Control Register** Three Write-Only registers in the S6840 are used to modify timer operation to suit a variety of applications. Control Register #2 has a unique address space (RS0 = 1, RS1 = 0, RS2 = 0) and therefore 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. 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/\overline{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 will be written into if CR20 is a logic zero. Control Register #3 can also be written into after a Reset low condition has occurred, since all control register bits (except CR10) are cleared. Therefore, one may write in the sequence CR3, CR2, CR1. 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 Table 2. Control Register Bits | CR | 10 INTERNAL RESET BIT | CR2 | CONTROL REGISTER ADDRESS BIT | CR30 TIMER #3 CLOCK CONTROL | | | |----|---------------------------------|-----|--------------------------------|-----------------------------|------------------------------|--| | 0 | ALL TIMERS ALLOWED TO OPERATE | 0 | CR#3 MAY BE WRITTEN | G | T3 CLOCK IS NOT PRESCALED | | | 1 | ALL TIMERS HELD IN PRESET STATE | 1 | CR#1 MAY BE WRITTEN | 1 _ | T3 CLOCK IS PHESCALED BY + 8 | | | | CRX1* | | TIMER #X CLOCK SOURCE | | | | | | 0 | | TX USES EXTERNAL CLOCK SOURCE | E ON C | X INPUT | | | | 1 | | TX USES ENABLE CLOCK | | | | | _ | CRX2 | | TIMER #X COUNTING MODE CONTR | ٥L | | | | | 0 | | TX CONFIGURED FOR NORMAL (16- | BIT) C | OUNTING MODE | | | | 1 | • | TX CONFIGURED FOR DUAL 8-BIT C | OUNT | ING MODE | | | | CRX3 CRX4 CRX5 | _ | TIMER #X COUNTER MODE AND INT | FERRU | PT CONTROL (See Table 3) | | | | CRX6 | | TIMER#X INTERRUPT ENABLE | | | | | | 0 | | INTERRUPT FLAG MASKED ON IRQ | | | | | | 1 | | INTERRUPT FLAG ENABLED TO TRO | | | | | | CRX7 | | TIMER #X COUNTER OUTPUT ENAB | LE | | | | | 0 | | TX OUTPUT MASKED ON OUTPUT OF | K | | | | | 1 | | TX OUTPUT ENABLED ON OUTPUT O | X | | | <sup>\*</sup>Control Register for Timer 1, 2 or 3, Bit 1. #### Control Register (Continued) 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 significant 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. The functions depicted in the foregoing discussions are tabulated on the first row in Table 2 for ease of reference. Control Register Bits CR10, CR20, and CR30 are unique in that each selects a different function. The remaining bits (1 through 7) of each Control Register select common functions, with a particular Control Register affecting only its corresponding timer. For example, 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. Control Register Bit 2 selects whether the binary information contained in the Counter Latches (and 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 (CRX2 = 0) the counter will decrement to zero after N+1 enabled ( $\overline{G}$ = 0) clock periods, where N is defined as the 16-bit number in the Counter Latches. With CRX2 = 1, a similar Time Out will occur after (L+1) • (M+1) enabled clock periods, where L and M respectively, refer to the LSB and MSB bytes in the Counter Latches. 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. #### Status Register/Interrupt Flags The S6840 has an internal Read-Only Status Register which contains four Interrupt Flags. (The remaining four bits of the register are not used, and default 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 Control Register is at a logic one. The conditions for asserting the Composite Interrupt Flag bit can therefore be expressed as: $INT = I1 \cdot CR16 + I2 \cdot CR26 + I3 \cdot CR36$ where INT = Composite Interrupt Flag (Bit 7) I1 = Timer #1 Interrupt Flag (Bit 0) I2 = Timer #2 Interrupt Flag (Bit 1) I3 = Timer #3 Interrupt Flag (Bit 2) An interrupt flag is cleared by a Timer Reset condition, i.e., External Reset = 0 or Internal Reset Bit (CR10) = 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 CI 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 16 bits of addressable latches. 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. #### Counter Latch Initialization (Continued) 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 Most Significant 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 Most Significant Byte of Timer #X when a Write Timer #X Latches Command is performed. So it can be seen that the S6840 has been designed to allow transfer of two bytes of data into the counter latches provided that the MSB is transferred first. In many applications, the source of the data will be an S6800 MPU. It should be noted that the 16-bit store operations of the S6800 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 Reset input also initializes the counter latches. In this case, all latches will assume a maximum count of 65,536<sub>10</sub>. It is important to note that an Internal Reset (Bit zero of Control Register 1 Set) has no effect on the counter latches. #### Counter Initialization Counter Initialization is defined as the transfer of data from the latches to the counter with subsequent clearing of the Individual Interrupt Flag associated with the counter. Counter Initialization always occurs when a reset condition (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-initialization 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 outputs are capable of driving two standard TTL loads. $\overline{\text{Clock}}$ Inputs $(\overline{\text{C1}}, \overline{\text{C2}}, \text{and } \overline{\text{C3}})$ — Input pins $\overline{\text{C1}}, \overline{\text{C2}},$ and $\overline{\text{C3}}$ 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 inputs. The asynchronous clock rate can vary from dc to the limit imposed by Enable (System $^{\phi}$ 2) Setup, and Hold time. The external clock inputs are clocked in by Enable (System \$\phi\$ 2) 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 $\overline{\mathbf{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 litter, "System litter" is the result of the input signals being out of synchronization with the Enable (System $\phi$ 2), 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. #### Asynchronous Input/Output Lines (Continued) External clock input $\overline{C3}$ represents a special case when Timer # 3 is programmed to utilize its optional $\div$ 8 prescaler mode. The maximum input frequency and allowable duty cycles for this case are specified under the AC Operating Characteristics. The output of the $\div$ 8 prescaler is treated in the same manner as the previously discussed clock inputs. That is, it is clocked into the counter by Enable pulses, is recognized on the fourth Enable pulse (provided setup and hold time requirements are met), and must produce an output pulse at least as wide as the sum of an Enable period, setup, and hold times. Gate Inputs (G1, G2, G3) — Input pins G1, G2, and G3 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 Enable (System $\phi$ 2) signal in the same manner as the previously discussed clock inputs. That is, a Gate transition is recognized 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 $\overline{G}$ transition in this document relate to internal recognition of the input transition. The Gate inputs of all timers directly affect the internal 16-bit counter. The operation of $\overline{G3}$ is therefore independent of the $\div$ 8 prescaler selection. Timer Outputs (O1, O2, O3) — Timer outputs O1, O2, and O3 are capable of driving up to two TTL loads and produce a defined output waveform for either Continuous or Single-Shot Timer modes. Output waveform definition is accomplished 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 timer mode and will produce a single pulse in the Single-Shot Timer mode. The Dual 8-bit mode will produce 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 (Vol.) regardless of the operating mode. The Continuous and Single-Shot Timer Modes are the only ones for which output response is defined. Signals appear at the outputs (unless CRX7 = 0) during Frequency and Pulse Width comparison modes, but the actual waveform is not predictable in typical applications. #### Timer Operating Modes The S6840 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 outlined in Table 3. Table 3. Operating Modes | CONT | ROL REG | ISTER | TIMED OREDATING MODE | | | |------|---------|-------|------------------------|--|--| | CRX3 | CRX4 | ÇRX5 | TIMER OPERATING MODE | | | | 0 | * | 0 | CONTINUOUS | | | | 0 | + | 1 | SINGLE-SHOT | | | | 1 | 0 | * | FREQUENCY COMPARISON | | | | 1 | 1 | * | PULSE WIDTH COMPARISON | | | <sup>\*</sup>Defines Additional Timer Functions In addition to the four timer modes in Table 3, the remaining control register bit is used to modify counter initialization and enabling or interrupt conditions. Continuous Operating Mode (Table 4) — 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 Intialization. A Write Timer Latches command can be selected as a Counter Initialization signal by clearing CRX4. In the dual 8-bit mode (CRX2 = 1)[Refer to the example in Figure 10] the MSB decrements once for every full countdown of the LSB + 1. When the LSB = 0, the MSB is unchanged; on the next clock pulse the LSB is reset to the count in the LSB Latches and Table 4. Continuous Operating Modes #### CONTINUOUS MODE (CRX3 = 0, CRX5 = 0) | CONTROL | REGISTER | INITIALIZA | TION/OUTPUT WAVEFORMS | |---------|----------|------------------------|-------------------------------| | CRX2 | CRX4 | COUNTER INITIALIZATION | *TIMER OUTPUT (OX) (CRX7 = 1) | | 0 | 0 | G↓ + W + R | (N + 1)(T) | | 0 | 1 | G↓+R | 1 <sub>a</sub> TO 10 10 | | 1 | 0 | G↓+W+R | (L + 1)(M + 1)(T) | | 1 | 1 | G↓+R | 10 (L)(T) V <sub>OL</sub> | G+ = NEGATIVE TRANSITION OF GATE INPUT. W = WRITE TIMER LATCHES COMMAND. R = TIMER RESET (CR10 = 1 OR EXTERNAL RESET = 0). N = 16-BIT NUMBER IN COUNTER LATCH, L = 8-BIT NUMBER IN LSB COUNTER LATCH. M = 8-BIT NUMBER IN MSB COUNTER LATCH. T = CLOCK INPUT NEGATIVE TRANSITIONS TO COUNTER. $t_0 = COUNTER INITIALIZATION CYCLE.$ TO = COUNTER TIME OUT (ALL ZERO CONDITION). <sup>\*</sup>All time intervals shown above assume that the Gate (G) and Clock (C) signals are synchronized to enable (System $\phi$ 2) with the specified setup and hold time requirements. #### Timer Operating Modes (Continued) 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 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 normal 16-bit mode the period of the output of the example in Figure 9 would span 1546 clock pulses as opposed to the 20 clock pulses using the Dual 8-bit mode. The counter is enabled by an absence of a Timer Reset condition and a logic zero at the $\overline{Gate}$ input. The counter will then decrement on the first clock signal recognized during or after the counter initialization cycle. It continues to decrement on each clock signal so long as $\overline{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 re-initialization of the counter. A special condition exists for the dual 8-bit mode (CRX2 = 1) if 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 re-initialized 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 $\frac{1}{2}$ the clock frequency. 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. The waveforms available are shown in Table 5. As indicated in Table 5, 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 remaining 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 non-zero data is written into the Counter Latches. Time Outs continue to occur at the end of each clock period. The three differences between Single-Shot and Continuous Timer Modes can be summarized as attributes of the Single-Shot mode: - Output is enabled for only one pulse until it is reinitialized. - Counter Enable is independent of Gate. - 3. L = M = 0 or N = 0 disables output. Aside from these differences, the two modes are identical. Time Interval Modes — The Time Interval Modes 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. The output signal is not defined in any of these modes, but the counter does operate in either Single 16-bit or Dual 8-bit modes as programmed by CRX2. Other features of the Time Interval Modes are outlined in Table 6. Frequency Comparison or Period Measurement Mode (CRX3 = 1, CRX4 = 0) — The Frequency Comparison Mode with CRX5 = 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{G}$ is detected. If CRX5 = 0, as shown in Table 6 and Table 7, an interrupt is generated if Gate input returns low prior to a Time Out. If 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 #### Timer Operating Modes (Continued) transition of the $\overline{\text{Gate}}$ input starts a new Counter Initialization cycle. (The condition of $\overline{\text{G}} \downarrow \bullet \overline{\text{I}} \bullet \text{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 required 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 7 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 7 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 CRX5 = 1, an interrupt is generated if the reverse is true. Assume now with CRX5 = 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, 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 CRX5 = 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 $\overline{\text{Gate}}$ input disables the counter. With CRX5 = 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. Τů Table 5. Single-Shot Operating Modes #### (CRX3 = 0, CRX7 = 1, CRX5 = 1)CONTROL REGISTER INITIALIZATION/OUTPUT WAVEFORMS CRX2 CRX4 **COUNTER INITIALIZATION** TIMER OUTPUT (OX) 0 n G + W + R - INNT) n 1 $G\downarrow + R$ 18M - 19Tu-- IL + 1I(M + FIITI 1 0 $G \downarrow + W + R$ (U)(T) GJ + R SINGLE-SHOT OPERATING MODES Symbols are as defined in Table 4. 1 1 Table 6. Time Interval Modes | | CRX3 = 1 | | | | | | | |------|----------|------------------------|--------------------------------------------------------------------------------------|--|--|--|--| | CRX4 | CRX5 | APPLICATION | CONDITION FOR SETTING INDIVIDUAL INTERRUPT FLAG | | | | | | 0 | 0 | FREQUENCY COMPARISON | INTERRUPT GENERATED IF GATEINPUT PERIOD (1/F) IS LESS THAN COUNTER TIME OUT (TO) | | | | | | 0 | 1 | FREQUENCY COMPARISON | INTERRUPT GENERATED IF GATE INPUT PERIOD (1/F) IS GREATER THAN COUNTER TIME OUT (TO) | | | | | | 1 | 0 | PULSE WIDTH COMPARISON | INTERRUPT GENERATED IF GATE INPUT "DOWN TIME" IS LESS THAN COUNTER TIME OUT (TO) | | | | | | 1 | 1 | PULSE WIDTH COMPARISON | INTERRUPT GENERATED IF GATE INPUT "DOWN TIME" IS GREATER THAN COUNTER TIME OUT (TO) | | | | | Table 7. Frequency Comparison Mode | | CRX3 = 1, CRX4 = 0 | | | | | | | | | |-----------------------------|------------------------------|--------------------------------------|----------------------------------------|---------------------------|--|--|--|--|--| | CONTROL REG<br>BIT 5 (CRX5) | COUNTER<br>Initialization | COUNTER ENABLE<br>FLIP-FLOP SET (CE) | COUNTER ENABLE<br>FLIP-FLOP RESET (CE) | INTERRUPT FLAG<br>SET (1) | | | | | | | 0 | G ↓ • T • (CE + TO • CE) + R | G↓•₩•R•ĭ | W + R + 1 | G ↓ BEFORE TO | | | | | | | 1 | G↓•Ī+R | Ğ↓•₩•R•ï | W + R + 1 | TO BEFORE G ↓ | | | | | | T represents the interrupt for a given timer. Table 8. Pulse Width Comparison Mode | | CRX3 = 1, CRX4 = 1 | | | | | | | | |-----------------------------|------------------------|--------------------------------------|----------------------------------------|---------------------------|--|--|--|--| | CONTROL REG<br>BIT 5 (CRX5) | COUNTER INITIALIZATION | COUNTER ENABLE<br>FLIP-FLOP SET (CE) | COUNTER ENABLE<br>FLIP-FLOP RESET (CE) | INTERRUPT FLAG<br>SET (1) | | | | | | 0 | Ğ↓•Ī + R | Ğ↓•₩•R•ī | W + R + 1 + G | G↑BEFORE TO | | | | | | 1 | <u>G</u> ↓•∏+R | Ğ↓•₩•R•T | W + R + 1 + G | TO BEFORE G ↑ | | | | | ## **ROM-I/O-TIMER** #### Features - □ 2048x8-Bit Bytes of Mask-Programmable ROM - 8-Bit Bidirectional Data Port for Parallel Interface Plus Two Control Lines - Programmable Interval Timer-Counter Functions - □ Programmable I/O Peripheral Data, Control and Direction Registers - □ Compatible with the Complete S6800 Microcomputer Product Family - □ TTL-Compatible Data and Peripheral Lines - ☐ Single 5 Volt Power Supply #### General Description The S6846 combination chip provides the means, in conjunction with the S6802, to develop a basic 2-chip microcomputer system. The S6846 consists of 2048 bytes of mask-programmable ROM, an 8-bit bidirectional data port with control lines, and a 16-bit programmable timer-counter. This device is capable of interfacing with the S6802 (basic S6800, clock and 128 bytes of RAM) as well as the S6800 if desired. No external logic is required to interface with most peripheral devices. The S6846 combination chip may be partitioned into three functional operating sections: programmed storage, timer-counter functions, and a parallel I/O port. #### General Description (Continued) #### Programmed Storage The mask-programmable ROM section is similar to other AMI ROM products. The ROM is organized in a 2048 by 8-bit array to provide read only storage for a minimum microcomputer system. Two mask-programmable chip selects are available for user definition. Address inputs A0-A10 allow any of the 2048 bytes of ROM to be uniquely addressed. Internal registers associated with the I/O functions may be selected with A0, A1 and A2. Bidirectional data lines (D0-D7) allow the transfer of data between the MPU and the S6846. #### **Timer-Counter Functions** Under software control this 16-bit binary counter may be programmed to count events, measure frequencies and time intervals, or similar tasks. It may also be used for square wave generation, single pulses of controlled duration, and gated delayed signals. Interrupts may be generated from a number of conditions selectable by software programming. The timer-counter control register allows control of the interrupt enables, output enables, and selection of an internal or external clock source. Input pin CTC (counter-timer clock) will accept an asynchronous pulse to be used as a clock to decrement the internal register for the counter-timer. If the divide-by-8 prescaler is used, the maximum clock rate can be four times the master clock frequency with a maximum of 4 MHz. Gate input (CTG) accepts an asynchronous TTL-compatible signal which may be used as a trigger or gating function to the counter-timer. A counter-timer output (CTO) is also available and is under software control via selected bits in the timer-counter control register. This mode of operation is dependent on the control register, the gate input, and the external clock. #### Parallel I/O Port The parallel bidirectional I/O port has functional operational characteristics similar to the B port on the S6821 PIA. This includes 8 bidirectional data lines and two handshake control signals. The control and operation of these lines are completely software programmable. The interrupt input (CP1) will set the interrupt flags of the peripheral control register. The peripheral control (CP2) may be programmed to act as an interrupt input or as a peripheral control output. #### **Absolute Maximum Ratings** | Supply Voltage | 0.3Vdc to +7.0Vdc | |-----------------------------|-------------------| | Input Voltage | ).3Vdc to +7.0Vdc | | Operating Temperature Range | 0°C to +70°C | | Storage Temperature Range | ~55°C to +150°C | | Thermal Resistance | 70°C/W | 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. ## Electrical Characteristics (VCC = 5.0V $\pm$ 5%, VSS = 0, TA = $0^{\circ}$ C to +70°C unless otherwise noted.) | Symbol | Parameter | Min. | Typ. | Max. | Unit | Conditions | |---------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------|------|------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------| | v <sub>IH</sub> | Input High Voltage All inputs | V <sub>SS</sub> + 2.0 | | Vcc | Vdc | i - | | V <sub>II</sub> . | Input Low Voltage Ali Inputs | V <sub>SS</sub> -0.3 | | V <sub>SS</sub> + 0.8 | Vdc | | | Vos | Clock Overshoot/Undershoot — Input High Level — Input Low Level | V <sub>CC</sub> -0.5<br>V <sub>SS</sub> -0.5 | | V <sub>CC</sub> + 0.5<br>V <sub>SS</sub> + 0.5 | Vde | | | Liu | Input Leakage Current R, W, Reset. CSO, CS1 CP1, CTG, CTC, E, A0-A11 | | 1.0 | 2.5<br>100 | μAde | V <sub>in</sub> = 0 to 5.25 Vdc | | ITSI | Three-State (Off State) Input Current D0-D7 PP0-PP7, CR2 | i | 2.0 | 10<br>100 | μAde | V <sub>in</sub> 0.4 to 2.4 Vdc | | V <sub>OH</sub> | Output High Voltage D0-D7 CP2, PP0-PP7 Other Outputs | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4<br> V <sub>SS</sub> + 2.4 | | | Vdc<br>Vdc | l <sub>Load</sub> ~ -205μAdc,<br>l <sub>Load</sub> = -145μAdc,<br>l <sub>Load</sub> = -100μAdc | | VOI. | Output Low Voltage D0 - D7 Other Outputs | | | V <sub>SS</sub> + 0.4<br>V <sub>SS</sub> + 0.4 | Vde | I <sub>Load</sub> = 1.6mAde<br>I <sub>Load</sub> = 3.2mAde | | Іон | Output High Current (Sourcing) D0-D7 Other Outputs CP2, PP0-PP7 | -205<br>-200<br>-1.0 | | -10 | μAdc<br>mADC | V <sub>OH</sub> = 2.4 Vdc<br>V <sub>O</sub> = 1.5 Vdc, the current<br>for driving other than TTL,<br>e.g., Darlington Base | | Ior. | Output Low Current (Sinking) D0-D7 Other Outputs | 1.6<br>3.2 | | | m Ade | V <sub>OL</sub> = 0.4Vde | | I <sub>LOH</sub> | Output Leakage Current (Off State) IRQ | 1 | | 10 | μAde | V <sub>OH</sub> = 2.4Vde | | PD | Power Dissipation | | | 1000 | mW | <u> </u> | | Cin | Capacitance D0 D7 | | | 20<br>12.5 | pF | V <sub>in</sub> = 0, T <sub>A</sub> - 25°C,<br>f = 1.0MHz | | | PPO-PP7, CP2 A0-A10, R/W, Reset, CS0, CS1, CP1, CTC, CTG IRQ | | I | 10<br>7.5 | | i | | Cout | PPO-PP7, CP2, CTO | | T | 5.0<br>10 | рF | | | Ę_ | Frequency of Operation | 0.1 | | 1.0 | MHz | | | t <sub>eye</sub> k<br>trl | Clock Timing Cycle Time Reset Low Time | 1.0 | | | he<br>he | | | tIR | Interrupt Release | _ | | 1.6 | μs | | ### Read/Write Timing | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |-----------------------------------|-------------------------------------|-------|------|------|------|------------| | PWEL | Enable Pulse Width, Low | 430 | | | ns | | | PWEH | Enable Pulse Width, High | 430 | | | ns | | | tAS | Set Up Time (Address CS0, CS1, R/W) | 160 | | | ns | | | tonk | Data Delay Time | • | | 320 | ns | <u>-</u> | | tH | Data Hold Time | 10 | | | ns | | | t <sub>AH</sub> | Address Hold Time | 10 | | | ns | | | t <sub>Ef</sub> , t <sub>Er</sub> | Rise and Fall Time | ļ ——— | | 25 | ns | | | $t_{\mathrm{DSW}}$ | Data Set Up Time | 195 | | | ns | | ## Bus Timing Peripheral I/O Lines | Symbol | Parameter | Min. | Typ. | Max. | Unit | Conditions | |-----------------------------------|------------------------------|------|------|------|------|------------| | tensu | Peripheral Data Setup | 200 | | | ns | | | t <sub>Pr</sub> , t <sub>Pc</sub> | Rise and Fall Times CP1, CP2 | | | 1.0 | μs | | | $t_{\mathrm{CP2}}$ | Delay Time E to CP2 Fall | | | 1.0 | μs | | | t <sub>DC</sub> | Delay Time I/O Data CP2 Fall | 20 | | | μs | | | tRSI | Delay Time E to CP2 Rise | | 1 | 1.0 | μs | | | tRS2 | Delay Time CP1 to CP2 Rise | | _ | 2.0 | μs | | | $t_{PDW}$ | Peripheral Data Delay | | | 1.0 | μs | | ### Timer-Counter Lines | t <sub>CR</sub> , t <sub>CF</sub> | Input Rise and Fall Time CTC and CTG | | 100 | ns | | |-----------------------------------|-----------------------------------------------|------------------------|-----|------|----------| | tpWH | Input Pulse Width High<br>(Asynchronous Mode) | t <sub>cyc</sub> + 250 | | ns | | | tpwL | Input Pulse Width Low<br>(Asynchronous Mode) | t <sub>eye</sub> + 250 | - | ns | | | t <sub>su</sub> | Input Setup Time<br>(Synchronous Mode) | 200 | | i ns | | | t <sub>hd</sub> | Input Hold Time<br>(Synchronous Mode) | 50 | | ns | | | tcTO | Output Delay | | 1.0 | μs | <u> </u> | Figure 2. Bus Read Timing Figure 3. Bus Write Timing (Read Information from \$6846) (Write Information from MPU) ENABLE ENABLE M/N, A, US DAYA BUS DATA BUS Figure 4. Peripheral Data and CP2 Delay Figure 5. IRQ Release Time (Control Mode PCR5 = 1, PCR4 = 0, PCR3 = 1) PPQ-PP7 ENABLE CPZ Figure 6. Peripheral Port Setup Time Figure 7. CP2 Delay Time (PCR5 = 1, PCR4 = 0, PCR3 = 0)ENABLE PPQ. PP7 CP1 ENABLE GP2 #### Signal Description Bus Interface — The S6846 interfaces to the S6802 or S6800 Bus via an eight-bit bidirectional data bus, two Chip Select lines, a Read/Write line, and eleven address lines. These signals, in conjunction with the S6800/02 VMA output, permit the MPU to control the S6846. Bidirectional Data Bus (D0-D7) — The bidirectional data lines (D0-D7) allow the transfer of data between the MPU and the S6846. The data bus output drivers are three-state devices which remain in the high-impedance (Off) state except when the MPU performs an S6846 register or ROM read (R/ $\overline{W}$ = 1 and I/O Registers or ROM selected). Chip Select (CS0, CS1) — The CS0 and CS1 inputs are used to select the two major sections of the S6846. They are mask programmed to be active high or active low as chosen by the user. Address Inputs (A0-A10) — The Address Inputs allow any of the 2048 bytes of ROM to be uniquely selected when the circuit is operating in the ROM mode. In the I/O-Timer mode, address inputs A0, A1, and A2 select the proper I/O Register, while A3 through A10 (together with CS0 and CS1) can be used as additional qualifiers in the I/O Select circuitry. (See the section on I/O-Timer Select for additional details.) Reset — The active low state of the Reset input is used to initialize all register bits in the I/O section of the device to their proper values. (See the section on Initialization for Reset conditions for timer and peripheral registers.) Enable ( $\phi 2$ ) — This signal synchronized data transfer between the MPU and the S6846. It also performs an equivalent synchronization function on the external clock, reset, and gate inputs of the S6846 Timer section. Read/ $\overline{W}$ rite $(R/\overline{W})$ — This signal is generated by the MPU and is used to control the direction of data transfer on the bidirectional data pins. A low level on the $R/\overline{W}$ input enables the S6846 input buffers and data is transferred to the circuit during the $\phi 2$ pulse when the part has been selected. A high level on the $R/\overline{W}$ input enables the output buffers and data is transferred to the MPU during $\phi 2$ when the part is selected. Interrupt Request ( $\overline{IRQ}$ ) — The active low $\overline{IRQ}$ output acts to interrupt the MPU through logic included on the S6846. This output utilizes an open chain configuration and permits other interrupt request outputs from other circuits to be connected in a wire-OR configuration. Peripheral Data (P0-P7) — The peripheral data lines can be individually programmed as either inputs or outputs via the Data Direction Register. When programmed as outputs, these lines will drive two standard TTL loads (3.2 mA). They are also capable of sourcing up to 1.0 mA at 1.5 Volts (Logic "1" output.) When programmed as inputs, the output drives associated with these lines enter a three-state (high impedance) mode. Since there is no internal pull-up for these lines, they represent a maximum $10\mu A$ load to the circuitry driving them — regardless of logic state. A logic zero at the Reset input forces the peripheral data lines to the input configuration by clearing the Data Direction Register. This allows the system designer to preclude the possibility of having a peripheral data output connected to an external driver output during power-up sequence. Interrupt Input (CP1) — Peripheral input line CP1 is an input-only that sets the Interrupt Flags of the Peripheral Control register. The active transition for this signal is programmed by the control register for the parallel port. CP1 may also act as a strobe for the peripheral data register when it is used as an input latch. Details for programming CP1 are in the section on the parallel peripheral port. Peripheral Control (CP2) — Peripheral Control line CP2 may be programmed to act as an Interrupt input or Peripheral Control output. As an input, this line has high impedance and is compatible with standard TTL voltage levels. As an output, it is also TTL compatible and may be used as a source of 1 mA at 1.5V to directly drive the base of a Darlington transistor switch. This line is programmed by the Control Register for the parallel port. Counter Timer Output (CTO) — The Counter Timer Output is software programmable by selected bits in the timer counter control register. The mode of op- eration is dependent on the Timer control register, the gate input, and the external clock. The output is TTL compatible. External Clock Input ( $\overline{CTC}$ ) — Input pin $\overline{CTC}$ will accept asynchronous TTL voltage level signals to be used as a clock to decrement the Timer. The high and low levels of the external clock must be stable for at least one system clock period plus the sum of the setup and hold times for the inputs. The asynchronous clock rate can vary from dc to the limit imposed by System $\phi 2$ , setup, and hold times. The external clock input is clocked in by Enable (System $\phi$ 2) 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 S6846. All references to $\overline{\text{CTC}}$ inputs in this document relate to internal recognition of the input transition. Note that a clock transition 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 either "System jitter" or "Input jitter" being observed on the output of the S6846 when using an asynchronous clock and gate input signal. "System jitter" is the result of the input signals being out of synchronization with the system $\phi 2$ clock (Enable), permitting signals with marginal set-up and hold time to be recognized by either the bit time nearest the input transition or subsequent bit time. "Input jitter" can be as great as the time between the negative going transitions of the input signal plus the system jitter if the first transition is recognized during one system cycle, and not recognized the next cycle or vice-versa. Gate Input ( $\overline{\text{CTG}}$ ) — The input pin $\overline{\text{CTG}}$ accepts as asynchronous TTL-compatible signal which is used as a trigger or a clock gating function to the Timer. The gating input is clocked into the S6846 by the Enable (System $\phi$ 2) signal in the same manner as the previously discussed clock inputs. That is, a $\overline{\text{CTG}}$ transition is recognized on the fourth Enable pulse (provided setup and hold time requirements are met), and the high or low levels of the $\overline{\text{CTG}}$ input must be stable for at least one system clock period plus the sum of setup and hold times. All references to $\overline{\text{CTG}}$ transition in this document relate to internal recognition of the input transition. The $\overline{\text{CTG}}$ input of the timer directly affects the internal 16-bit counter. The operation of $\overline{\text{CTG}}$ is therefore independent of the $\div$ 8 prescaler selection. ### **Functional Select Circuitry** I/O Timer Select Circuitry — Two chip select inputs are provided with the S6846, and are programmed active high or low simultaneously with the ROM pattern. The I/O-Timer selection can therefore be made to correspond to any one of the four possible state combinations of the two chip select inputs. ( $\overline{CS0}$ - $\overline{CS1}$ , $\overline{CS0}$ - $\overline{CS1}$ , or $\overline{CS0}$ - $\overline{CS1}$ ) Address lines A3, A4, and A5 are also used as I/O-Timer Select inputs. Specifically, these lines must be at a logic zero (low) for the I/O-Timer section to be selected. Address line A6 can also be used as a qualifier for I/O-Timer selection, as can any one of the four high Address lines (A7 through A10). A6 is unique among these selector inputs in that it is possible to program either the high or low state of A6 as an I/O-Timer select input. The circuit of Figure 13 is representative of the I/O-Timer select circuitry on the S6846. The mask programmable options are represented by switches. Internal Addressing — Seven I/O Register locations within the S6846 combination circuit are accessible to the MPU data bus. Selection of these registers is controlled by A0, A1, and A2 as shown in Table 1. CS0 and CS1 must be in the I/O state and the proper register address must be applied to access a particular register. The combination status register is Read-only; all other Registers are Read/Write. Table 1. Internal Register Addresses | Registered Selected | A2 | A1 | AO | |-----------------------------|----|----|----| | Combination Status Register | 0 | 0 | 0 | | Peripheral Control Register | 0 | 0 | 1 | | Data Direction Register | 0 | 3 | 0 | | Peripheral Data Register | 0 | 1 | 1 | | Combination Status Register | 1 | 0 | 0 | | Timer Control Register | 1 | 0 | 1 | | Timer MSB Register | 1 | 1 | 0 | | Timer LSB Register | 1 | 1 | 1 | | ROM Address | X | Х | Х | Initialization — When the Reset input has accepted a low signal, all registers are initialized to the Reset state. The data direction and data registers are cleared. The Peripheral Control Register is cleared except for bit 7 (the Reset bit). This forces the parallel port to the input mode with Interrupts disabled. To remove the Reset condition from a parallel port, an "0" must be written into the Peripheral Control Register bit 7 (PCR7). The counter latches are preset to their maximal count, the Timer control register bits are reset to zero except for Bit 0 (CCR0) (which is set), the counter ouput is cleared, and the counter clock disabled. This state forces the timer counter to remain in an inactive state. The combination status register is cleared of all interrupt flags. During timer initialization, the reset bit (CCR0) must be cleared. ROM — The Mask Programmable ROM section is similar in operation to other AMI ROM products. The ROM is organized as 2048 words of 8-bits to provide read-only storage for a minimum microcomputer system. The ROM is active when selected by the unique combination of the chip select inputs. ROM Select — The active levels of CS0 and CS1 for ROM and I/O select are a user programmable option. Either CS0 or CS1 may be programmed active high or active low, but different codes must be used for ROM or I/O select. CS0 and CS1 are mask programmed simultaneously with the ROM pattern. The ROM Select Circuitry is shown in Figure 14. #### **Timer Operation** The Timer may be programmed to operate in modes which fit a wide variety of applications. The device is fully bus compatible with the S6800 system, and is accessed by Load and Store operations from the MPU. In a typical application, the timer will be loaded by storing two bytes of data into the counter latch. This data is then transferred into the counter during a Counter Initialization cycle. The counter decrements on each subsequent clock cycle (which may be system \$\phi^2\$ or an external clock) until one of several predetermined conditions causes it to halt or recycle. Thus the timer is programmable, cyclic in nature, controllable by external inputs or MPU program, and accessible to the MPU at any time. Counter Latch Initialization — The Timer consists of a 16-bit addressable counter and 16 bits of addressable latches. The function of the latches is to store a binary equivalent of the desired count value minus one. Counter initialization results in the transfer of the latch contents of the counter. It should be noted that data transfer to the counters is always accomplished via the latches. Thus, the counter latches may be accurately described as a 16-bit "counter initialization data" storage register. In some modes of operation, the initialization of the latches will cause simultaneous counter initialization (i.e., immediate transfer of the new latch data into the counters). It is, therefore, necessary to insure that all 16 bits of the latches are updated simultaneously. Since the S6846 data bus is 8 bits wide, a temporary register (MSB Buffer Register) is provided for in the Most Significant Byte of the desired latch data. This is a "write-only" register selected via address lines A0, A1, and A2. Data is transferred directly from the data bus to the MSB Buffer when the chip is selected, $R/\overline{W}$ is low, and the timer MSB register is selected (A0 = "0"; A1 = A2 = "1"). The lower 8 bits of the counter latch can also be referred to as a "write-only" register. Data Bus information will be transferred directly to the LSB of a counter latch when the chip is selected, $R/\overline{W}$ is low and the Timer LSB Register is selected (A0 = A1 = A2 = "1"). Data from the MSB Buffer will automatically be transferred into the Most Significant Byte of the counter latches simultaneously with the transfer of the Data Bus information to the Least Significant Byte of the Counter Latch. For brevity, the conditions for this operation will be referred to henceforth as a "Write Timer Latches Command." The S6846 has been designed to allow transfer of two bytes of data into the counter latches from any source, provided the MSB is transferred first. In many applications, the source of data will be an S6802 or S6800 MPU. It should therefore be noted that the 16-bit store operations of the S6800 family of microprocessors (STS and STX) transfer data in the order required by the S6846. 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 Reset input also initializes the counter latches. All latches will assume maximum count (65, 536) values. It is important to note that an internal Reset (Bit zero of the Timer Control Register Set) has no effect on the counter latches. Counter Initialization — Counter Initialization is defined as the transfer of data from the latches to the counter with attendant clearing of the Individual Interrupt Flag associated with the counter Counter Initialization always occurs when a reset condition (external $\overline{Resct}$ – 0 or $\overline{TCRO}$ = 1) is recognized. It can also occur (dependent on the Timer Mode) with a Write Timer Latches command or recognition of a negative transition of the $\overline{Gatc}$ input. Counter recycling or reinitialization occurs when a 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, but the Interrupt Flag is unaffected. Timer Control Register — The Timer Control register (see Table 2) in the S6846 is used to modify timer operation to suit a variety of applications. The Control | Control Register<br>Bit | State | Bit Definition | State Definition | |-------------------------|-------|--------------------------|-----------------------------------| | TCRO | 0 | Internal Reset | Timer Enabled | | | 1 | Ţ i | Timer in Preset State | | TCR1 | 0 | Clock Source | Timer uses External Clock (CTC) | | | 1 | | Timer uses φ2 System Clock | | TCR2 | 0 | ÷ 8 Prescaler | Clock is not Prescaled | | | 1 | Enabler | Clock is Prescaled by ÷ 8 Counter | | TCR3 | Х | | | | TCR4 | Х | Operating Mode Selection | See Table 3 | | TCR5 | Х | | | | TCR6 | G | Timer Interrupt Enable | IRQ Masked from Timer | | | 1 | | IRQ Enabled from Timer | | TCR7 | 0 | Timer Output Enable | Counter Output (CTO) Set LOW | | Γ | 1 | 1 | Counter Output Enabled | Table 2. Format for Timer/Counter Control Register Register has a unique address space (A0 = 1, A1 = 0, A2 = 1) and therefore may be written into at any time. The least significant bit of the Control Register 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 "one" into Timer Control Register Bit 0 (TCR0) causes the counter to be preset with the contents of the counter latches, all counter clocks to be disabled, and the timer output and interrupt flag (Status Register) to be reset. The Counter Latch and Control Register are undisturbed by an Internal Reset and may be written into regardless of the state of TCR0. Timer Control Register Bit 1 (TCR1) is used to select the clock source. When TCR1 = 0, the external clock input $\overrightarrow{CTC}$ is selected, and when TCR1 = "1", the timer uses system $\phi 2$ . Timer Control Register Bit 2 (TCR2) enables the $\div$ 8 prescaler (TCR1 = "1"). In this mode, the clock frequency is divided by eight before being applied to the counter. When TCR2 = "0" the clock is applied directly to the counter. TCR3, 4, 5 select the Timer Operating Mode, and are discussed in the next section. Timer Control Register Bit 6 (TCR6) is used to mask or enable the Timer Interrupt Request. When TCR6 = 0, the Interrupt Flag is masked from the timer. When TCR6 = 1, the Interrupt Flag is enabled into Bit 7 of the Composite Status Register (Composite IRQ Bit), which appears on the $\overline{IRQ}$ output pin. Timer Control Register Bit 7 (TCR7) has a special function when the timer is in the Cascaded Single Shot mode. (This function is explained in detail in the section describing the mode.) In all other modes, TCR7 merely acts as an output enable bit. If TCR7 = 0, the Counter Timer Output (CTO) is forced low. Writing a logic one into TCR7 enables CTO. Timer Operating Modes — The S6846 has been designed to operate effectively in a wide variety of applications. This is accomplished by using three bits of the control register (TCR3, TCR4, and TCR5) to define different operating modes of the Timer, outlined in Table 3. Continuous Operating Mode (TCR3 = 0, TCR5 = 0) — The timer may be programmed to operate in a continuous counting mode by writing zeros into bits 3 and 5 of the timer control register. Assuming that the timer output is enabled (TCR7 = 1), a square wave will be generated at the Timer Output CTO (see Table 4). Either a Timer Reset (TCR0 = 1 or External Reset = 0) condition or internal recognition of a negative transition of the CTG input results in Counter Initialization. A Write Timer Latches command can be selected as a Counter Initialization signal by clearing TCR4. Table 3. Operating Modes | TCR5 | TCR4 | TCR3 | Timer Operating Mode | Counter Initialization | Interrupt Flag Set | |------|------|------|------------------------|------------------------|--------------------| | 0 | 0 | 0 | Continuous | CTG ! + W + R | T.O. | | 0 | 0 | 1 | Cascaded Single Shot | CTG↓+ R | T.O. | | 0 | 1 | 0 | Continuous | CTG↓÷ R | T.O. | | 0 | 1 | 1 | Normal Single Shot | CTG↓+R | T.0. | | 1 | 0 | 0 | Frequency Comparison | <u>CTG</u> ↓ · | CTG↓ Before T.O. | | 1 | 0 | 1 | <u> </u> | CTG↓∙Ĭ∙R | T.O. Before CTG↓ | | 1 | 1 | 0 | Pulse Width Comparison | CTG↓ · T + R | CTG↑ Before T.O. | | 1 | 1 | 1 | | | T.O. Before CTG↑ | R = Reset Condition W = Write Time Latches T.O. = Counter Time Out CTG + = Negative Transition of Pin 17 CTG↑ = Positive Transition of Pin 17 I = Interrupt Flag (CSR0 ) = 0 Table 4. Continuous Operating Modes | | Continuous Mode<br>(TCR3 = 0, TCR7 = 1, TCR5 = 0) | | | | | | | | |-----------------------|---------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Control R<br>Register | Control Register Initialization/Output Waveforms | | | | | | | | | TCR2 | TCR4 | Counter | Timer Output (2X) | | | | | | | 0 | 0 | Initialization G+W+R | $\leftarrow (N+1) (T) \rightarrow \qquad \leftarrow (N+1) (T) \rightarrow \qquad \leftarrow (N+1) (T) \rightarrow \qquad - \qquad \lor_{OH}$ | | | | | | | 0 | 1 | G + R | to T.O. T.O. T.O. | | | | | | $\overline{G}$ = Negative transition of $\overline{GATE}$ input. W = Write Timer Latches Command. R = Timer Reset (TCR0 = 1 or External RESET = 0) N = 16 Bit Number in Counter Latch. T = Period of Clock input to Counter. to = Counter initialization Cycle. T.O. = Counter Time Out (All Zero Condition). The discussion of the Continuous Mode has assumed the application requires an output signal. It should be noted the Timer operates in the same manner with the output disabled (TCR7 = 0). A Read Timer Counter command is valid regardless of the state of TCR7. Normal Single-Shot Timed Mode (TCR3 = 0, TCR4 = 1, TCR5 = 1) — This mode is identical to the Continuous Mode with two 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. The output waveform (CTO) is shown in Figure 15. As indicated in Figure 15, 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 reinitialization 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 $\overline{\text{CTG}}$ input level remaining in the low state for the Single-Shot mode. Aside from these differences, the two modes are identical. Time Interval Modes (TCR3 = 1) — The Time Interval Modes are provided for applications requiring 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 $\overline{\text{CTG}}$ input. Counter Initialization is also affected by Interrupt Flag status. The output signal is not defined in any of these modes. Other features of the Time Interval Modes are outlined in Table 5. Cascaded Single-Shot Mode (TCR3 = 0, TCR4 - 0, TCR5 = 1) — This mode is identical to the single-shot mode with two exceptions. First, the output waveform does not return to a low level and remain low after timeout. Instead, the output level remains at its initialized level until it is reprogrammed and changed by timeout. The output level may be changed at any timeout or may have any number of timeouts between changes. The second difference is the method used to change the output level. Timer Control Register Bit 7 (TCR7) has a special function in this mode. The timer output (CTO) is equal to TCR7 clocked by timeout. At every timeout, the content of TCR7 is clocked to and held at the CTO output. Thus, output pulses of length greater than one timer cycle can be generated by cascading timer cycles and counting timeouts with a software program, (See Figure 15). An interrupt is generated at each timeout. To cascade timer cycles, the MPU would need an interrupt routine to: 1) count each timeout and determine when to change TCR7; 2) write into TCR7 the state corresponding to the next desired state of the output waveform (only necessary during the last timer cycle before the output is to change state); and 3) clear the interrupt flag by reading the combination status register. It is also possible, if desired, to change the length of the timer cycle by reinitializing the timer latches. This allows more flexibility for obtaining desired times. Table 5. Time Interval Modes | | | TCR3 = | 1 | |------|------|---------------------------|---------------------------------------------------------------------------------------| | TCR4 | TCR5 | Application | Condition for Setting Individual Interrupt Flag | | 0 | 0 | Frequency<br>Comparison | Interrupt Generated if CTG Input Period (1/F) is Less Than Counter Time Out (T.O.) | | 0 | 1 | Frequency<br>Comparison | Interrupt Generated if CTG Input Period (1/F) is Greater Than Counter Time Out (T.O.) | | 1 | 0 | Pulse Width<br>Comparison | Interrupt Generated if CTG Input "Down Time" is Less Than Counter Time Out (T.O.) | | 1 | 1 | Pulse Width<br>Comparison | Interrupt Generated if CTG Input "Down Time" is Greater Than Counter Time Out (T.O.) | Frequency Comparison Mode (TCR3 = 1, TCR4 = 0) — The timer within the S6846 may be programmed to compare the period of a pulse (giving the frequency after calculations) at the CTG input with the time period required for Counter Time Out. A negative of the CTG input enables the counter and starts a Counter Initialization cycle - provided that other conditions as noted in Table 6 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 6 that an interrupt condition will be generated if TCR5 = 0 and the period of the pulse (single pulse or measured separately repetative pulses) at the CTG input is less than the Counter Time Out period. If TCR5 = 1, an interrupt is generated if the reverse is true. Assume now with TCR5 = 1 that a Counter Initialization has occurred and that the CTG 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 $\overline{\text{CTG}}$ input cycle until the mode is changed, or a cycle is determined to be above the predetermined limit. Pulse Width Comparison Mode (TCR3 = 1, TCR4 = 1) — This mode is similar to the Frequency Comparison Mode except for the limiting factor being a positive, rather than negative, transition of the $\overline{CTG}$ input. With TCR5 = 0, an Individual Interrupt Flag will be generated if the zero level pulse applied to the $\overline{CTG}$ input is less than the time period required for Counter Time Out. With TCR5 = 1, the interrupt is generated when the reverse condition is true. As can be seen in Table 7, a positive transition of the $\overline{\text{CTG}}$ input disables the counter. With $\overline{\text{TCR5}} = 0$ , it is therefore possible to directly obtain the width of any pulse causing an interrupt. Table 6. Frequency Comparison Mode | CRX3 = 1, CRX4 = 0 | | | | | | | | |-----------------------------|---------------------------|--------------------------------------|----------------------------------------|---------------------------|--|--|--| | Control Reg<br>Bit 5 (CRX5) | Counter<br>Initialization | Counter Enable<br>Flip-Flop Set (CE) | Counter Enable<br>Flip-Flop Reset (CE) | Interrupt Flag<br>Set (1) | | | | | 0 | G↓·Ī·(CE+TO·CE)+R | Ğ↓·W·R·I | W+R+I | G↓ Before TO | | | | | 1 | G↓∙Ĩ÷R | G↓·W·R·I | W+R+I | TO Before G↓ | | | | I represents the interrupt for the timer. Table 7. Pulse Width Comparison Mode | | | CRX3 = 1, CRX4 =1 | | | |-----------------------------|---------------------------|--------------------------------------|----------------------------------------|---------------------------| | Control Reg<br>Bit 5 (CRX5) | Counter<br>Initialization | Counter Enable<br>Flip-Flop Set (CE) | Counter Enable<br>Flip-Flop Reset (CE) | Interrupt Flag<br>Set (1) | | 0_ | Ğ↓·Ī+R | Ğ↓·W·Ř·Ī | W+R+J+G | Gt Before TO | | 1 | G↓·Ĩ÷R | G↓·W·R·T | W+R+I+G | TO Before G↑ | Differences Between the S6840 and the S6846 Timers - Control registers 1 and 3 are buried (access through control register 2 only) in the S6840 timer. In the S6846, all registers are directly accessible. - 2) The S6840 has a dual 8 bit continuous mode for generating non-symmetrical waveforms. The S6846, instead, has a cascaded one shot mode which can accomplish the same function, but also allows the user to generate waveforms longer than one timeout. - Because of the different modes, there is a difference in the control registers between the \$6840 and the \$6846. | Contral<br>Register<br>Bit | \$6840 | \$6846 | | | |----------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--|--| | 2 | 16 bit or dual 8 bit<br>mode control | ÷8 prescale enable | | | | 7 | autput enable (all modes) | output next state<br>(cascaded one shot<br>mode only), output<br>enable all other modes | | | | 0 | R1 internal reset<br>R2 control register select<br>R3 timer 3 clock control | internal reset | | | Composite Status Register — The Composite Status Register (CSR) is a read-only register which is shared by the Timer and the Peripheral Data Port (of the S6846.) Three individual interrupt flags in the register are set directly via the appropriate conditions in the timer or peripheral port. The composite interrupt flag—and the IRQ Output—respond to these individual interrupts only if corresponding enable bits are set in the appropriate Control Registers. (See Figure 16). The sequence of assertion is not detected. Setting TCR6 while CSR0 is high will cause CSR7 to be set, for example. The Composite Interrupt Flag (CSR7) is clear only if all enabled Individual Interrupt Flags are clear. The conditions for clearing CSR1 and CSR2 are detailed in a later section. The Timer Interrupt Flag (CSR0) is cleared under the following conditions: - 1) Timer Reset Internal Reset Bit (TCR0) = 1 or External Reset = 0. - 2) Any Counter Initialization condition. - 3) A Write Timer Latches command if Time Interval (TCR3 = 1) are being used. - 4) A Read Timer Counter command, provided this is preceded by a Read Composite Status Register while CSR0 is set. This latter condition prevents missing an Interrupt Request generated after reading the Status Register and prior to reading the counter. - The remaining bits of the Composite Status Register (CR3-CSR6) are unused. They default to a logic zero when read. #### I/O Operation Parallel Peripheral Port — The peripheral port of the S6846 contains 8 Peripheral Data lines (P0-P7), two Peripheral Control lines (CP1 and CP2), a Data Direction Register, a Peripheral Data Register, and a Peripheral Control Register. The port also directly affects two bits (CSR1 and CSR2) of the Composite Status Register. The Peripheral Port is similar to the "B" side of a PIA (S6820 or S6821) with the following exceptions: - All registers are directly accessible in the S6846. Data Direction and Peripheral Data in the S6820/6821 are located at the same address, with Bit Two of the Control Register used for register selection. - Peripheral Control Register Bit Two (PCR2) of the S6846 is used to select an optional input latch function. This option is not available with S6820/6821 PIA's. - Interrupt Flags are located in the S6846 composite status register rather than Bits 6 and 7 of the Control Register as used in the S6820/ 6821. - 4) Interrupt Flags are cleared in the \$6820/6821 by reading data from the Peripheral Data Register. \$6846 Interrupt Flags are cleared by either reading or writing to the Peripheral Data Register provided that a sequence of a) Flag Set, b) Read Composite Status Register, c) Read/Write Peripheral Data Register is followed. - 5) Bit 6 of the S6846 Peripheral Control Register is not used. Bit 7 (PCR7) is an Internal Reset Bit not available on the S6820/6821. 6) The Peripheral Data lines (and CP2) of the S6846 feature internal current limiting which allows them to directly drive the base of Darlington NPN transistors. Data Direction Register — The MPU can write directly to this eight-bit register to configure the Peripheral Data lines as either inputs or outputs. A particular bit within the register (DDRN) is used to control the corresponding Peripheral Data line (PN). With DDRN = 0, PN becomes an input; if DDRN = 1, PN is an output. As an example, writing Hex SOF into the Data Direction Register results in P0 through P3 becoming outputs and P4 through P7 being inputs. Hex S35 is the Data Direction Register results in alternate outputs and inputs at the parallel port. Peripheral Data Register — This eight-bit register is used for transferring data between the peripheral data port and the MPU. Any bit corresponding to an output line will be used to drive the output buffer associated with that line. Data in these output bits is normally provided by an MPU Write function (Input bits — those associated with input lines — are unchanged by a Write Command.) Any input bit will reflect the state of the associated input line if the input latch function is deselected. If the Control Register is programmed to provide input latching, the input bit will retain the state at the time CPI was activated until the Peripheral Data Register is read by the MPU. Peripheral Control Register — This eight-bit register is used to control the reset function as well as for selection of optional functions of the two peripheral control lines (CP1 and CP2). The peripheral Control Register functions are outlined in Table 8. Table 8. Peripheral Control Register Format (Expanded) Peripheral Port Reset (PCR7) — Bit 7 of the Peripheral Control Register (PCR7) may be used to initialize the peripheral section of the S6846. When this bit is set high, the peripheral data register, the peripheral data direction register, and the interrupt flags associated with the peripheral port (CSR1 and CSR2) are all cleared. Other bits in the peripheral control register are not affected by PCR7. PCR7 is set by either a logic zero at the External $\overline{\text{RE-SET}}$ input or under program control by writing a "one" into the location. In any case, PCR7 may be cleared only by writing a zero into the location while $\overline{\text{RESET}}$ is high. The bit must be cleared to activate the port. Control of CP1 Peripheral Control Line — CP1 may be used as an interrupt request to the S6846, as a strobe to allow latching of input data, or both. In any case, the input can be programmed to be activated by either a positive or negative transition of the signal. These options are selected via Control Register Bits PCR0, PCR1 & PCR2. Control Register Bit 0 (PCR0) is used to enable the interrupt transfer circuitry of the S6846. Regardless of the state of PCR0, an active transition of CP1 causes the Composite Status Register Bit One (CSR1) to be set. If PCR0 = 1, this interrupt will be reflected in the Composite Interrupt Flag (CSR7), and thus at the $\overline{IRQ}$ output. CSR1 is cleared by a Timer Reset condition or by either reading or writing to the peripheral data register after the Composite Status Register is read. The latter alternative is conditional — CSR1 must have been a logic one when the Composite Status Register was last read. This precludes inadvertent clearing of interrupt flags generated between the time the Status Register is read and the manipulation of peripheral data. Control Register Bit One (PCR1) is used to select the edge which activates CP1. When PCR1 = 0, CP1 is active on negative transitions (high to low). Low to High transitions are sensed by CP1 when PCR1 = 1. In addition to its use as an interrupt input, CP1 can be used as a strobe to capture input data in an internal latch. This option is selected by writing a one into Peripheral Control Register Bit Two (PCR2). In operation, the data at the pins designated by the Data Direction Register as inputs will be captured by an active transition of CP1. An MPU Read of the Periph- eral Data Register will result in the captured data being transferred to the MPU - and it also releases the latch to allow capture of new data. Note that suc- cessive active transitions with no Read Peripheral Data Command between does not update the input latch. Also, it should be noted that use of the input latch function (which can be deselected by writing a zero into PCR2) has no effect on output data. It also does not affect Interrupt function of CP1. Control of CP2 Peripheral Control Line — CP2 may be used as an input by writing a zero into PCR5. In this configuration, CP2 becomes a dual of CP1 in regard to generation of interrupts. An active transition (as selected by PCR4) causes Bit Two of the Composite Status Register to be set. PCR3 is then used to select whether the CP2 transition is to cause CSR7 to be set — and thereby cause $\overline{IRQ}$ to go low. CP2 has no effect on the input latch function of the S6846. Writing a one into PCR5 causes CP2 to function as an output. PCR4 then determines whether CP2 is to be used in a handshake or programmable output mode. With PCR4 = 1, CP2 will merely reflect the data written into PCR3. Since this can readily be changed under program control, this mode allows CP2 to be a programmable output line in much the same manner as those lines selected as outputs by the Data Direction Register. The handshaking mode (PCR5 = 1, PCR4 = 0) allows CP2 to perform one of two functions as selected by PCR3. With PCR3 = 1, CP2 will go low on the first Enable (System $\phi$ 2) positive transition after a Read or Write to the Peripheral Data Register. This Input/Output Acknowledge signal is released (returns high) on the next positive transition of the Enable signal. In the Interrupt Acknowledge mode (PCR5 = 1, PCR4 = PCR3 = 0), CP2 is set when CSR1 is set by an active transition of CP1. It is released (goes low) on the first positive transition of Enable after CSR1 has been cleared via an MPU Read or Write to the Peripheral Data Register. (Note that the previously described conditions for clearing CSR1 still apply.) Restart Sequence — A typical restart sequence for the S6846 will include initialization of both the Peripheral Control and Data Direction Registers of the parallel port. It is necessary to set up the Peripheral Control Register first, since PCR7 = 0 is a condition for writing data into the Data Direction Register. (A logic zero at the external Reset input automatically sets PCR7.) Summary — The S6846 has several optional modes of operation which allow it to be used in a variety of applications. The following tables are provided for reference in selecting these modes. Table 9. S6846 Internal Register Addresses | A2 | A1 | A0 | Register Selected | | |----|----|-----|-----------------------------|--| | 0 | 0 | 0 | Combination Status Register | | | 0 | 0 | 1 | Peripheral Control Register | | | 0 | 1 | 0 | Data Direction Register | | | 0 | 1 | 1 1 | Peripheral Data Register | | | 1 | 0 | 0 | Combination Status Register | | | Ī | 0 | 1 | Timer Control Register | | | 1 | 1 | 0 | Timer MSB Register | | | 1 | 1 | 1 | Timer LSB Register | | | Χ | X | Х | ROM Address | | Table 10. Composite Status Register Table 11. Timer Control Register R = RESET CONDITION W - WRITE TIMER LATCHES T.O. = COUNTER TIME OUT CTG1 = NEG TRANSITION OF PIN 17 CTG+ ~ POS TRANSITION OF PIN 17 t = INTERRUPT FLAG (CSRO) = 0 Table 12. Peripheral Control Register #### S6846 Custom Programming The preferred method of pattern submission is the AMI Hex format as described below with its built-in address space mapping and error checking. This is the format produced by the AMI Assembler/Loader. The format is as follows and may be on paper tape, punched card or other media readable by AMI. In addition the value for $E_0$ , $E_1$ , $E_2$ \* is required to program the mask. Description #### ASCII Character | 1 | Start of record (S) | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | Type of record | | | 0 Header record | | | 1 — Data record | | | $9-{ m End}$ of file record | | 3 - 4 | Byte Count | | | Since each data byte is represented as two hex characters, the byte count must be multiplied by two to get the number of characters to the end of the record. (This includes checksum and address data.) Records may be of any length being defined in each record by the byte count. | | 5, 6, 7, 8 | Address Value | #### 5, 6, 7, 8 The memory location where this record is to be stored. #### 9, ..., NData Each data byte is represented by two hex characters. Most significant character first. #### N+1, N+2Checksum The one's complement of the additive summation (without carry) of the data bytes, the address, and the byte count. #### EXAMPLE: - 1. Only positive logic formats for E0, E1. E2 are accepted. $I = V_{HIGH}$ ; $\theta = V_{LOW}$ . - 2. A "0" indicates the chip is enabled by a logic 0. A "1" indicates the chip is enabled by a logic I. - 3. Paper tape format is the same as the card format above except: - a. The record should be a maximum of 80 characters. - b. Carriage return and line feed after each record followed by another record. - c. There should not be any extra line feed between records at all. - d. After the last record, four (4) \$\$\$\$ (dollar) signs should be punched with carriage return and line feed indicating end of file. #### Ordering Information (see note) | Order No. | No. Pins | Package | Temp. Range | Description | |-----------|----------|---------|-------------|----------------------------------| | S6846P | 40 | Plastic | 0°C - +70°C | NMOS Combination ROM, I/O, Timer | | S6846 | 40 | Ceramic | 0°C +70°C | NMOS Combination ROM, I/O, Timer | Note: Because the S6846 has a ROM in chip for which the bit pattern is customer defined, the part marking will be S6846 — XXX where S6846 is the basic die and XXX is the customer bit pattern identification number. This number is issued at the time of ordering. Special part marking is also available upon request. ## ASYNCHRONOUS COMMUNICATION **INTERFACE ADAPTER (ACIA)** #### ADVANCE PRODUCT DESCRIPTION #### **FEATURES** - 8 Bit Bidirectional Data Bus for Communication with MPI1 - False start bit deletion. - Peripheral/modem control functions. - Double buffered Receiver and Transmitter - One or two stop bit operation. - Eight and nine-bit transmission with optional even and odd parity. - Parity, overrun and framing error checking. - Programmable control register. - Optional ±1, 116, and ±64 clock modes. - Up to 500,000 bps transmission. #### FUNCTIONAL DESCRIPTION The S6850 Asynchronous Communications Interface Adapter (ACIA) provides the data formatting and control to interface serial asynchronous data communications to bus organized systems such as the \$6800 Microprocessing Unit. The S6850 includes select enable, read/write, interrupt and bus interface logic to allow data transfer over an eight bit bi-directional 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. Word lengths, clock division ratios and transmit control through the Request to Send output may be programmed. For modem operation three control lines are provided. These lines allow the ACIA to interface directly with the \$6860 0-600 bps digital modern. #### ABSOLUTE MAXIMUM RATINGS | Supply V | oltage VCC | -0.3 to +7.0V | Operating Temperature Range TA | 0 to +70°C | |-----------|----------------------|---------------|--------------------------------|---------------| | Input Vol | tage V <sub>in</sub> | -0.3 to +7.0V | Storage Temperature Range Tstg | -55 to +150°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. #### DC (STATIC) CHARACTERISTICS (VCC = 5 0V ± 5%, $T_A$ = 25°C imless otherwise noted.) | Characteristic Input High Voltage (Normal Operating Levels) | | Min. | Тур. | Max. | Unit | |-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|------|----------|--------| | | | +2.4 | | $V_{CC}$ | Vdc | | Input Low Voltage (Normal Operating Levels) | V <sub>II</sub> . | -0.3 | | +0.4 | Vde | | Input High Threshold Voltage All Inputs Except Enable | V <sub>lHT</sub> | +2.0 | - | | Vde | | Input Low Threshold Voltage Ali Inputs Except I:nable | VILT | - | - | τ0.8 | Vde | | Input Leakage Current (V <sub>in</sub> = 0'to 5.0 Vdc) R/W, RS, CS0, CS1, ČŠ2, Enable | j ljin | _ | 1.0 | 2.5 | μAdc | | Three-State (Off State) Input Current (Vin = 0.4 to 2.4 Vdc, VCC = max) D0-D7, | ITSI | - | 2.0 | 10 | μAde · | | Output High Voltage ( $I_{\rm Load} = -100 \mu {\rm Adc}$ , Unable Pulse Width $< 25 \mu {\rm s}$ ) All Outputs Except $\overline{\rm IRQ}$ | V <sub>OH</sub> | +2.4 | - | <u> </u> | Vde | | Output Low Voltage (U <sub>Load</sub> = 1.6 mAde) Enable Pulse Width < 25 μs | VoL | | - | +0.4 | Vdc | | Output Leakage Current (Off State) IRQ | <sup>1</sup> LOH | | 1.0 | 10 | μAde | | Power Dissipation | ₽D | _ | 300 | 525 | πıW | | Input Capacitance $(V_{in} = 0, T_A = 25^{\circ}C, T = 1.0 \text{ MHz})$ | Cin | | | | pF | | D0-D7 R/W, RS, CS0, CS1, CS2, RXD, CTS, DCD, CTX, CRX Enable | | -<br>- | - | 10 | | | Output Capacitance<br>$(V_{in} = 0, T_A = 25^{\circ}C, f \approx 1.0 \text{ MHz})$ | Cout | | - | 10 | pF | #### AC (DYNAMIC) CHARACTERISTICS Loading = 130 pF and one TTL load for D0-D7 = 20pF and 1 TTL load for RTS and TXD = 100pF and 3KΩ to VCC for IRQ. #### READ TIMING CHARACTERISTICS (Figure 1) | Characteristic | Symbol | Min. | Typ. | Max. | Unit | |-------------------------------------------------------------|------------------|------|------|------|------| | Setup Time, Address valid to Enable positive transition | TAEW | 180 | - | | ns | | Setup Time, Enable positive transition to Data valid on bus | T <sub>EDR</sub> | | | 395 | ns | | Data Bus Hold Time | THR | 10 | _ | - | ns | | Rise and Fall Time for Enable input | trE, UE | - | _ | 25 | μis | #### FIGURE 1 - READ TIMING CHARACTERISTICS #### WRITE TIMING CHARACTERISTICS (Figure 2) | Characteristic | Symbol | Min. | Тур. | Max. | Unit | |--------------------------------------------------------------------------|--------|-------|----------|------|------| | Enable Pulse Width | TE | 0.470 | - | 25 | μs | | Setup Time, Address valid to Enable positive transition | TAEW | 180 | '- | - | ns | | Setup Time, Data valid to Enable netative transition | TDSU | 300 | | | ns | | Setup time, Read/Write negative transition to Enable positive transition | TWL | 130 | <u> </u> | | ns | | Data Bus Hold Time | THW | 10 | <i></i> | | ns | #### FIGURE 2 WRITE TIMING CHARACTERISTICS #### TRANSMIT/RECEIVE CHARACTERISTICS (Figure 3) | Characteristic | Symbol | Min. | Typ. | Max. | Unit | |----------------------------------------|-------------------|------|------|------|------| | Clock Frequency | | • | | | | | ÷ 1 mode | f <sub>C</sub> | | ! | 500 | KHz | | ÷ 16 mode | | | 1 [ | 800 | KHz | | ÷ 64 mode | | | | 800 | KHz. | | Clock Pulse Width, Low State | PWCL | 600 | | | nsec | | Clock Pulse Width, High State | PWCH | 600 | T | , | nsec | | Delay Time, Transmit Clock to Data Out | TIDD | | | 1.0 | usec | | Set up Time, Receive Data | T <sub>RDSU</sub> | 500 | | | nsec | | Hold Time, Receive Data | T <sub>RDH</sub> | 500 | | | nsec | | Delay Time, Enable to IRQ Reset | TIRQR | | | 1.2 | μsec | | Delay Time, Enable to RTS | TRTS | | | 1.0 | изес | ## FIGURE 3 - TRANSMIT/RECEIVE TIMING ## MPU/ACIA INTERFACE | Pin | Label | FUNCTION | |------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (22) | DO | ACIA BI-DIRECTIONAL DATA LINES-The bi-directional data lines (D0-D7) allow for | | (21) | DI | data transfer between the ACIA and the MPU. The data bus output drivers are three-state | | (20) | D2 | devices that remain in the high-impedance (off) state except when the MPU performs an | | (19) | <b>D</b> 3 | ACIA read operation. The Read/Write line is in the read (high) state when the ACIA is | | (18) | D4 | selected for a read operation, | | (17) | D5 | | | (16) | D6 | | | (15) | D7 | | | (14) | E | ACIA ENABLE SIGNAL—The Enable signal (E) is a high impedance 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 S6800 $\phi$ 2 clock. | | (13) | R/W | READ/WRITE CONTROL SIGNAL—The Read/Write line is a high impedance 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), the ACIA output driver is turned on and a selected register is read. When it is low, the ACIA output driver is turned off and the MPU writes into a selected register. Thus, the Read/Write signal is used to select the Read Only or Write Only registers within the ACIA. | | (8) | CSO | | | (10) | CS1 | | | (9) | CS2 | CHIP SELECT SIGNALS—These three high impedance TTL compatible input lines are used to address an ACIA. A particular ACIA is selected when CSO and CS1 are high and $\overline{CS2}$ is low. Transfers of data to and from ACIA are then performed under the control of Enable, Read/Write, and Register Select. | | (11) | RS | REGISTER SELECT SIGNAL—The Register Select line is a high impedance input that is TTL compatible and is used to select the Transmit/Receive Data or Control/Status registers in the ACIA. 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. | | (7) | ĪRQ | INTERRUPT REQUEST SIGNAL—Interrupt request is a TTL compatible, open drain active low output that is used to interrupt the MPU. The Interrupt Request remains low as long as the cause of the interrupt is present and the appropriate interrupt enable within the ACIA is set. | # ACIA/MODEM OR PERIPHERAL INTERFACE | Pin | Label | FUNCTION | | | | | |-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | (4) | CTX | TRANSMIT CLOCK-The Transmit Clock is a high impedance TTL compatible input used for the clocking of transmitted data. The transmitter initiates data on the negative | | | | | | | | transition of the clock. Clock frequency of 1, 16, or 64 times the data rate may be selected. | | | | | | Pin | Label | FUNCTION | |------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (3) | CRX | <b>RECEIVE CLOCK</b> The Receive Clock is a high impedance TTL compatible input used for synchronization of received data. (In the $\div$ 1 mode, the clock and data must be synchronized externally.) The receiver strobes the data on the positive transition of the clock. Clock frequency of 1, 16, or 64 times the data rate may be selected. | | (2) | RXD | RECEIVED DATA—The Received Data line is a high impedance TTL compatible input through which data is received in a serial NRZ(Non Return to Zero) 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. Data rates are in the range of 0 to 500 Kbps when external synchronization is utilized. | | (6) | TXD | <b>TRANSMIT DATA</b> —The Transmit Data output line transfers serial NRZ data to a modem or other peripheral device. Data rates are in the range of 0 to 500Kbps when external synchronization is utilized. | | (24) | CTS | CLEAR-TO-SEND—This high impedance TTL compatible input provides automatic control of the transmitting end of a communications link via the modern's "clear-to-send" active low output by inhibiting the Transmitter Data Register Empty status bit (TDRE). | | (5) | RTS | REQUEST-TO-SEND—The Request-to-Send output enables the MPU to control a peripheral or modern via the data bus. The active state is low. The Request-to-Send output is controlled by the contents of the ACIA control register. | | (23) | <u>DCD</u> | DATA CARRIER DETECTED—This high impedance TTL compatible input provides automatic control of the receiving end of a communications link by means of the modem "Data-Carrier-Detect" or "Received-Line-Signal Detect" output. The 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 Receiver Interrupt Enable (RIE) is set. | | (12) | $v_{CC}$ | +5 volts ± 5% | | (1), | GND | GROUND | #### APPLICATION INFORMATION INTERNAL REGISTERS. The ACIA has four internal registers utilized for status, control, receiving data, and transmitting data. The register addressing by the R/W and RS lines and the bit definitions for each register are shown in Figure 4. FIGURE 4 - DEFINITION OF ACIA REGISTERS | | BUFFER ADDRESS | | | | | | |----------|----------------|--------------|---------------------------------------------------|---------------------------------------|--|--| | | RS ● R/W | RS ● R/W | $\overline{RS} \bullet \overline{R}/\overline{W}$ | RS • R/W | | | | Data Bus | Transmit | Receiver | - | | | | | Line | Data | Date | Control | Status | | | | Number | Register | Register | Register | Register | | | | | (Write Only) | (Read Only) | (Write Only) | (Read Only) | | | | 0 | Data Bit 0* | Data Bit 0* | Clk. Divide | Rx Data Reg. | | | | • | | | Sel. 1 (CR0) | Full (RDRF) | | | | ı | Data Bit 1 | Data Bit 1 | Clk, Divide | Tx Data Reg. | | | | | | | Sel. 2 (CR1) | Empty (TDRE) | | | | 2 | Data Bit 2 | Data Bit 2 | Word Sel, 1 | Data Carrier | | | | | | | (CR2) | $\overline{Det}$ . $(\overline{DCD})$ | | | | 3 | Data Bit 3 | Data Bit 3 | Word Sel. 2 | Clear-to-Send | | | | | | | (CR3) | ( <del>CTS</del> ) | | | | 4 | Data Bit 4 | Data Bit 4 | Word Sel. 3 | Framing Error | | | | | | | (CR4) | (FE) | | | | 5 | Data Bit 5 | Data Bit 5 | Tx Control 1 | Receiver Overrun | | | | | | | (CR5) | (OVRN) | | | | 6 | Data Bit 6 | Data Bit 6 | Tx Control 2 | Parity Error (PE) | | | | | | | (CR6) | - , , | | | | 7 | Data Bit 7*** | Data Bit 7** | Rx Interrupt. | Interrupt Request | | | | | 1 | | Enable (CR7) | (fRQ) | | | #### Notes: - Leading bit = LSB = Bit 0 - \*\* Unused data bits in received character will be "O's." - \*\*\* Unused data bits for transmission are "don't care's." ACIA 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: transmitting data register, the receiving data register and error status and the modern status inputs of the ACIA. Receiver Data Register Full (RDRF) [Bit 0] — Receiver Data Register Full indicates that received data has been transferred to the Receiver Data Register. RDRF is cleared after an MPU read of the Receiver Data Register or by a Master Reset. The cleared or empty state indicates that the contents of the Receiver 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 (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 if the Receiver Interrupt Enable (RIE) is set. It remains high until the interrupt is cleared by reading the Status Register and the data register or a Master Reset occurs. If the DCD input remains high after Read Status and Read Data or Master Reset have occurred, the DCD Status bit remains high and will follow the DCD input. Clear-to-Send (CTS) [Bit 3] The Clear-to-Send bit indicates the state of the Clear-to-Send input from a modem. A low 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 the start and stop bit and is detected by the absence of the 1st stop bit. This error indicates a synchronization error, faulty transmission, or a break condition. The framing error flag is set or reset during the receiver 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 Receiver 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 tead 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 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. Overrun is also reset by the 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 parity check results are inhibited. Interrupt Request ( $\overline{IRQ}$ ) [Bit 7] The IRQ bit indicates the state of the $\overline{IRQ}$ output. Any interrupt that is set and enabled will be indicated in the status register. Any time the $\overline{IRQ}$ output is low the IRQ bit will be high to indicate the interrupt or service request status. CONTROL REGISTER—The ACIA control Register consists of eight bits of write only 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 modem control output. Counter Divide Select Bits (CR0 and CR1). The Counter Divide Select Bits (CR0 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 and initializes both the receiver and transmitter. Note that after a 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 hits provide for the following clock divide ratios: | CR1 | CR0 | Function | |-----|-----|--------------| | 0 | 0 | ÷ ] | | 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 Bit | | 0 | 1 | 0 | 7 Bits + Even Parity + 1 Stop Bit | | 0 | į | 1 | 7 Bits + Odd Parity + 1 Stop Bit | | 1 | 0 | 0 | 8 Bits + 2 Stop Bits | | 1 | 0 | ı | 8 Bits + 1 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 double-buffered and therefore become effective immediately. Transmitter Control Bits (CR5 and CR6)—Two Transmitter Control bits provide for the control of the Transmitter Buffer Empty interrupt output, the Request-to-Send output and the transmission of a BREAK level (space). The following encoding format is used: | CR6 | CR5 | Function | |-----|-----|-----------------------------------------------------------------------------------------------------| | 0 | 0 | RTS = low, Transmitting Interrupt Dis-<br>abled | | 0 | ì | RTS = low, Transmitting Interrupt Enabled | | l | 0 | RTS = high, Transmitting Interrupt Disabled | | ì | 1 | RTS = low, Transmitting Interrupt Disabled and Transmits a BREAK level on the Transmit Data Output. | Receiver Interrupt Enable Bit (RIE) (CR7)—Interrupts will be enabled by a high level in bit position 7 of the Control Register (CR7). Interrupts caused by the Receiver Data Register Full being high or by a low to high transition on the Data Carrier Detect signal line are enabled or disabled by the Receiver Interrupt Enable Bit. TRANSMIT DATA REGISTER (TDR)—Data is written in the Transmit Data Register during the peripheral enable time (E) when the ACIA has been addressed and RS · R/W is selected. 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 one 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 descrializer (a shift register) upon receiving a complete character. This event causes the Receiver 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 Receiver 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 Receiver 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. #### OPERATIONAL DESCRIPTION From the MPU Bus interface the ACIA appears as two addressable RAM memory locations. Internally, there are four registers; two read-only and two write-only registers. The read-only registers are status and receive data, and the write only registers are control and transmit data. The serial interface consists of serial transmit and receive lines and three modem/peripheral control lines. During a power-on sequence, the ACIA is internally latched in a reset condition to prevent erroneous output transitions. This power-on reset latch can only be released by the master reset function via the control register; bits bij and bij are set "high" for a master reset. 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) and etc. TRANSMITTER—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 Transmitter 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 senalized and transmitted from the Tx 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 fooded for transmission even though the first character is in the process of heing transmitted. This second character will be automatically transferred into the shift register when the first character transmission is completed. The above sequence continues until all the characters have been transmitted. RECEIVER—Data is received from a peripheral by means of the Rx Data input. A divide by one clock ratio is provided for an externally synchronized clock (to us 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 obtained by the detection of the leading mark-to-space transition of the start bit. 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 (odd or even) will be checked and the error indication will be available in the status register along with framing error, everrun error, and receiver 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. The status register can be road again to determine if another character is available in the receiver 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. # ASYNCHRONOUS COMMUNICATION INTERFACE ADAPTER (ACIA) #### Features - 8 Bit Bidirectional Data Bus for Communication with MPU - □ False Start Bit Deletion - □ Peripheral/Modem Control Functions - □ Double Buffered Receiver and Transmitter - ☐ One or Two Stop Bit Operation - ☐ Eight and Nine-Bit Transmission with Optional Even and Odd Parity - ☐ Parity, Overrun and Framing Error Checking - □ Programmable Control Register - ☐ Optional ÷1, ÷16, and ÷64 Clock Modes - ☐ Up to 500,000 bps Transmission #### General Description The S68A50/S68B50 Asynchronous Communications Interface Adapter (ACIA) provides the data formatting and control to interface serial asynchronous data communications to bus organized systems such as the S68A00/S68B00 Microprocessing Units. The S68A50/S68B50 includes select enable, read/write, interrupt and bus interface logic to allow data transfer over an eight-bit bidirectional 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. Word lengths, clock division ratios and transmit control through the Request to Send output may be programmed. For modem operation three control lines are provided. #### **Absolute Maximum Ratings** | Supply Voltage | V | |-----------------------------|--------------| | Input Voltage 0.3V to +7.0 | | | Operating Temperature Range | $^{c}$ | | Storage Temperature Range | $\mathbf{C}$ | #### Note: This device contains circuitry to protect the inputs against damage due to high static voltages or electrical 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. # Electrical Characteristics ( $V_{CC}$ = +5.0V ±5%, $V_{SS}$ = 0, $T_{\Lambda}$ = 0°C to +70°C unless otherwise noted.) | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------------------------|------------------------------------------------------|----------------------|---------|----------------------|-------|---------------------------------------------------------------| | VIH | Input High Voltage (normal operating level) | V <sub>SS</sub> +2.0 | 1 | ı Vcc | Vdc | • | | $v_{L}$ | Input Low Voltage (normal operating level) | $V_{\rm SS}$ 0.3 | | V <sub>SS</sub> +0.8 | Vde | | | IIN | Input Leakage Current R/W, ES, CS0, CS1, CS2, Enable | | 1.0 | 2.5 | μAde | $V_{IN} = 0$ Vdc to 5.25Vdc | | ITSI | Three-State (Off State) Input Current D0-D7 | Ī | 2.0 | 10 | μAdc | $V_{\rm IN}$ = 0.4Vdc to 2.4Vdc | | VOH | Output High Voltage (all outputs except IRQ) | | | | | | | | D0-D7 | V <sub>SS</sub> +2.4 | İ | | Vdc | I <sub>LOAD</sub> = -205µ Ade,<br>Enable Pulse Width <25µs | | | Tx Data, RTS | V <sub>SS</sub> +2.4 | | ļ | Vdc | I <sub>LOAD</sub> = -100μAdc,<br>Enable Pulse Width <25μs | | V <sub>OL</sub> | Output Low Voltage (Enable pulse width < 25µs) | | | V <sub>S</sub> g+0.4 | Vdc | $I_{ m LOAD}$ = 1.6mAdc,<br>Enable Pulse Width $<$ 25 $\mu s$ | | lLOH | Output Leakage Current (Off State) IRQ | | 1.0 | . 10 | μAdc | V <sub>OH</sub> = 2.4Vdc | | $P_{\mathrm{D}}$ | Power Dissipation | | 300 | 525 | mW | • | | $c_{IN}$ | Input Capacitance | | | • | | | | | D0-D7<br>E,Tx,CLK,Rx Clk,R/W,RS,Rx Data. | | 10 | 12.5 | pF | | | | CS0,CS1,CS2,RXD,CTS,DCD,CTX,CRX | | 7.0 | 7.5 | рF | i<br>V <sub>IN</sub> = 0, T <sub>A</sub> = 25°C, | | COUT | Output Capacitance RTS,Tx Data | | | 10 | ρF | f = 1.0MHz | | 001 | ĪRQ | · | | 5.0 | p₩ | İ | | PWCL | Minimum Clock Pulse Width, Low ÷16, ÷64 Modes | 600 | | · | ns | _ | | PWCH | Minimum Clock Pulse Width, High ÷16, ÷64 Modes | 600 | | _ | ทร | | | $f_{\mathrm{C}}$ | Clock Frequency ÷1 Mode | | İ | 500 | kHz | | | | ÷16, ÷64 Modes | ļ | | 800 | kHz | | | t <sub>TDD</sub> | Clock-to-Data Delay for Transmitter | ļ , | <u></u> | ↓ _ <sup>1.0</sup> | μs | | | <sup>t</sup> R <u>D</u> ŞU | Receive Data Setup Time ÷1 Mode | 500 | | !<br>- | ns | | | tr.DH_ | Receive Data Hold Time ÷1 Mode | 500 | | | ns | <del></del> | | <sup>t</sup> IR | Interrupt Request Release Time | | | 1.2 | μs | <u></u> | | LRTS | Request-to-Send Delay Time | | | 1.0 | μ5 | | | $t_{r}, t_{f}$ | Input Transition Times (Except Enable) | į | | 1.0* | μS | | <sup>\*1.0</sup>µ or 10% of the pulse width, whichever is smaller. Bus Timing Characteristics ( $V_{CC}$ = +5.0V ±5%, $V_{SS}$ = 0, $T_A$ = 0°C to +70°C unless otherwise noted.) ## Read | | | S68. | S68 | | | | |-----------------------------------|--------------------------------------------------------------------|----------|------|------|------------|-------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | | t <sub>cycF</sub> | Enable Cycle Time | 0.666 | | 0.50 | †· · | μs | | PWEH | Enable Pulse Width, High | 0.28 | 25 | 0.22 | <b>2</b> 5 | μs | | $\overline{_{\mathrm{PW_{EL}}}}$ | Enable Pulse Width, Low | 0.28 | | 0.21 | † · · · · | μs | | t <sub>AS</sub> | Setup Time, Address and R/W Valid<br>to Enable Positive Transition | 140 | | 70 | | ns | | t <sub>DDR</sub> | Data Delay Time | <b>1</b> | 220 | | 180 | ns | | t <sub>H</sub> | Data Hold Time | 10 | | 10 | 1 | ns | | $t_{AH}$ | Address Hold Time | 10 | | 10 | | ns | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable Input | | 25 | _ | 25 | ns | #### Write | | | S68 | Λ50 | S68 | | | |-----------------------------------|--------------------------------------------------------------------|-------|------|------|------|-------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Units | | teycE | Enable Cycle Time | 0.666 | | 0.50 | | μs | | PWEH | Enable Pulse Width, High | 0.28 | 25 | 0.22 | 25 | μѕ | | $PW_{EL}$ | Enable Pulse Width, Low | 0.28 | | 0.21 | | μѕ | | tAS | Setup Time, Address and R/W Valid<br>to Enable Positive Transition | 140 | | 70 | | ns | | $t_{DSW}$ | Data Setup Time | 80 | | 60 | | ns | | $t_{\rm H}$ | Data Hold Time | 10 | | 10 | | ns | | t <sub>AH</sub> | Address Hold Time | 10 | | 10 | | ns | | t <sub>Fr</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable Input | | 25 | ļ | 25 | ns | # MPU/ACIA Interface | Pin | Label | Function | |--------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (22)<br>(21)<br>(20)<br>(19)<br>(18)<br>(17)<br>(16)<br>(15) | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7 | ACIA Bidirectional Data Lines — The bidirectional data lines (D0-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. The Read/Write line is in the read (high) state when the ACIA is selected for a read operation. | | (14) | Е | ACIA Enable Signal — The Enable signal (E) is a high impedance 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 S6800 $\phi 2$ clock. | | (13) | R/W | Read/Write Control Signal — The Read/Write line is a high impedance 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), the ACIA output driver is turned on and a selected register is read. When it is low, the ACIA output driver is turned off and the MPU writes into a selected register. Thus, the Read/Write signal is used to select the Read Only or Write Only registers within the ACIA. | | (8)<br>(10)<br>(9) | $\frac{\text{CS0}}{\text{CS1}}$ | Chip Select Signals — These three high impedance TTL compatible input lines are used to address an ACIA. A particular ACIA is selected when CS0 and CS1 are high and $\overline{\text{CS2}}$ is low. Transfers of data to and from ACIA are then performed under the control of Enable, Read/Write and Register Select. | | (11) | RS | Register Select Signal — The Register Select line is a high impedance input that is TTL compatible and is used to select the Transmit/Receive Data or Control/Status registers in the ACIA. 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. | | (7) | ĪRQ | Interrupt Request Signal — Interrupt request is a TTL compatible, open drain active low output that is used to interrupt the MPU. The Interrupt Request remains low as long as the cause of the interrupt is present and the appropriate interrupt enable within the $\Lambda$ CIA is set. | # ACIA/Modem or Peripheral Interface | Pin | Label | Function | |------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (4) | CTX | Transmit Clock — The Transmit Clock is a high impedance TTL compatible input used for the clocking of transmitted data. The transmitter initiates data on the negative transition of the clock. Clock frequency of 1, 16, or 64 times the data rate may be selected. | | (3) | CRX | Receive Clock — The Receive Clock is a high impedance TTL compatible input used for synchronization of received data. (In the ÷1 mode, the clock and data must be synchronized externally.) The receiver strobes the data on the positive transition of the clock. Clock frequency of 1, 16, or 64 times the data rate may be selected. | | (2) | RXD | Received Data — The Received Data line is a high impedance TTL compatible input through which data is received in a serial NRZ (Non Return to Zero) 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. Data rates are in the range of 0 to 500Kbps when external synchronization is utilized. | | (6) | TXD | Transmit Data — The Transmit Data output line transfers serial NRZ data to a modem or other peripheral device. Data rates are in the range of 0 to 500Kbps when external synchronization is utilized. | | (24) | CT§ | Clear-to-Send — This high impedance TTL compatible input provides automatic control of the transmitting end of a communications link via the modem's "clear-to-send" active low output by inhibiting the Transmitter Data Register Empty status bit (TDRE). | | (5) | RTS | Request-to-Send — The Request-to-Send output enables the MPU to control a peripheral or modem via the data bus. The active state is low. The Request-to-Send output is controlled by the contents of the ACIA control register. | | (23) | DCD | Data Carrier Detected — This high impedance TTL compatible input provides automatic control of the receiving end of a communications link by means of the modem "Data-Carrier-Detect" or "Received-Line-Signal Detect" output. The 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 Receiver Interrupt Enable (RIE) is set. | | (12) | $v_{\rm cc}$ | +5volts ± 5% | | (1) | GND | Ground | | | | | #### Application Information Internal Registers — The ACIA has four internal registers utilized for status, control, receiving data and transmitting data. The register addressing by the R/W and RS lines and the bit definitions for each register are shown in Figure 4. Figure 4 — Definition of ACIA Registers | | | Buff | er Address | | |----------------------------|-----------------------------------------------|--------------|------------------------------|------------------------------| | | RS ● R/W | RS ● R/W | RS • R/W | RS • R/W | | Data Bus<br>Line<br>Number | Transmit Received Data Data Register Register | | Control<br>Register | Status<br>Register | | | (Write Only) | (Read Only) | (Write Only) | (Read Only) | | 0 | Data Bit 0* | Data Bit 0* | Clk. Divide<br>Sel. (CR0) | Rx Data Reg.<br>Full (RDRF) | | 1 | Data Bit 1 | Data Bit 1 | Clk. Divide<br>Sel. (CR1) | Tx Data Reg.<br>Empty (TDRE) | | 2 | Data Bit 2 | Data Bit 2 | Word Sel. 1<br>(CR2) | Data Carrier Det. Loss (DCD) | | 3 | Data Bit 3 | Data Bit 3 | Word Sel. 2<br>(CR3) | Clear-to-Send<br>(CTS) | | 4 | Data Bit 4 | Data Bit 4 | Word Sel. 3<br>(CR4) | Framing Error<br>(FE) | | 5 | Data Bit 5 | Data Bit 5 | Tx Control 1<br>(CR5) | Overrun (OVRN) | | 6 | Data Bit 6 | Data Bit 6 | Tx Control 2<br>(CR6) | Parity Error (PE) | | 7 | Data Bit 7*** | Data Bit 7** | Rx Interrupt<br>Enable (CR7) | Interrupt Request<br>(IRQ) | #### Notes: Leading bit = LSB = Bit 0 \*\* Unused data bits in received character will be "0's" \*\*\* Unused data bits for transmission are "don't care's" ACIA 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: transmitting data register, the receiving data register and error status and the modem status inputs of the ACIA. Receiver Data Register Full (RDRF) [Bit 0] — Receiver Data Register Full indicates that received data has been transferred to the Receiver Data Register. RDRF is cleared after an MPU read of the Receiver Data Register or by a Master Reset. The cleared or empty state indicates that the contents of the Receiver 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{DCD}$ ) [Bit 2] — The Data Carrier Detect bit will be high when the $\overline{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 if the Receiver Interrupt Enable (RIE) is set. It remains high until the interrupt is cleared by reading the Status Register and the data register or a Master Reset occurs. If the $\overline{DCD}$ input remains high after Read Status and Read Data or Master Reset have occurred, the $\overline{DCD}$ Status bit remains high and will follow the $\overline{DCD}$ input. Clear-to-Send (CTS) [Bit 3] — The Clear-to-Send bit indicates the state of the Clear-to-Send input from a modem. A low 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 the start and stop bit and is detected by the absence of the 1st stop bit. This error indicates a synchronization error, faulty transmission, or a break condition. The framing error flag is set or reset during the receiver 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 Receiver 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 Overrun is reset. Character synchronization is maintained during the Overrun condition. The overrun indication is reset after the reading of data from the Receiver Data Register. Overrun is also reset by the 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 parity check results are inhibited. Interrupt Request $(\overline{1RQ})$ [Bit 7] — The IRQ bit indicates the state of the $\overline{1RQ}$ output. Any interrupt that is set and enabled will be indicated in the status register. Any time the $\overline{1RQ}$ output is low the IRQ bit will be high to indicate the interrupt or service request status. Control Register — The ACIA Control Register consists of eight bits of write only 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 modern control output. Counter Divide Select Bits (CR0 and CR1) — The Counter Divide Select Bits (CR0 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 and initializes both the receiver and transmitter. Note that after a 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 + I 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 + 1 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 double-buffered and therefore become effective immediately. Transmitter Control Bits (CR5 and CR6) — Two Transmitter Control bits provide for the control of the Transmitter Buffer Empty interrupt output, the Request-to-Send output and the transmission of a BREAK level (space). The following encoding format is used: | CR6 | CR5 | Function | |-----|-----|-----------------------------------------------------------------------------------------------------| | 0 | 0 | $\overline{RTS}$ = low, Transmitting Interrupt Disabled | | 0 | 1 | RTS = low, Transmitting Interrupt Enabled | | 1 | 0 | RTS = high, Transmitting Interrupt Disabled | | 1 | 1 | RTS = low, Transmitting Interrupt Disabled and Transmits a BREAK level on the Transmit Data Output. | Receiver Interrupt Enable Bit (RIE) (CR7) — The Interrupts will be enabled by a high level in bit position 7 of the Control Register (CR7). Interrupts caused by the Receiver Data Register Full being high or by a low to high transition on the Data Carrier Detect signal line are enabled or disabled by the Receiver Interrupt Enable Bit. Transmit Data Register (TDR) — Data is written in the Transmit Data Register during the peripheral enable time (E) when the ACIA has been addressed and RS • R/W is selected. 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 one 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 descrializer (a shift register) upon receiving a complete character. This event causes the Receiver 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 Receiver 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 Receiver 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. #### Operational Description From the MPU Bus interface the ACIA appears as two addressable RAM memory locations. Internally, there are four registers; two read-only and two write-only registers. The read-only registers are status and receive data, and the write-only registers are control and transmit data. The serial interface consists of serial transmit and receive lines and three modem/peripheral control lines. During a power-on sequence, the ACIA is internally latched in a reset condition to prevent erroneous output transitions. This power-on reset latch can only be released by the master reset function via the control register: bits b0 and b1 are set "high" for a master reset. 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) and etc. Transmitter -- 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 Trans- mitter 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 Tx 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. This second character will be automatically transferred into the shift register when the first character transmission is completed. The above sequence continues until all the characters have been transmitted. Receiver — Data is received from a peripheral by means of the Rx 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 obtained by the detection of the leading mark-to-space transition of the start bit. 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 (odd or even) will be checked and the error indication will be available in the status register along with framing error, overrun error, and receiver data register full. In a typical recciving 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. The status register can be read again to determine if another character is available in the receiver 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. # SYNCHRONOUS SERIAL DATA ADAPTER (SSDA) #### **Features** - ☐ Programmable Interrupts from Transmitter, Receiver, and Error Detection Logic - ☐ Character Synchronization on One or Two Sync Codes - External Synchronization Available for Parallel-Serial Operation - ☐ Programmable Sync Code Register - ☐ Up to 600kbps Transmission - □ Peripheral/Modem Control Functions - ☐ Three Bytes of FIFO Buffering on Both Transmit and Receive - ☐ Seven, Eight, or Nine Bit Transmission - Optional Even and Odd Parity - ☐ Parity, Overrun, and Underflow Status #### General Description The S6852 Synchronous Serial Data Adapter provides a bi-directional serial interface for synchronous data information interchange. It contains interface logic for simultaneously transmitting and receiving standard synchronous communications characters in bus organized systems such as the S6800 Microprocessor systems. The bus interface of the S6852 includes select, enable, read/write, interrupt, and bus interface logic to allow data transfer over an 8-bit bi-directional data bus. The parallel data of the bus system is serially transmitted and received by the synchronous data interface with synchronization, fill character insertion/deletion, and error checking. The functional configuration of the SSDA is programmed via the data bus during system initialization. Programmable control registers provide control for variable word lengths, transmit control, receive control, synchronization control, and interrupt control. Status, timing and control lines provide peripheral or modem control. Typical applications include floppy disk controllers, cassette or cartridge tape controllers, data communications terminals, and numerical control systems. Pin Configuration #### ٧٠٠ 2∏ R∗UATA 000 173 D. 1 21 4∏ i×Ck b∏ swrbté 82 70 6∏ tx data 03 T 19 ₁∏⊪₀ S6852 84 N IR e∏ Yur 05 11/ E ☐ RESET D6 | 15 07 15 E ] 14 BAV ] 13 ıo∏ cs D RS #### **Maximum Ratings** | Supply Voltage0.3V to +7.0V | |------------------------------------------| | Input Voltage | | Operating Temperature Range 0°C to +70°C | | Storage Temperature Range55°C to +150°C | | Thermal Resistance+70°C/W | 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. Electrical Characteristics (V $_{CC}$ = +5.0V ±5%, V $_{SS}$ = 0, T $_{A}$ = 0 $^{\circ}C$ to 70 $^{\circ}C$ unless otherwise noted.) | Symbol | Parameter | Min, | Тур. | Max. | Units | Canditions | |-------------------|-------------------------------------------------------------------------------------|------------------------------------------------|----------|-----------------------|-------|------------------------------------------------------------------------------------------------| | VIH | Input High Voltage | V <sub>SS</sub> + 2.0 | | | Vdc | | | VIL | Input Low Voltage | | | V <sub>SS</sub> + 0.8 | Vdc | | | I <sub>in</sub> | Input Leakage Current Tx Clk, Rx Clk, Rx Data, Enable, Reset, RS, R/W, CS, DCD, CTS | | 1.0 | 2.5 | μAde | V <sub>in</sub> = 0Vde to 5,25Vdc | | ITSI | Three -State (Off State) Input Current DO-D7 | | 2.0 | 10 | μ Ade | V <sub>in</sub> = 0.4Vdc to 2.4Vdc,<br>V <sub>CC</sub> = 5.25Vdc | | VOH. | Output High Voltage D0-D7 Tx Data, \overline{\overline{\text{DTR}}}, TUF | V <sub>SS</sub> + 2.4<br>V <sub>SS</sub> + 2.4 | | | Vdc | ILoad = -205µAdc,<br>Enable Pulse Width <25µs<br>ILoad = -100µAdc,<br>Enable Pulse Width <25µs | | VOL | Output Low Voltage | | | V <sub>SS</sub> + 0.4 | Vdc | I <sub>Load</sub> = 1.6mAde,<br>Enable Pulse Width <25as | | ILOH | Output Leakage Current (Off State) TRQ | | 1.0 | 10 | μAde | V <sub>OH</sub> = 2.4Vdc | | PD | Power Dissipation | ] | 300 | 525 | mW | | | Cin | Input Capacitance DO-D7 Other Inputs | | ] | 12.5<br>7.5 | pF | $V_{in} = 0$ , $T_A = 25$ °C,<br>f = 1.0MHz | | Cout | Output Capacitance Tx Data, SM/DTR, TUF, IRQ | | <b>_</b> | 10<br>5.0 | pF | V <sub>in</sub> = 0, T <sub>A</sub> = 25°C,<br>f = 1.0MHz | | PWCL | Minimum Clock Pulse Width, Low | 700 | | | ns | Figure 1 | | PW <sub>CH</sub> | Minimum Clock Pulse Width, High | 700 | 1 | T | ns | Figure 2 | | (C | Clock Frequency | | | 600 | kHz | ,, | | trosu | Receive Data Serup Time | 350 | | | ns. | Figure 3, 7 | | <sup>t</sup> RD[[ | Receive Data Hold Time | 350 | | | ns | Figure 3 | | tsM | Sync Match Delay Time | l | | 1.0 | μs | Figure 3 | | tTDD | Clock to Data Belay for Transmitter | | | 1.0 | μs | Figure 4 | | †TUF | Transmitter Underflow | 1 | | 1.0 | μs | Figure 4, 6 | | tDTR | DTR Delay Time | | | 1.0 | ħ₽ | Figure 5 | | t1R | Interrupt Request Release Time | | | 1.2 | μs | Figure 5 | | tRes | Reset Minimum Pulse Width | 1.0 | | | hr | | | ters | CTS Setup Time | T | | 200 | п\$ | Figure 6 | | <sup>t</sup> DCD | DCD Setup Time | | | 500 | пѕ | Figure 7 | | tr, tf | Input Rise and Fall Times (except Enable) | | | 1.0* | ha | 0.8V to 2.0V | <sup>\*1.0</sup>µs or 10% of the pulse width, whichever is smaller. # **Bus Timing Characteristics** #### Read | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |-----------------|-----------------------------------------------------------------|------|----------------|------|--------------------|---------------------| | $t_{\rm eyeE}$ | Enable Cycle Time | 1.0 | | | μs | | | PWEH | Enable Pulse Width, High | 0.45 | | 25 | μs | | | PWEL | Enable Pulse Width, Low | 0.43 | | | $\mu_{\mathbf{S}}$ | | | <sup>t</sup> AS | Setup Time, Address and R/W valid to Enable positive transition | 160 | | | ns | Figures<br>8 and 10 | | gaat | Data Delay Time | | | 320 | ns | | | tH | Data Hold Time | 10 | <del>-</del> - | | ns | ] | | tAH | Address Hold Time | 10 | | | ns | 1 | | tEr, tEf | Rise and Fall Time for Enable input | | T | 25 | ns | | #### Write | Symbol | Parameter | Min. | Typ. | Max. | Unit | Conditions | |-----------------------------------|-----------------------------------------------------------------|------|------|------|------|---------------------| | $t_{\rm cycE}$ | Enable Cycle Time | 1.0 | | | μs | | | PWEH | Enable Pulse Width, High | 0.45 | | 25 | μs | ] | | PWEL | Enable Pulse Width, Low | 0.43 | | | με | | | t <sub>AS</sub> | Setup Time, Address and R/W valid to Enable positive transition | 160 | | | ns | Figures<br>9 and 10 | | $t_{ m DSW}$ | Data Setup Time | 195 | | | ns | | | tH | Data Hold Time | 10 | | | ns | | | t <sub>AH</sub> | Address Hold Time | 10 | ļ | | ns | | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable input | | | 25 | ns | ] | #### **Device Operation** At the bus interface, the SSDA appears as two addressable memory locations. Internally, there are seven registers: two read-only and five write-only registers. The read-only registers are Status and Receive Data; the write-only registers are Control 1, Control 2, Control 3, Sync Code and Transmit Data. The serial interface consists of serial input and output lines with independent clocks, and four peripheral/modem control lines. Data to be transmitted is transferred directly into the 3-byte Transmit Data First-In First-Out (FIFO) Register from the data bus. Availability of the input to the FIFO is indicated by a bit in the Status Register; once data is entered, it moves through the FIFO to the last empty location. Data at the output of the FIFO is automatically transferred from the FIFO to the Transmitter Shift Register as the shift register becomes available to transmit the next character. If data is not available from the FIFO (underflow condition), the Transmitter Shift Register is automatically loaded with either a sync code or an all "1"s character. The transmit section may be programmed to append loaded with either a sync code or an all "1"s character. The transmit section may be programmed to append even, odd, or no parity to the transmitted word. An external control line (Clear-to-Send) is provided to inhibit the transmitter without clearing the FIFO. Serial data is accumulated in the receiver based on the synchronization mode selected. In the external sync mode, used for parallel-serial operation, the receiver is synchronized by the DCD (Data Carrier Detect) input and transfers successive bytes of data to the input of the Receiver FIFO. The single-sync-character mode requires that a match occur between the Sync Code Register and one incoming character before data transfer to the FIFO begins. The two-sync-character mode requires that two sync codes be received in sequence to establish synchronization. Subsequent to synchronization in any mode, data is accumulated in the shift register, and parity is optionally checked. An indication of parity error is carried through the Receiver FIFO with each character to the last empty location. Availability of a word at the FIFO output is indicated by a bit in the Status Register, as is a parity error. The SSDA and its internal registers are selected by the address bus, Read/Write (R/W) and Enable control lines. To configure the SSDA, Control Registers are selected and the appropriate bits set. The Status Register is addressable for reading status. Other I/O lines, in addition to Clear-to-Send (CTS) and Data Carrier Detect (DCD), include SM/DTR (Sync Match/Data Terminal Ready) and Transmitter Underflow (TUF). The transmitter and receiver each have individual clock inputs allowing simultaneous operation under separate clock control. Signals to the microprocessor are the Data bus and Interrupt Request (IRQ). #### Initialization During a power-on sequence, the SSDA is reset via the Reset input and internally latched in a reset condition to prevent erroneous output transitions. The Sync Code Register, Control Register 2, and Control Register 3 should be programmed prior to the programmed release of the Transmitter and/or Receiver Reset bits; these bits in Control Register 1 should be cleared after the Reset line has gone high. #### Transmitter Operation Data is transferred to the transmitter section in parallel form by means of the data bus and Transmit Data FIFO. The Transmit Data FIFO is a 3-byte register whose status is indicated by the Transmitter Data Register Available status bit (TDRA) and its associated interrupt enable bit. Data is transferred through the FIFO on Enable (E) pulses. Two data transfer modes are provided in the SSDA. The 1-byte transfer mode provides for writing data to the transmitter section (and reading from the receiver section) one byte at a time. The 2-byte transfer mode provides for writing two data characters in succession. Data will automatically transfer from the last register location in the Transmit Data FIFO (when it contains data) to the Transmitter Shift Register during the last half of the last bit of the previous character. A character is transferred into the Shift Register by the Transmitter Clock. Data is transmitted *LSB first*, and odd or even parity can be optionally appended. The unused bit positions in short word length characters from the data bus are "don't cares." (Note: The data bus inputs may be reversed for applications requiring the MSB to be transferred first, e.g., IBM format for floppy disks; however, care must be taken to properly program the control registers — Table 1 will have its bit positions reversed.) When the Shift Register becomes empty and data is not available for transfer from the Transmit Data FIFO, an "underflow" occurs, and a character is inserted into the transmitter data stream to maintain character synchronization. The character transmitted on underflow will be either a "Mark" (all "1"s) or the contents of the Sync Code Register, depending upon the state of the Transmit Sync Code on Underflow control bit. The underflow condition is indicated by a pulse (\$1 Tx Clk high period) on the Underflow output (when in Tx Sync on underflow mode). The Underflow output occurs coincident with the transfer of the last half of the last bit preceding the underflow character. The Underflow status bit is set until cleared by means of the Clear Underflow control bit. This output may be used in floppy disk systems to synchronize write operations and for appending CRCC. Transmission is initiated by clearing the Transmitter Reset bit in Control Register 1. When the Transmitter Reset bit is cleared, the first full positive half-cycle of the Transmit Clock will initiate the transmit cycle, with the transmission of data or underflow characters beginning on the negative edge of the Transmit Clock pulse which started the cycle. If the Transmit Data FIFO was not loaded, an underflow character will be transmitted (see Figure 4). The Clear-to-Send (CTS) input provides for automatic control of the transmitter by means of external system hardware; e.g., the modem CTS output provides the control in a data communications system. The CTS input resets and inhibits the transmitter section when high, but does not reset the Transmit Data FIFO. The TDRA status bit is inhibited by CTS being high in either the one-sync-character or two-sync-character mode of operation. In the external sync mode, TDRA is unaffected by CTS in order to provide Transmit Data FIFO status for preloading and operating the transmitter under the control of the CTS input. When the Transmitter Reset bit (Tx Rx) is set, the Transmit Data FIFO becomes available for new data with TDRA inhibited. #### Receiver Operation Data and a presynchronized clock are provided to the SSDA receiver section by means of the Receive Data (Rx Data) and Receive Clock (Rx Clk) inputs. The data is a continuous stream of binary data bits without means for identifying character boundaries within the stream. It is, therefore, necessary to achieve character synchronization for the data at the beginning of the data block. Once synchronization is achieved, it is assumed to be retained for all successive characters within the block. Data communications systems utilize the detection of sync codes during the initial portion of the preamble to establish character synchronization. This requires the detection of a single code or two successive sync codes. Floppy disk and cartridge tape units require sixteen bits of defined preamble and cassettes require eight bits of preamble to establish the reference for the start of record. All three are functionally equivalent to the detection of sync codes. Systems which do not utilize code detection techniques require custom logic external to the SSDA for character synchronization and use of the parallel-to-serial (external sync) mode. (Note: The Receiver Shift Register is set to ones when reset.) #### Synchronization The SSDA provides three operating modes with respect to character synchronization: - one-sync-character mode, two-sync-character mode, and external sync mode. The external sync mode requires synchronization and control of the receiving section through the Data Carrier Detect (DCD) input (see Figure 7). This external synchronization could consist of direct line control from the transmitting end of the serial data link or from external logic designed to detect the start of the message block. The one-sync-character mode searches on a bit-by-bit basis until a match is achieved between the data in the Shift Register and the Sync Code Register. The match indicates character synchronization is complete and will be retained for the message block. In the two-sync-character mode, the receiver searches for the first sync code match on a bit-by-bit basis and then looks for a second successive sync code character prior to establishing character synchronization. If the second sync code character is not received, the bit-by-bit search for the first sync code is resumed. Sync codes received prior to the completion of synchronization (one or two character) are not transferred to the Receive Data FIFO. Redundant sync codes during the preamble or sync codes which occur as "fill characters" can automatically be stripped from the data, when the Strip Sync control bit is set, to minimize system loading. The character synchronization will be retained until cleared by means of the Clear Sync bit, which also inhibits synchronization search when set. #### Receiving Data Once synchronization has been achieved, subsequent characters are automatically transferred into the Receive Data FIFO and clocked through the FIFO to the last empty location by E pulses (MPU System $\phi$ 2). The Receiver Data Available status bit (RDA) indicates when data is available to be read from the last FIFO location (#3) when in 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 are full. Data being available in the Receive Data FIFO causes an interrupt request if the Receiver Interrupt Enable (RIE) bit is set. The MPU will then read the SSDA Status Register, which will indicate that data is available for the MPU read from the Receive Data FIFO register. The IRQ and RDA status bits are reset by a read from the FIFO. If more than one character has been received and is resident in the Receive Data FIFO, subsequent E clocks will cause the FIFO to update and the RDA and IRQ status bits will again be set. The read data operation for the 2-byte transfer mode requires an intervening E clock between reads to allow the FIFO data to shift. Optional parity is automatically checked as data is received, and the parity status condition is maintained with each character until the data is read from the Receive Data FIFO. Parity errors will cause an interrupt request if the Error Interrupt Enable (EIE) has been set. The parity bit is not transferred to the data bus but must be checked in the Status Register, NOTE: In the 2-byte transfer mode, parity should be checked prior to reading the second byte, since a FIFO read clears the error bit. Other status bits which pertain to the receiver section are Receiver Overrun and Data Carrier Detect (DCD). The Overrun status bit is automatically set when a transfer of a character to the Receive Data FIFO occurs and the first register of the Receive Data FIFO is full. Overrun causes an interrupt if Error Interrupt Enable (EIE) has been set. The transfer of the overrunning character into the FIFO causes the previous character in the FIFO input register location to be lost The Overrun status bit is cleared by reading the Status Register (when the overrun condition is present), followed by a Receive Data FIFO Register read. Overrun cannot occur and be cleared without providing an opportunity to detect its occurrence via the Status Register. A positive transition on the $\overline{DCD}$ input causes an interrupt if the EIE control bit has been set. The interrupt caused by $\overline{DCD}$ is cleared by reading the Status Register when the $\overline{DCD}$ status bit is high, followed by a Receive Data FIFO read. The $\overline{DCD}$ status bit will subsequently follow the state of the $\overline{DCD}$ input when it goes low. #### Input/Output Functions #### SSDA Interface Signals for MPU The SSDA interfaces to the S6800 MPU with an 8-bit bi-directional data bus, a chip select line, a register select line, an interrupt request line, read/write line, an enable line, and a reset line. These signals, in conjunction with the S6800 VMA output, permit the MPU to have complete control over the SSDA. SSDA Bi-Directional Data (D0-D7)—The bi-directional data lines (D0-D7) allow for data transfer between the SSDA 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 SSDA read operation. SSDA Enable (E) — The Enable signal, E, is a high impedance TTL compatible input that enables the bus input/output data buffers, clocks data to and from the SSDA, and moves data through the FIFO Registers. This signal is normally the continuous S6800 System $\phi 2$ clock, so that incoming data characters are shifted through the FIFO. Read/Write (R/W) — The Read/Write line is a high impedance input that is TTL compatible and is used to control the direction of data flow through the SSDA's input/output data bus interface. When Read/Write is high (MPU read cycle), SSDA output drivers are turned on if the chip is selected and a selected register is read. When it is low, the SSDA output drivers are turned off and the MPU writes into a selected register. The Read/Write signal is also used to select read-only or write-only registers within the SSDA. Chip Select (CS)— This high impedance TTL compatible input line is used to address the SSDA. The SSDA is selected when $\overline{CS}$ is low. VMA should be used in generating the $\overline{CS}$ input to insure that false selects will not occur. Transfers of data to and from the SSDA are then performed under the control of the Enable signal, Read/Write, and Register Select. Register Select (RS) — The Register Select line is a high impedance input that is TTL compatible. A high level is used to select Control Registers C2 and C3, the Sync Code Register, and the Transmit/Receive Data Registers. A low level selects the Control 1 and Status Registers (see Table 1). Table 1. SSDA Programming Model | AEGISTEA | CONTROL INPUTS | | ADDRESS CONTROL | | REGISTER CONTENT | | | | | | | | |-----------------------|----------------|-----|-----------------|-----|---------------------------------------|-------------------------------------------------------|------------------------------------------|--------------------------------------------------|------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------| | | RS | R/W | AC2 | ACT | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | STATUS (S) | a | 1 | X | x | INTERRUPT<br>REQUEST<br>(IRQ) | RECEIVER<br>PARITY<br>ERROR<br>(PE) | RECEIVER<br>OVERRUN<br>(Rx Ovrn) | TRANS-<br>MITTER<br>UNDERFLOW<br>(TUF) | CLEAR-TO-<br>SEND<br>(CTS) | DATA<br>CARRIER<br>DETECT<br>(DCD) | TRANS-<br>MITTER<br>DATA<br>REGISTER<br>AVAILABLE<br>(TORA) | RECEIVER<br>DATA<br>AVAILABLE<br>(RDA) | | CONTROL 1<br>(C1) | 0 | a | x | х | ADDRESS<br>CONTROL 2<br>(AC2) | ADDRESS<br>CONTROL 1<br>(AC1) | RECEIVER<br>INTERRUPT<br>ENABLE<br>(RIE) | TRANS-<br>MITTER<br>INTERRUPT<br>ENABLE<br>(TIE) | CLEAR<br>SYNC | STRIP SYNC<br>CHARACTERS<br>(STRIP SYNC) | TRANS-<br>MITTER<br>RESET<br>(Tx Hs) | RECEIVER<br>RESET<br>(Fix Rs) | | RECEIVE<br>DATA FIFO | 1 | 1 | х | Х | 07 | 06 | 05 | D4 | D3 | D2 | D1 | 00 | | CONTROL 2<br>(C2) | 1 | 0 | a | 0 | ERROR<br>INTERRUPT<br>Enable<br>(EIE) | TRANSMIT<br>SYNC CODE<br>ON<br>UNDERFLOW<br>(Tx Sync) | WORD<br>LENGTH<br>SELECT 3<br>(WS3) | WORD<br>LENGTH<br>SELECT Z<br>(WS2) | WORD<br>LENGTH<br>SELECT 1<br>(WS1) | 1-BYTE/<br>2-BYTE<br>TRANSFER<br>(1-BYTE/<br>2-BYTE) | PERIPHERAL<br>CONTROL 2<br>(PC2) | PERIPHERAL<br>CONTROL 1<br>(PC1) | | CONTROL 3<br>(C3) | 1 | 0 | 0 | 1 | NOT USED | NOT USED | NOT USED | NOTUSED | CLEAR<br>THANS-<br>MITTER<br>UNDERFLOW<br>STATUS<br>(CTUF) | CLEAR CTS<br>STATUS<br>(CLEAR CTS) | ONE-SYNC-<br>CHARACTER/<br>TWO-SYNC-<br>CHARACTER<br>MODE<br>CONTROL<br>(1 Sync/<br>2 Sync) | EXTERNAL/<br>INTERNAL<br>SYNC MODE<br>CONTROL<br>{E/I Sync} | | SYNC CODE | 1 | 0 | 1 | 0 | 07 | D6 | <b>05</b> | 04 | П3 | D2 | D1 | 00 | | TRANSMIT<br>DATA FIFO | 1 | 0 | 1 | 1 | D <b>7</b> | □6 | D5 | D4 | D3 | D2 | D1 | DO | X = DON'T CARE | Status Register<br>IRQ Bit 7 | The IRQ flag is cleared when the source | RIE | Bit 5 | When "1", enables interrupt on RDA (S Bit 0). | | |------------------------------|------------------------------------------------------------------------------------|------------------|----------|-------------------------------------------------------------------------|--| | 2104, 230 | of the IRQ is cleared. The source is de-<br>termined by the enables in the Control | TIE | Bit 4 | When "1", enables interrupt on TDRA (S Bit 1). | | | | Registers: TIE, RIE, EIE. | Clear Sync | Bit 3 | When "1", clears receiver char- | | | Bits 6-0 | indicate the SSDA status at a point in | | | acter synchronization. | | | D. | time, and can be reset as follows: | Strip Sync | Bit 2 | When "1", strips all sync codes from the received data stream. | | | ₽Æ | Bit 6 Read Rx Data FIFO, or a "1" into Rx Rs (C1 Bit 0). | <i>a</i> . D | TO CO. A | | | | Rx Ovrn | Bit 5 Read Status and then Rx Data | Tx Rs | Bit I | When "1", resets and inhibits the transmitter section. | | | 10 07.11 | FIFO, or a "1" into Rx Rs (C1<br>Bit 0). | Rx Rs | Bit 0 | When "1", resets and inhibits the receiver section. | | | TUF | Bit 4 A "1" into CTUF (C3 Bit 3) or into Tx Rs (C1 Bit 1). | Control Register | 3 | | | | стs | Bit 3 A "1" into Clear CTS (C3 Bit 2)<br>or a "1" into Tx Rs (C1 Bit 1) | CTUF | Bit 3 | When "1", clears TUF (S Bit 4), and IRQ if enabled. | | | $\overline{ extbf{DCD}}$ | Bit 2 Read Status and then Rx Data<br>FIFO or a "1" into Rx Rs (C1 | Clear CTS | Bit 2 | When "1", clears $\overline{\text{CTS}}$ (S Bit 3), and IRQ if enabled. | | | | Bit 0) | 1 Sync/2 Sync | Bit 1 | When "1", selects the one-sync- | | | TDRA | Bit 1 Write into Tx Data FIFO. | | | character mode; when "0", se- | | | RDA | Bit 0 Read Rx Data FIFO. | | | lects the two-sync-character mode. | | | Control Register | 1 | E/I Sync | Bit 0 | When "1", selects the external | | | AC2, AC1 | Bits 7, 6 Used to access other registers, as shown above. | · • | | sync mode; when "0", selects the internal sync mode. | | #### Control Register 2 EIE Bit 7 When "1", enables the PE, Rx Ovm, TUF, CTS, and DCD interrupt flags (S Bits 6 through 2). Bit 6 When "1", allows sync code Tx Sync contents to be transferred on underflow, and enables the TUF Status bit and output. When "0", > an all mark character is transmitted on underflow. WS3, 2, 1 Bits 5-3 Word Length Select | BIT 5<br>WS3 | BIT 4<br>WS2 | BIT 3<br>WS1 | WORD LENGTH | | | | | |--------------|--------------|--------------|----------------------|--|--|--|--| | 0 | 0 | 0 | 6 BITS + EVEN PARITY | | | | | | 0 | 0 | 1 | 6 BITS + ODD PARITY | | | | | | 0 | 1 | 0 | 7 BITS | | | | | | 0 | 1 | 1 | 8 BITS | | | | | | 1 | 0 | 0 | 7 BITS + EVEN PARITY | | | | | | 1 | 0 | 1 | 7 BITS + ODD PARITY | | | | | | 1 | 1 | 0 | 8 BITS + EVEN PARITY | | | | | | 1 | 1 | 1 | 8 BITS + ODD PARITY | | | | | parity should not be selected. Interrupt Request (IRQ) - Interrupt Request is a TTL compatible, open-drain (no internal pullup), active low output that is used to interrupt the MPU. The Interrupt Request remains low until cleared by the MPU. Reset Input - The Reset input provides a means of resetting the SSDA from an external source. In the low state, the Reset input causes the following: - 1. Receiver Reset (Rx Rs) and Transmitter Reset (Tx. Rs) bits are set causing both the receiver and transmitter sections to be held in a reset condition. - 2. Peripheral Control bits PC1 and PC2 are reset to zero, causing the SM/DTR output to be high. - 3. The Error Interrupt Enable (EIE) bit is reset. - 4. An internal synchronization mode is selected. - 5. The Transmitter Data Register Available (TDRA) status bit is cleared and inhibited. When Reset returns high (the inactive state), the transmitter and receiver sections will remain in the reset state until the Receiver Reset and Transmitter Reset bits are cleared via the bus under software control. The control Register bits affected by Reset (Rx Rs, Tx Rs, PC1, PC2, EIE, and E/I Sync) cannot be changed when Reset is low. 1-Byte/ 2-Byte Bit 2 When "1", enables the TDRA and RDA bits to indicate when a 1-byte transfer can occur: when "0", the TDRA and RDA bits indicate when a 2-byte transfer can occur. PC2, PC1 Bits 1-0 SM/DTR Output Control | BIT 1<br>PC2 | BIT 0<br>PC1 | SM/OTR OUTPUT AT PIN 5 | | | | | | |--------------|--------------|----------------------------|--|--|--|--|--| | 0 | 0 | 1<br>PULSE1-BIT WIDE ON SM | | | | | | | 1 | 0<br>1 | O<br>SM INHIBITED, O | | | | | | Note: When the SSDA is used in applications requiring the MSB of data to be received and transmitted first, the data bus inputs to the SSDA may be reversed (D0 to D7, etc.) Caution must be used when this is done since the bit positions in this table will be reversed, and the #### Clock Inputs Separate high impedance TTL compatible inputs are provided for clocking of transmitted and received data. Transmit Clock (Tx Clk) — The Transmit Clock input is used for the clocking of transmitted data. The transmitter shifts data on the negative transition of the clock Receive Clock (Rx Clk) — The Receive Clock input is used for clocking in received data. 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 (Rx Data) - The Receive Data line is a high impedance TTL compatible input through which data is received in a serial format. Data rates are from 0 to 600 kbps. Transmit Data (Tx Data) — The Transmit Data output line transfers serial data to a modem or other peripheral. Data rates are from 0 to 600 kbps. #### Peripheral/Modem Control The SSDA includes several functions that permit limited control of a peripheral or modem. The functions included are Clear-to-Send, Sync Match/Data Terminal Ready, Data Carrier Detect, and Transmitter Underflow. Clear-to-Send (CTS) — The CTS input provides a realtime inhibit to the transmitter section (the Tx Data FIFO is not disturbed). A positive CTS transition resets the Tx Shift Register and inhibits the TDRA status bit and its associated interrupt in both the one-synccharacter and two-sync-character modes of operation. TDRA is not affected by the CTS input in the external sync mode. The positive transition of $\overline{CTS}$ is stored within the SSDA to insure that its occurrence will be acknowledged by the system. The stored $\overline{CTS}$ information and its associated $\overline{RQ}$ (if enabled) are cleared by writing a "1" in the Clear $\overline{CTS}$ bit in Control Register 3 or in the Transmitter Reset bit. The $\overline{CTS}$ status bit subsequently follows the $\overline{CTS}$ input when it goes low. The CTS input provides character timing for transmitter data when in the external sync mode. Transmission is initiated on the negative transition of the first full positive clock pulse of the transmitter clock (Tx Clk) after the release of CTS (see Figure 6). Data Carrier Detect ( $\overline{DCD}$ ) — The $\overline{DCD}$ input provides a real-time inhibit to the receiver section (the Rx FIFO is not disturbed). A positive $\overline{DCD}$ transition resets and inhibits the receiver section except for the Receiver FIFO and the RDRA status bit and its associated $\overline{IRQ}$ . The positive transition of $\overline{DCD}$ is stored within the SSDA to insure that its occurrence will be acknowledged by the system. The stored $\overline{DCD}$ information and its associated $\overline{IRQ}$ (if enabled) are cleared by reading the Status Register and then the Receiver FIFO, or by writing a "I" into the Receiver Reset bit. The $\overline{DCD}$ status bit subsequently follows the $\overline{DCD}$ input when it goes low. The $\overline{DCD}$ input provides character synchronization timing for the receiver during the external sync mode of operation. The receiver will be initialized and data will be sampled on the positive transition of the first full Receive Clock cycle after release of $\overline{DCD}$ (see Figure 7). Sync Match/Data Terminal Ready (SM/DTR) — The SM/DTR output provides four functions (see Table 1) depending on the state of the PC1 and PC2 control bits. When the Sync Match mode is selected (PC1 = "1", PC2 = "0"), the output provides a one-bit-wide pulse when a sync code is detected. The SM output is inhibited when PC2 = "1". The DTR mode (PC1 = "0") provides an output level corresponding to the complement of PC2 (DTR = "0" when PC2 = "1"). (See Table 1.) Transmitter Underflow (TUF) — The Underflow output indicates the occurrence of a transfer of a "fill character" to the Transmitter Shift Register when the last location (#3) in the Transmit Data FIFO is empty. The Underflow output pulse is approximately a Tx Clk high period wide and occurs during the last half of the last bit of the character preceding the "Underflow" (see Figure 4). The Underflow output does not respond to underflow conditions when the Tx Sync bit is in the reset state. #### SSDA Registers Seven registers in the SSDA can be accessed by means of the bus. The registers are defined as read-only or write-only according to the direction of information flow. The Register Select input (RS) selects two registers in each state, one being read-only and the other write-only. The Read/Write input (R/W) defines which of the two selected registers will actually be accessed. Four registers (two read-only and two write-only) can be addressed via the bus at any particular time. These registers and the required addressing are defined in Table 1. #### Control Register 1 (C1) Control Register 1 is an 8-bit write-only register that can be directly addressed from the data bus. Control Register 1 is addressed when RS = "0" and R/W = "0". Receiver Reset (Rx Rs), C1 Bit 0 — The Receiver Reset control bit provides both a reset and inhibit function to the receiver section. When Rx Rs is set, it clears the receiver control logic, sync logic, error logic, Rx Data FIFO, Parity Error status bit, and DCD interrupt. The Receiver Shift Register is set to ones. The Rx Rs bit must be cleared after the occurrence of a low level on Reset in order to enable the receiver section of the SSDA. Transmitter Reset (Tx Rs), C1 Bit 1—The Transmitter Reset control bit provides both a reset and inhibit to the transmitter section. When Tx Rs is set, it clears the transmitter control section, Transmitter Shift Register, Tx Data FIFO (which can be reloaded after one E clock pulse), the Transmitter Underflow status bit, and the CTS interrupt, and inhibits the TDRA status bit (in the one-sync-character and two-sync-character modes). The Tx Rs bit must be cleared after the occurrence of a low level on Reset in order to enable the transmitter section of the SSDA. Strip Synchronization Characters (Strip Sync), C1 Bit 2 — If the Strip Sync bit is set, the SSDA will automatically strip all received characters which match the contents of the Sync Code Register. The characters used for synchronization (one or two characters of sync) are always stripped from the received data stream. Clear Synchronization (Clear Sync), C1 Bit 3 - The Clear Sync control bit provides the capability of dropping receiver character synchronization and inhibiting resynchronization. The Clear Sync bit is set to clear and inhibit receiver synchronization in all modes and is reset to zero to enable resynchronization. Transmitter Interrupt Enable (TIE), C1 Bit 4 - TIEenables both the Interrupt Request output (IRQ) and Interrupt Request status bit to indicate a transmitter service request. When TIE is set and the TDRA status bit is high, the IRQ output will go low (the active state) and the IRQ status bit will go high. Receiver Interrupt Enable (RIE), C1 Bit 5 — RIE enables both the Interrupt Request output (IRQ) and the Interrupt Request status bit to indicate a receiver service request. When RIE is set and the RDA status bit is high, the IRQ output will go low (the active state) and the IRQ status bit will go high. Address Control 1 (AC1) and Address Control 2 (AC2), C1 Bits 6 and 7 - AC1 and AC2 select one of the write-only registers — Control 2, Control 3, Sync Code, or Tx Data FIFO — as shown in Table 1, when RS = "1" and R/W = "0". #### Control Register 2 (C2) Control Register 2 is an 8-bit write-only register which can be programmed from the bus when the Address Control bits in Control Register 1 (AC1 and AC2) are reset, RS = "1" and R/W = "0". Peripheral Control 1 (PC1) and Peripheral Control 2 (PC2), C2 Bits 0 and 1 -Two control bits, PC1 and PC2, determine the operating characteristics of the Sync Match/DTR output. PC1, when high, selects the Sync Match mode. PC2 provides the inhibit/enable control for the SM/DTR output in the Sync Match mode. A one-bit-wide pulse is generated at the output when PC2 is "0", and a match occurs between the contents of the Sync Code Register and the incoming data even if sync is inhibited (Clear Sync bit = "1"), The Sync Match pulse is referenced to the negative edge of Rx Clk pulse causing the match (see Figure 3). The Data Terminal Ready (DTR) mode is selected when PC1 is low. When PC2 = "1" the SM/ $\overline{DTR}$ output = "0" and vice versa. The operation of PC2 and PC1 is summarized in Table 1. 1-Byte/2-Byte Transfer (1-Byte/2-Byte), C2 Bit 2 -When 1-Byte/2-Byte is set, the TDRA and RDA status bits will indicate the availability of their respective data FIFO registers for a single byte data transfer. Alternately, if 1-Byte/2-Byte is reset, the TDRA and RDA status bits indicate when two bytes of data can be moved without a second status read. An intervening Enable pulse must occur between data transfers. Word Length Selects (WS1, WS2, WS3), C2 Bits 3, 4, 5 Word Length Select bits WS1, WS2, and WS3 select word length of 7, 8, or 9 bits including parity as shown in Table 1. Transmit Sync Code on Underflow (Tx Sync), C2 Bit 6 - When Tx Sync is set, the transmitter will automatically send a sync character when data is not available for transmission. If Tx Sync is reset, the transmitter will transmit a Mark character (including the parity bit position) on underflow. When the underflow is detected, a pulse approximately a Tx Clk high period wide will occur on the underflow output if the Tx Sync bit is set. Internal parity generation is inhibited during underflow except for sync code fill character transmission in 8-bit plus parity word lengths. Error Interrupt Enable (EIE), C2 Bit 7 - When EIE is set, the IRQ status bit will go high and the $\overline{IRQ}$ output will go low if: - 1. A receiver overrun occurs. The interrupt is cleared by reading the Status Register and reading the Rx Data FIFO. - 2. DCD input has gone to a "1". The interrupt is cleared by reading the Status Register and reading the Rx Data FIFO. - 3. A parity error exists for the character in the last location (#3) of the Rx Data FIFO. The interrupt is cleared by reading the Rx Data FIFO. - 4. The CTS input has gone to a "1". The interrupt is cleared by writing a "1" in the Clear CTS bit, C3 bit 2, or by a TX Reset. - 5. The transmitter has underflowed (in the Tx Sync on Underflow mode). The interrupt is cleared by writing a "1" into the Clear Underflow, C3 bit 3, or Tx Reset. When EIE is a "0", the IRQ status bit and the $\overline{IRQ}$ output are disabled for the above error conditions. A low level on the Reset input resets EIE to "0". #### Control Register 3 (C3) Control Register 3 is a 4-bit write-only register which can be programmed from the bus when RS = "1" and R/W = "0" and Address Control bit AC1 = "1" and AC2 = "0". External/Internal Sync Mode Control (E/I Sync), C3 Bit 0 — When the E/I Sync Mode bit is high, the SSDA is in the external sync mode and the receiver synchronization logic is disabled. Synchronization can be achieved by means of the $\overline{DCD}$ input or by starting Rx Clk at the midpoint of data bit 0 of a character with $\overline{DCD}$ low. Both the transmitter and receiver sections operate as parallel — serial converters in the External Sync mode. The Clear Sync bit in Control Register 1 acts as a receiver sync inhibit when high to provide a bus controllable inhibit. The Sync Code Register can serve as a transmitter fill character register and a receiver match register in this mode. A "low" on the Reset input resets the E/I Sync Mode bit placing the SSDA in the internal sync mode. One-Sync-Character/Two-Sync-Character Mode Control (1 Sync/2 Sync), C3 Bit 1 — When the 1 Sync/2 Sync bit is set, the SSDA will synchronize on a single match between the received data and the contents of the Sync Code Register. When the 1 Sync/2 Sync bit is reset, two successive sync characters must be received prior to receiver synchronization. If the second sync character is not detected, the bit by bit search resumes from the first bit in the second character. See the description of the Sync Code Register for more details. Clear CTS Status (Clear CTS), C3 Bit 2 — When a "1" is written into the Clear CTS bit, the stored status and interrupt are cleared. Subsequently, the CTS status bit reflects the state of the CTS input. The Clear CTS control bit does not affect the CTS input nor its inhibit of the transmitter section. The Clear CTS command bit is self-clearing, and writing a "0" into this bit is a nonfunctional operation. Clear Transmit Underflow Status (CTUF), C3 Bit 3 — When a "1" is written into the CTUF status bit, the CTUF bit and its associated interrupt are reset. The CTUF command bit is self-clearing and writing a "0" into this bit is a nonfunctional operation. #### Sync Code Register The Sync Code Register is an 8-bit register for storing the programmable sync code required for received data character synchronization in the one-sync-character and two-sync-character modes. The Sync Code Register also provides for stripping the sync/fill characters from the received data (a programmable option) as well as automatic insertion of fill characters in the transmitted data stream. The Sync Code Register is not utilized for receiver character synchronization in the external sync mode; however, it provides storage of receiver match and transmit fill characters. The Sync Code Register can be loaded when AC2 and AC1 are a "1" and "0", respectively, and R/W = "0" and RS = "1". The Sync Code Register may be changed after the detection of a match with the received data (the first sync code having been detected) to synchronize with a double-word sync pattern. (This sync code change must occur prior to the completion of the second character.) The sync match (SM) output can be used to interrupt the MPU system to indicate that the first eight bits have matched. The service routine would then change the sync match register to the second half of the pattern. Alternately, the one-sync-character mode can be used for sync codes for 16 or more bits by using software to check the second and subsequent bytes after reading them from the FIFO. The detection of the sync code can be programmed to appear on the Sync Match/DTR output by writing a "1" in PC1 (C2 bit 0) and a "0" in PC2 (C2 bit 1). The Sync Match output will go high for one bit time beginning at the character interface between the sync code and the next character (see Figure 3). # Receive Data First-In First-Out Register (Rx Data FIFO) The Receive Data FIFO Register consists of three 8-bit registers which are used for buffer storage of received data. Each 8-bit register has an internal status bit which monitors its full or empty condition. Data is always transferred from a full register to an adjacent empty register. The transfer from register to register occurs on E pulses. The RDA status bit will be high when data is available in the last location of the Rx Data FIFO. In an Overrun condition, the overrunning character will be transferred into the full first stage of the FIFO register and will cause the loss of that data character. Successive overruns continue to overwrite the first register of the FIFO. This destruction of data is indicated by means of the Overrun status bit. The Overrun bit will be set when the overrun occurs and remains set until the Status Register is read, followed by a read of the Rx Data FIFO. Unused data bits for short word lengths (including the parity bit) will appear as "0"s on the data bus when the Rx Data FIFO is read. # Transmit Data First-In First-Out Register (Tx Data FIFO) The Transmit Data FIFO Register consists of three 8-bit registers which are used for buffer storage of data to be transmitted. Each 8-bit register has an internal status bit which monitors its full or empty condition. Data is always transferred from a full register to an adjacent empty register. The transfer is clocked by E pulses. The TDRA status bit will be high if the Tx Data FIFO is available for data. Unused data bits for short word lengths will be handled as "don't cares". The parity bit is not transferred over the data bus since the SSDA generates parity at transmission. When an Underflow occurs, the Underflow character will be either the contents of the Sync Code Register or an all "1"s character. The underflow will be stored in the Status Register until cleared and will appear on the Underflow output as a pulse approximately a Tx Clk high period wide. #### Status Register The Status Register is an 8-bit read-only register which provides the real-time status of the SSDA and the associated serial data channel. Reading the Status Register is a non-destructive process. The method of clearing status bits depends upon the function each bit represents and is discussed for each bit in the register. Receiver Data Available (RDA), S Bit 0 — The Receiver Data Available status bit indicates when receiver data can be read from the Rx Data FIFO. The receiver data being present in the last register (#3) 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 (#2 and #3) are full when in the 2-byte transfer mode. The second character can be read without a second status read (to determine that the character is available). An E pulse must occur between reads of the Rx Data FIFO to allow the FIFO to shift. Status must be read on a word-by-word basis if receiver data error checking is important. The RDA status bit is reset automatically when data is not available. Transmitter Data Register Available (TDRA), S Bit 1—The TDRA status bit indicates that data can be loaded into the Tx Data FIFO Register. The first register (#1) of the Tx Data FIFO being empty will be indicated by a high level in the TDRA status bit in the 1-byte transfer mode. The first two registers (#1 and #2) must be empty for TDRA to be high when in the 2-byte transfer mode. The Tx Data FIFO can be loaded with two bytes without an intervening status read; however, one E pulse must occur between loads. TDRA is inhibited by the Tx Reset or Reset. When Tx Reset is set, the Tx Data FIFO is cleared and then released on the next E clock pulse. The Tx Data FIFO can then be loaded with up to three characters of data, even though TDRA is inhibited. This feature allows preloading data prior to the release of Tx Reset. A high level on the CTS input inhibits the TDRA status bit in either sync mode of operation (one-synccharacter or two-sync-character). CTS does not affect TDRA in the external sync mode. This enables the SSDA to operate under the control of the CTS input with TDRA indicating the status of the Tx Data FIFO. The CTS input does not clear the Tx Data FIFO in any operating mode. Data Carrier Detect ( $\overline{DCD}$ ), S Bit 2 — A positive transition on the $\overline{DCD}$ input is stored in the SSDA until cleared by reading both Status and Rx Data FIFO. A "1" written into Rx Rs also clears the stored $\overline{DCD}$ status. The $\overline{DCD}$ status bit, when set, indicates that the $\overline{DCD}$ input has gone high. The reading of both Status and Receive Data FIFO allows Bit 2 of subsequent Status reads to indicate the state of the $\overline{DCD}$ input until the next positive transition. Clear-to-Send (CTS), S Bit 3 — A positive transition on the CTS input is stored in the SSDA until cleared by writing a "1" into the Clear CTS control bit or the Tx Rs bit. The CTS status bit, when set, indicates that the CTS input has gone high. The Clear CTS command (a "1" into C3 Bit 2) allows Bit 3 of subsequent Status reads to indicate the state of the CTS input until the next positive transition. Transmitter Underflow (TUF), S Bit 4 — When data is not available for the transmitter, an underflow occurs and is so indicated in the Status Register (in the Tx Sync on underflow mode). The underflow status bit is cleared by writing a "1" into the Clear Underflow (CTUF) control bit or the Tx Rs bit. TUF indicates that a sync character will be transmitted as the next character. A TUF is indicated on the output only when the contents of the Sync Code Register is to be transferred (transmit sync code on underflow = "1"). Receiver Overrun (Rx Ovrn), S Bit 5 — Overrun indicates data has been received when the Rx Data FIFO is full, resulting in data loss. The Rx Ovrn status bit is set when Overrun occurs. The Rx Ovrn status bit is cleared by reading Status followed by reading the Rx Data FIFO or by setting the Rx Rs control bit. Receiver Parity Error (PE), S Bit 6—The parity error status bit indicates that parity for the character in the last register of the Rx Data FIFO did not agree with selected parity. The parity error is cleared when the character to which it pertains is read from the Rx Data FIFO or when Rx Rs occurs. The DCD input does not clear the Parity Error or Rx Data FIFO status bits. Interrupt Request (IRQ), S Bit 7 — The Interrupt Request status bit indicates when the $\overline{IRQ}$ output is in the active state ( $\overline{IRQ}$ output = "0"). The IRQ status bit is subject to the same interrupt enables (RIE, TIE, and EIE) as the $\overline{IRQ}$ output. The IRQ status bit simplifies status inquiries for polling systems by providing single bit indication of service requests. # ADVANCED DATA LINK CONTROLLER #### **Features** - □ S6800 Compatible - ☐ Protocol Features - ☐ Automatic Flag Detection and Synchronization - ☐ Zero Insertion and Deletion - □ Extendable Address, Control and Logical Control Fields (Optional) - □ Variable Word Length Info Field 5, 6, 7, or 8-bits - ☐ Automatic Frame Check Sequence Generation and Check - ☐ Abort Detection and Transmission - ☐ 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 - ☐ MIL-STD-883, Class B and C Devices Available #### General Description The S6854 ADLC performs the complex MPU/data communication link function for the "Advanced Data Communication Control Procedure" (ADCCP). High Level Data Link Control (HDLC) and Synchronous Data Link Control (SDLC) standards. The ADLC 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. #### Absolute Maximum Ratings\* | Supply Voltage | | |------------------------------|-------------------------------------| | Input Voltage | 0.3V to +7.0V | | Operating Temperature Range | | | Industrial Temperature Range | | | Military Temperature Range | $-55^{\circ}$ C to $+125^{\circ}$ C | | Storage Temperature Range | 55°C to +150°C | | Thermal Resistance | | <sup>\*</sup>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. # Electrical Characteristics ( $V_{CC}$ = 5.0V ± 5%, $V_{SS}$ = 0, $T_A$ = 0°C to 70°C unless otherwise noted.) | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | | |----------------------------|----------------------------------------------------|-----------------------|------|----------------------|------|--------------------------------------------------------------|--| | $\overline{v_{\text{IH}}}$ | Input High Voltage | V <sub>SS</sub> + 2.0 | | | Vdc | | | | $v_{\text{IL}}$ | Input Low Voltage | | | V <sub>SS</sub> +0.8 | Vdc | | | | I <sub>IN</sub> | Input Leakage Current<br>All Inputs Except D0 — D7 | | 1.0 | 2.5 | μAdc | V <sub>IN</sub> = 0 to 5.25Vdc | | | I <sub>TSI</sub> | Three-State (Off State) Input Current D0 - D7 | | 2.0 | 10 | μAde | V <sub>IN</sub> = 0.4 to 2.4Vdc<br>V <sub>CC</sub> = 5.25Vdc | | | V <sub>OII</sub> | Output High Voltage<br>D0 — D7 | V <sub>SS</sub> +2.4 | | | Vdc | I <sub>LOAD</sub> = - 205μAde | | | | All Others | V <sub>SS</sub> +2.4 | | | | $I_{LOAD} = -100 \mu Ade$ | | | $\overline{v_{ m ol}}$ | Output Low Voltage | | | V <sub>SS</sub> +0.4 | Vdc | I <sub>LOAD</sub> =1.6mAdc | | | I <sub>LOII</sub> | Output Leakage Current (Off State) | | 1.0 | 10 | μAde | V <sub>OH</sub> = 2.4 Vde | | | P <sub>D</sub> | Power Dissipation | | | 850 | mW | | | | CIN | Capacitance | | | | рF | $V_{IN} = 0$ , $T_A = 25^{\circ} C$ , | | | | D0 — D7<br>All Other Inputs | | | 12.5<br>7.5 | | f = 1.0MHz | | | C <sub>OUT</sub> | ĪRQ<br>All Others | | | 5.0<br>10 | pF | | | | | | S6 | 854 | S63 | BA54 | | | |--------------|--------------------------------------------|------|----------|------|------|------|--------------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Unit | Conditions | | $PW_{CL}$ | Minimum Clock Pulse Width, Low | 700 | | 450 | | ns | | | $PW_{CH}$ | Minimum Clock Pulse Width, High | 700 | <u> </u> | 450 | | ns | 1 | | fC | Clock Frequency | | 0.66 | | 1.0 | MHz | 1 | | tRDSU | Receive Data Setup Time | 250 | | 200 | | ns | 1 | | tRDH | Receive Data Hold Time | 120 | | 100 | | ns | 1 | | tRTS | Request-to-Send Delay Time | | 680 | | 460 | ns | 1 | | tTDD | Clock-to-Data Delay for Transmitter | | 460 | | 320 | ns | 1 | | tFD | Flag Detect Delay Time | j | 680 | · · | 460 | ns | 7 | | tmr | DTR Delay Time | | 680 | | 460 | ns | 1 | | tLOC | Loop On Line Control Delay Time | . 1- | 680 | 1 | 460 | ns | | | t RDSR | RDSR Delay Time | | 540 | _ | 400 | ns | 1 | | tTDSR | TDSR Delay Time | 1 | 540 | | 400 | ns | 1 | | t <b>I</b> R | Interrupt Request Release Time | 1 | 1.2 | | 0.9 | μs | 1 | | tRES | Reset Minimum Pulse Width | 1,0 | T | 0,65 | | μs | 1 | | tr, tf | Input Rise and Fall Times<br>Except Enable | | 1.0* | | 1,0* | μs | 0.8V to 2.0V | <sup>\*1.0</sup> $\mu$ s or 10% of the pulse width, whichever is smaller. ## Bus Timing Characteristics ( $V_{CC}$ = 5.0 V ± 5%, $V_{SS}$ = 0, $T_A$ = 0° C to +70° C unless otherwise noted.) | | | S6 | 854 | S68 | A54 | | | |-----------------------------------|-----------------------------------------------------------------|------|------|-------|------|------|--| | Symbol | Parameter | Min, | Max. | Min. | Max. | Unit | | | tcyc | Enable Cycle Time | 1.0 | | 0.666 | | μs | | | PWEH | Enable Pulse Width, High | 0.45 | _ | 0.28 | | μs | | | PWEL | Enable Pulse Width, Low | 0.43 | | 0.28 | | μs | | | tAS | Setup Time, Address and R/W Valid to Enable positive transition | 160 | | 140 | | ns | | | t <sub>DDR</sub> | Data Delay Time | | 320 | | 220 | ns | | | $t_{\rm H}$ | Data Hold Time | 10 | · | 10 | [ | ns | | | $\iota_{\mathrm{AH}}$ | Address Hold Time | 10 | | 10 | | ns | | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable input | | 25 | | 25 | ns | | #### Write | $\iota_{\mathrm{CYCE}}$ | Enable Cycle Time | 1.0 | | 0.666 | | μs | |-----------------------------------|-----------------------------------------------------------------|------|----|-------|----|-----------| | PWEH | Enable Pulse Width, High | 0.45 | | 0.28 | | jis | | $^-$ PW $_{ m EL}$ | Enable Pulse Width, Low | 0.43 | | 0.28 | | $\mu_{s}$ | | t <sub>AS</sub> | Setup Time, Address and R/W Valid to Enable positive transition | 160 | | 140 | | ns | | $t_{DSW}$ | Data Setup Time | 195 | | 80 | | ns | | tн | Data Hold Time | 10 | | 10 | | ns | | t <sub>AH</sub> | Address Hold Time | 10 | | 10 | | ns | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for Enable input | | 25 | | 25 | ns | Figure 2. Receiver Data Setup/Hold, Flag Detect and Loop On-Line Control Delay 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 flag (F). Between the opening flag and closing flag, a frame contains an address field, control field, information field, and frame check sequence field. 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 D0 (data bus bit 0, pin 22) is serially transmitted first, and the first serially received bit is transferred to the MPU on D0. The FCS field is transmitted and receives 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 (I) Field — The I-field follows the C-field and precedes the FCS field. The I-field contains "data" to be transferred but is not always necessarily contained in every frame. The word length of the Ifield can be selected from 5 to 8 bits per byte by control bits in control register #4. The I-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 I-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 length, 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 (LC) Field — When the Logical control Field Select bit in control register #3 is selected, the ADLC separates the 1-field into two subfields. The first sub-field is the Logical Control field and the following sub-field is the "data" portion of the I-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 poly-nomial $x^{16} + x^{12} + x^5 + 1$ is used both for the transmitter and receiver. Both the transmitter and receiver poly-nominal 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 (if selected), information, and received FCS fields and compares the result to F0B8 (Hexadecimal). When the result matches F0B8, 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: - 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 Afield 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. - 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 5 1's within a frame (A, C, LC, I, and FCS field). The receiver deletes a binary 0 that follows successive 5 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 8 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 7 or more consecutive 1's is interpreted as an abort by the receiver. The receiver responds to a received abort as follows: - 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 is suppressed after 15 or more consecutive 1's are received (Received Idle 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 Idle 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 RESET input has gone high. At any time during operation, writing a "1" into the Rx RS control bit or TX RS control causes the reset condition of the receiver or the transmitter. Transmitter Operation—The Tx F1FO 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 idle) or the Flag "time fill" (active idle) state. This active or inactive mark idle state will continue until data is loaded into the Tx F1FO. 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 F1FO 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. A frame continues as long as data is written into the Tx FIFO at the "Frame Continue" address. The ADLC internally keeps 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 efficient way to terminate the frames from a software standpoint is to write the last data character into the Transmit FIFO "Frame Terminate" address (RS1, RS0 = 11) rather than the Transmit FIFO "Frame Continue" address (RS1, RS0 = 10). An alternate method is to follow the last write of data in the Tx FIFO "Frame Continue" address with the setting of 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 (at 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 RTS (Request-To-Send) 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 (RxC) 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, #### Operation (Continued) 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 (RxD) during time fill can cause this kind of invalid frame. Once synchronization has been achieved and the internal buffer time (24 bit times) expires data will automatically transfer to 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 (Reg. #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 (Reg. #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 two 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 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 8a, 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 loop), goes active on the loop (starts transmitting its own stations' 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 closing 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 7 "1's" followed by mark 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 non-loop, full duplex mode. The ADLC in the secondaries should operate in a loop mode, monitoring uploop 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. Table 1. Summary of Loop Mode Operation | STATE | RX SECTION | TX SECTION | LOOP<br>Status bit | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | OFF-LOOP | Rx section receives data from loop and searches for 7 "1's" (when On-Loop Control bit set) to go ON-LOOP. | Inactive 1) NRZ MODE Tx data output is maintained "high" (mark). 2) NRZI MODE Tx data output reflects the Rx data input state delayed by one bit time. (Not normally connected to loop.) The NRZI data is internally decoded to provide error-free transitions to On-Loop mode. | "ŋ·' | | 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. 2) When On-Loop control bit is reset, Rx section searches of 8 "1's" to go OFF-LOOP. | Inactive 1) NRZ MODE Tx data output reflects Rx data input state delayed one bit time. 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. Received flag causes FD output to go low. IRQ 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" | - (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 8b. After hardware reset, the ADLC LOC/DTR 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/ 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 ones are received by the ADLC the $\overline{LOC}/\overline{DTR}$ output will go to a low level, disabling gate A (refer to Figure 8b), 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 one 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 ones (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 Register 3). A minimum 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 repeated sequence out gate B in Figure 8h is now opening flag sequence (01111110). Transmission now continues from the Tx FIFO with data (address, control, etc.) as previously described. When the ADLC has gone active-on-poll, the Loop 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 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 one 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 will mark idle 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, (TxD = 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-line) similar to the way it went on-line. When the Loop On-Line control bit is reset the ADLC receiver section looks for 8 successive "1's" before allowing the $\overline{\text{LOC}}/\overline{\text{DTR}}$ output to return high (the inactive state). Gate A in Figure 8b 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). #### Input/Output Functions All inputs of ADLC are high impedance and TTL compatible level inputs. All outputs of the ADLC are compatible with standard TTL. Interrupt Request (IRQ), however, is an open drain output (no internal pull-up). #### Interface for MPU #### D0-D7 Bidirectional Data Bus — 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 activates the address inputs ( $\overline{\text{CS}}$ , RSO and RS1) and R/W input and enables the data transfer on the data bus. E also move data through the Tx FIFO and Rx FIFO. E should be a free running clock such as the S6800 MPU system clock. #### $\overline{\text{CS}}$ Chip Select — An ADLC read or write operation is enabled only when the $\overline{CS}$ input is low and the E clock input is high. (E • $\overline{CS}$ ). #### RSO #### RS1 Register Selects — When the Register Select inputs are enabled by $(E \cdot \overline{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. #### R/W Read/Write Control Line — The R/W input controls the direction of data flow on the data bus when it is enabled by (E · CS). When R/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 Reset Input — The 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, 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 $\overline{\text{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". #### $\overline{IRC}$ Interrupt Request Output — IRQ 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. #### Clock and Data of Transmitter and Receiver #### TxC Transmitter Clock Input — 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. #### RxC Receiver Clock Input — The receiver samples the data on the positive transition of the TxC clock. RxC should be synchronized with receive data externally. #### TxD Transmit Data Output — The serial data from the transmitter is coded in NRZ or NRZI (Zero Complement) data format. #### RxD Receiver Data Input — 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\times C}\leqslant \frac{1}{2t_E+300ns}$$ where $t_E$ is the period of E. #### Peripheral/Modem Control #### RTS Request to Send Output — 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 RTS bit goes high, the RTS output is forced low. When the RTS bit returns low, the RTS output remains low until the end of the frame. The positive transition of 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 RESET input is low, the RTS output goes high. CTS Clear to Send Input — The $\overline{\text{CTS}}$ input provides a real-time inhibit to the TDRA status bit and its associated interrupt. The positive transition of $\overline{\text{CTS}}$ is stored within the ADLC to insure its occurrence will be acknowledged by the system. The stored CTS information and its associated IRQ (if enabled) are cleared by writing a "1" in the Clear Tx Status bit or in the Transmitter Reset bit. #### $\overline{DCD}$ Data Carrier Detect Input — The DCD input provides a real-time inhibit to the receiver section. A high level on the DCD input resets and inhibits the receiver register, but data in the Rx FIFO from a previous frame is not disturbed. The positive transition of DCD is stored within the ADLC to insure that its occurrence will be acknowledged by the system. The stored DCD information and its associated IRQ (if enabled) are cleared by means of the Clear Rx Status Control bit or by the Rx Reset bit. #### LOC/DTR Loop On Line Control/Data Terminal Ready output The LOC/DTR output serves as a DTR output in the non-loop mode or as a Loop Control output in the loop mode. When $\overline{LOC}/\overline{DTR}$ output performs the DTR function, it is turned on and off by means of the LOC/DTR control bit. When the Loc/DTR control bit is high the $\overline{\mathrm{DTR}}$ output will be low. In the loop mode the LOC/DTR output provides the means of controlling the external loop interface hardware to go On-line or Off-line, When the LOC/DTR control bit is SET and the loop has "idled" for 7 bit times or more (RxD) = 011111111..., the $\overline{LOC}/\overline{DTR}$ output will go low (on-line). When the LOC/DTR control bit is low and the loop has "idled" for 8 bit times or more, the $\overline{\text{LOC}}/\overline{\text{DTR}}$ output will return high (off-line). The RESET input being low will cause the LOC/DTR output to be high. #### $\overline{ ext{FD}}$ Flag Detect Output — An output to indicate the reception of a flag and initiate an external time-out counter for the loop mode operation. The FD output goes low for one bit time beginning at the last bit of the flag character, as sampled by the receiver clock (RxC). #### DMA Interface #### RDSR Receiver Data Service Request Output — 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). 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. #### TDSR Transmitter Data Service Request Output — The TDSR Output is provided for DMA mode operation and indicates (when high) that the Tx FIFO requests service (TDSR reflects the TDRA status bit). TDSR goes low when the Tx FIFO is loaded. TDSR is inhibited by: The Tx Rs control bit being SET, $\overline{RESET}$ being low, or $\overline{CTS}$ being high. If the prioritized status mode is used, Tx underrun also inhibits TDSR. #### **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 transmitter 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 | Reyister Selected | R/W | RS1 | RSO | Address<br>Control Bit<br>(C1b0) | |---------------------------------------|-----|-----|-----|----------------------------------| | Write Control Register #1 | 0 | 0 | 0 | х | | Write Control Register #2 | 0 | 0 | 1 | 0 | | Write Control Register #3 | D | 0 | 1 | 1 | | Write Transmit FIFO (Frame Terminate) | 0 | 1 | 1 | 0 | | Write Control Register #4 | 0 | 1 | 1 | 1 | | Read Status Register #1 | 1 | 0 | 0 | х | | Read Status Register #2 | 1 | G | 1 | x | | Read Receiver FIFO | 1 | 1 | Х | Х | #### 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 no longer valid. Both the Rx Reset bit and Reset input clear the Rx FIFO. Abort ("In Frame") and a high level on the 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. RxRs control bit or Tx Abort control bit resets all pointers. The pointer will shift through the FIFO. When 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 written by 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 2BYTE/1BYTE 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. Table 3. ADLC Internal Register Structure | | | RS1 R\$0 = 00 | RS1 RS0 = 01 | R\$1 R\$0 = 10 | R\$1 R\$0 = 11 | |-----------|------|---------------------------------|-------------------------------|---------------------------|----------------| | | Bit# | Status Register #1 | Status Register #2 | Receiver Data<br>Register | - | | | 0 | RDA | Address Present | Bit 0 | | | Registers | 1 | Status #2<br>Read Request | Frame Valid | Bit 1 | | | 8 | 2 | Loop On Line | Inactive Idle Received | Bit 2 | | | ad Only | 3 | Flag Detected<br>(When Enabled) | Abort Received | Bit 3 | Not Used | | Read | 4 | CTS | FCS Error | Bit 4 | | | | 5 | Tx Underrun | DCD | Bit 5 | | | | 6 | TDRA/Frame<br>Complete | Tx Overrun | Bit 6 | | | | 7 | IRQ Present | RDA (Receiver Data Available) | Bit 7 | | | | | | | | Transmitter<br>Data | Transmitter<br>Data | <u> </u> | |----------------------|------|---------------------------------------|------------------------------------------------------------|-----------------------------------|---------------------|---------------------------|--------------------------------------------------| | | Bit# | Control Register #1 | Control Register #2<br>(C <sub>1</sub> b <sub>0</sub> = 0) | Control Register #3<br>(C1bg = 1) | (Continue Data) | (Last Data)<br>(C1b0 = 0) | Cantrol Register #4<br>C1b0 = 1) | | | 0 | Address Control (AC) | Prioritized Status<br>Enable | Logical Control Field<br>Select | Bit 0 | Bit 0 | Double Flag/Single<br>Flag Interframe<br>Control | | | 1 | Receiver Interrupt<br>Enable (RJE) | 2 Byte/1 Byte<br>Transfer | Extended Control<br>Field Select | Bit 1 | Bit 1 | Word Length Select | | isters | 2 | Transmitter Interrupt<br>Enable (TIE) | Flag/Mark Idle | Auto, Address<br>Extension Mode | Bit 2 | Bit 2 | Word Length Select<br>Transmit #2 | | Write Only Registers | 3 | ROSR Mode (DMA) | Frame Complete/<br>TDRA Select | 01/11 (dle | Bit 3 | Bit 3 | Word Length Select<br>Receive # 1 | | Write O | 4 | TDSR Mode (DMA) | Transmit Last Data | Flag Detected<br>Status Enable | Bit 4 | Bit 4 | Word Length Select<br>Receive # 2 | | | 5 | Rx Frame<br>Discontinue | CLR Rx Status | Loop/Non-Loop<br>Mode | Bit 5 | Bit 5 | Transmit Abort | | | 6 | Rx RESET | CLR Tx Status | Go Active on<br>Poll/Test | Bit 6 | Bit 6 | Abort Extend | | | 7 | TX RESET | RTS Control | Loop On-Line<br>Control DTR | Bit 7 | Bit 7 | NRZI/NRZ | #### Control Registers #### Control Register 1 (CR1) | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|----|------|------|-------------|------|------|-----|-----|----| | RS1 | RSO | R/W | AC | TxRS | RxRS | Discontinue | TDSR | RDSR | TIE | RIE | AC | | 0 | 0 | 0 | X | | L | | Mode | Mode | | | | - b0 Address Control (AC) AC provides another RS (Register Select) signal internally. The AC bit is used in conjunction with RSO, 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, and interrupt request caused by RDA status is inhibited, and the ADLC does not request data transfer via the IRQ 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, and interrupt request caused by TDRA status is inhibited, and the ADLC does not request a data transfer via the IRQ output. - b5 Rx Frame Discontinue (DISCONTINUE) When the DISCONTINUE bit is set, the currently re- - ceived frame is ignored and the ADLC discards the data of the current frame. 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 DCD input. Rx Rs is set by forcing a low level on the RESET input or by writing a "1" into this bit from the data bus. Rx Rs must be reset by writing a "0" from the data bus after RESET has gone high. - by 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 in both status registers, are reset (FIFO cannot be loaded). During reset, the stored CTS status is reset but the CTS status bit follows the CTS input. Tx Rs is set by forcing a low level on the RESET input or by writing a "1" from the data bus. It must be reset by writing a "0" after RESET has gone high. #### Control Register 2 (CR2) | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|----|-----|------|------|------|---------|------|------|-----| | RS1 | RS0 | R/W | AC | RTS | CLR | CLR | Tx | FC/TDRA | F/M | 2/1 | PSE | | 0 | 1 | 0 | 0 | | 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 suppresses 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 bits indicate when two bytes of data can be moved without a second status read. - b2 Flag/Mark Idle Select (F/M Idle) 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 (C3b3). 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. When the Tx Last bit is set just after loading a data byte, - 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 register # 1 and #2 (except 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 TxST) When a "1" is written into CLR TxST 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 TxST bit automatically returns to the "0" state. - b7 Request to Send Control (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. If the transmitter is idling when the RTS bit return low, the RTS output will go high (the inactive state) within two bit times. #### Control Register 3 (CR3) | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|----|------|------|------|------|-------|-----|-----|-----| | RS1 | RS0 | R/W | AC | LOC/ | GAP/ | Loop | FDSE | 01/11 | AEX | CEX | LCF | | 0 | 1 | 0 | 1 | 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 WLS1 and WLS2. - b1 Extended Control Field Select (C<sub>EX</sub>) When the C<sub>EX</sub> bit is a "1", the control field is extended and assumed to be 16 bits. When C<sub>EX</sub> is "0", the control field is assumed to be 8 bits. - b2 Auto/Address Extend Mode (A<sub>EX</sub>) The A<sub>EX</sub> bit when "low" allows full 8 bits of the address octet to be utilized for addressing because address extension is inhibited. When the A<sub>EX</sub> 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). - by 01/11 Idle (01/11 Idle) 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 one 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 to point 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 "loop-back" 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 "off-line" 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...DTR output goes to low level. 0...DTR output goes to high level. #### Control Register 4 (CR4) | | | | | 7 | 6 | 5 | 4 | 3 | 3 2 | | 0 | |-----|-----|-----|----|----------|---------------------|-----|------------------|---------|---------|---------|--------| | RSI | RSO | R/W | AC | NRZI/NRZ | $ABT_{\mathbf{EX}}$ | ABT | R | tx Tx | | 'x | "FF"/F | | 1 | 1 | 0 | 1 | | | | wls <sub>2</sub> | $wls_1$ | $wls_2$ | $wls_1$ | | - b) Double Flag/Single Flag Interframe Control ("FF" /"F") - The "FF"/"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. - b<sub>1</sub> Transmitter Word Length Select (Tx WLS1 and WLS2). - $b_2$ Tx WLS1 and WLS2 are used to select the word length of the transmitter information field. The encoding format is shown in Table 4. Table 4. I-Field Character Length Select | WLS <sub>1</sub> | WLS2 | f-Field Character Length Length | |------------------|------|---------------------------------| | 0 | 0 | 5 bits | | 1 | 0 | 6 bits | | 0 | 1 | 7 bits | | 1 | 1 | 8 bits | - b3 Receiver Word Length Select (Rx WLS1 and WLS2) b4 Rx WLS1 and WLS2 are used to select the word length of the receiver information field. The en - coding format is shown in Table 4. - 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. - be Abort Extend $(ABT_{EX}) = If ABT_{EX}$ is set, the abort code initiated by ABT or the underrun condition 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 Non-Loop 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, 0... NRZ. NOTE: NRZI 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 IRQ 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 S2RQ 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 9. 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. #### Status Register 1 (SR1) | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|---------|-----|-----|----|------|------|-----| | RS1 RS0 R/W AC | IRQ | TDRA/FC | TXU | CTS | FD | LOOP | S2RQ | RDA | | 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 OR-ed and indicated at by the S2RQ status bit. Therefore S2RQ indicated 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". - by 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 cleard 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 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 (Reg. #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 (Reg. #1 and #2) must be empty for TDRA to be high and when in the "2-Byte Transfer Mode". TDRA is inhibited by Tx Reset, or CTS being high. - When the Frame Complete Mode of operation is selected, the TDRA/FC status bit goes high when a Flag or Abort has been transmitted. The bit remains high until cleared by resetting the TDRA/FC control bit or setting the Tx Reset bit. - b7 Interrupt Request (IRQ) The Interrupt Request status bit indicates when the IRQ output is in the active state (IRQ Output = "0"). The IRQ status bit is subject to the same interrupt enables (RIE, TIE) as the IRQ output. The IRQ status bit simplifies status inquiries for polling systems by providing single bit indication of service requests. Figure 9. Status Register Priority Tree (PSE = 1) \*Prioritized even when PSE = 0 NOTE: Status bit above will inhibit one below it. #### Status Register 2 (SR2) | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-------------------------|----|-----|------|-----|-----|-----|------|----|----| | RS1 | RSO | $\mathbf{R}/\mathbf{W}$ | AC | RDA | OVRN | DCD | ERR | Rx | Rx | FV | AP | | 0 | 1 | 1 | X | | | | 1 | АВТ | Idle | | | - bo 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 Tx 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 (Rx Idle) The Rx Idle 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. - bg Abort Received (RxABT) The RxABT status bit indicates that 7 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 boundary 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 IRQ (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 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 F1FO 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. #### **Programming Considerations** - 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 (DCD, 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 IRQ 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 3 Rx FIFO bytes. However, the FIFO may contain data from 2 different frames when an overrun, 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. - 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 and status. - 3. Frame Complete Status and RTS Release In many cases, a MODEM will require a delay for releasing 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 (and 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 S6800 (a) Care 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 500ns. (b) The ADLC is a completely static part. However, the E frequency should be high enough to move data through the FIFO's and to service the peripheral requirements. Also, the period between successive E pulses should be less than the period of RxC or TxC in order to maintain synchronization between the data bus and the peripherals. #### August 1978 # VIDEO DISPLAY GENERATOR #### Features - 32 x 16 (512 total) Alphanumeric Two Color Display on Black Background with Internal or External Character Generator ROM. - □ Two Semigraphics Modes with Display □ Densities Ranging from 64 x 32 to 64 x 48 in 8 and 4 Color Sets Respectively, plus Black. - ☐ Full Graphics Modes with Display Densities Ranging from 64 x 64 to 256 x 192 in 2 and 4 Colors. - Full NTSC Compatible Composite Video with Choice of Interlaced and Non-interlaced Display Versions. - ☐ Provides Microprocessor Compatible Interface Signals. - ☐ Generates Display Refresh RAM Addresses. - ☐ NMOS Device, Single 5V Supply, TTL Compatible Logic Levels. - ☐ Color Set Select Pin Can Give 8 Color Displays in Full Graphics Mode. #### General Description The S68047 Video Display Generator (VDG) is designed to produce composite video suitable for display on a standard American NTSC compatible black/white television or color televison or monitor. There are three major types of display which the S68047 can generate. These include an alphanumerics mode of which there are two types, each with normal or inverted video; a semigraphics mode of which there are also two types; and full graphics mode of which there are eight types. #### Alphanumeric Modes The alphanumeric modes, internal and external, enable the S68047 to display a matrix of $32 \times 16$ (512 total) characters. The internal mode utilizes an on-chip 64 ASCII character ROM to display each character in a 5 x 7 dot matrix font. In the external alphanumeric #### General Description (Continued) mode, an external memory is required, either ROM or RAM, which is used to display the 32 x 16 character matrix with each character located within an 8 x 12 dot matrix of customized font. Switching between internal and external alphanumerics modes and normal and inverted video can be accomplished on a character by character basis. #### Semigraphic Modes The two semigraphic modes, semigraphic 4 (SG4) and semigraphic 6 (SG6), subdivide each of the 512 (32 x 16) character blocks of 8 x 12 dots each into 2 x 2 and 2 x 3 smaller blocks respectively. In SG4 each block is created from 4 x 6 dots and in SG6 each block consists of 4 x 4 dots. In addition the SG4 and SG6 modes can each be displayed in 8 and 4 colors plus black. Display switching from alphanumerics to semigraphics modes or vice versa during a raster display is called minor mode switching and can take place on a character basis. #### **Graphics Modes** The eight full graphics modes are divided into two major groups, 4 color and 2 color. The 4 color graphics provide 4 display densities ranging from 64 x 64 for Graphics 0 through to 128 x 192 elements for Graphics 6. The 2 color graphics also provide 4 display densities ranging from 128 x 64 for Graphics 1 through to 256 x 192 elements for Graphics 7. The latter display has the highest density of the eight graphics modes. The amount of display memory increases proportionately with increasing density of display to a maximum of 6K bytes for Graphics 7. Switching between either the alphanumeric modes or semigraphics modes and any of the full graphics modes is called major mode switching. Major mode switching can only occur at the end of every twelfth raster line scan. #### **Applications** Anywhere data can be more usefully presented graphically on a CRT and for a minimum cost, the VDG in system (television or monitor) should be conjunction with a microprocessor based controller with the highest video rate to be used. can utilize a standard American NTSC compatible TV or monitor for such a purpose. Applications are extremely broad ranging from educational systems, video games, small low cost business/home computers to process control monitors and medical diagnostic displays. The different modes of operation permit various cost/ display presentation tradeoffs. The alphanumerics modes allow use of the TV screen as a video teletype at the most limited level of operation. Only 512 bytes, one for each character, need to be stored, each byte being a minimum of six bits wide per the ASCII code. If video inversion switching or alpha to semigraphics switching is required per character then two extra bits are required in the display RAM as shown in Fig. 5. The semigraphics modes each offer an intermediate range of graphics densities with tradeoffs in density versus color. Typical semigraphics display capabilities are bar graphs, charts, mini displays, etc. which with minor mode switching to alphanumerics modes allow annotation or captioning of the resultant display. The various graphics modes provide greater density displays with greater freedom of display presentations. The tradeoffs in increasing density are with increasing display memory size and color versus density. A minimum Graphics 0 provides a display density of 64 x 64 (4096) elements, each element being composed of a matrix of 12 (4 x 3) dots with a selection of four colors per element. Since each of the even numbered 4 color graphics modes map two bits of the data word to one picture element, each data word of memory provides four picture elements. Thus Graphics 0 requires 4096/4 = 1024 bytes of display RAM, Graphics 2 requires 8192/4 = 2048 and so on. Graphics 1, like all the odd numbered 2 color graphics modes, maps one bit of data word to one picture element. Each data word therefore maps eight elements. Graphics 1 density of 128 x 8 (8192) elements therefore requires 8192/8 = 1024 bytes of display RAM and Graphics 7, the densest display, requires 49, 152/8 = 6144 bytes of RAM. At the higher density graphics displays, the rate of change of elements approaches the maximum dot frequency of 6MHz. This video rate taxes the capabilities of most commercially available television sets and thus the quality of the display system (television or monitor) should be commensurate # Electrical Specifications Absolute Maximum Ratings | Supply Voltage | 7.0V | |-----------------------|----------------| | Input Voltage | -0.3V to +7.0V | | Operating Temperature | . 0°C to 70°C | | Storage Temperature | 65°C to 150°C | DC (Static) Characteristics (V $_{CC}$ = 5.0V ± 5% ; $T_A$ = $25^{\circ}C,$ unless otherwise specified). | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |--------------------|------------------------------------------------|-------|------|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>IH</sub> | Input Voltage High | 2.0 | | $v_{cc}$ | V | | | V <sub>IH</sub> | Input Voltage High<br>(Color Clock only) | 4.0 | | $v_{cc}$ | v | | | $V_{lL}$ | Input Voltage Low | - 0.3 | | +0.6 | v | | | I <sub>IN</sub> | Input Leakage Current (all inputs) | | 1.0 | 2.5 | $\mu$ A | $V_{IN} = 0 - 5.25V;$<br>$V_{CC} = 0V$ | | I <sub>L(TS)</sub> | Tri-State Output<br>Leakage Current (A0 — A11) | | | 10 | μΑ | $V_{CC} = 5.25V; \overline{MS} = 0V;$<br>$V_{IN} = 0.4 - 2.4V$ | | $I_{LO}$ | Output Leakage Current<br>(HS, FS, RP) | | | 10 | μA | $V_{IN} = 2.4V; V_{CC} = 0V$ | | V <sub>OH</sub> | Output Voltage High<br>(A0 - A11, HS, FS, RP) | 2.4 | | | v | $I_{OH} = -100\mu A (\overline{HS}, \overline{FS}, \overline{RP});$<br>$0\mu A (A_0 - A_{11}); CL = 30pF$ | | VOL | Output Voltage Low<br>(A0 - A11, HS, FS, RP) | | | 0.4 | V | $I_{OL} = 1.6 \text{mA} (\overline{\text{HS}}, \overline{\text{FS}}, \overline{\text{RP}});$<br>$0 \text{mA} (A_0 - A_{11}); CL = 30 \text{pF}$ | | $I_{\rm CC}$ | V <sub>CC</sub> Supply Current | 7 | 45 | | mA | $V_{\rm CC}$ = 5V; $T_{\rm A}$ = 25°C | | C <sub>IN</sub> | Input Capacitance | | | 10 | pF | $V_{IN} = 0, T_A = 25^{\circ}C;$<br>f = 1.0MHz | | C <sub>OUT</sub> | Output Capacitance | | | 12 | pF | $V_{\rm IN} = 0, T_{\rm A} = 25^{\circ}{\rm C};$<br>f = 1.0MHz | AC Electrical Characteristics ( $V_{CC}$ = 5.0V ± 5%; $T_A$ = 0 - 70°C except where noted). Alpha Internal Mode (Figure 1) | ymbol | Parameter | Min, | Тур. | Max. | Unit | Conditions | |------------------|----------------------------------------|------|------|------|------|------------| | fvc | Video Clock Frequency | 5.6 | 6.0 | 6.4 | MHz | | | $t_{ m ch}$ | Character Time | 1.43 | 1.33 | 1.25 | μs | | | $t_{ACC}$ | Access-Time of External<br>Refresh RAM | | | 0.7 | μs | | | t <sub>dot</sub> | Dot Time | 178 | 166 | 156 | ns | | ### Alpha External Mode (Figure 1) NOTE: All parameters are the same as in Alpha Internal Mode except $t_{ACC}$ | t <sub>ACC</sub> | Access-time of Refresh<br>RAM + Access-time of<br>External ROM | | | 0.7 | μs | | |------------------|----------------------------------------------------------------|--|--|-----|----|--| |------------------|----------------------------------------------------------------|--|--|-----|----|--| #### Semigraphics Mode (Figure 1) | | <del></del> | | | | | | |-----------|--------------------------|-----|-----|-----|----|--| | $t_{pic}$ | Picture Element Duration | 712 | 664 | 624 | ns | | NOTE: All other parameters are the same as in Alpha Internal Mode. #### Color Sub-carrier Input | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------------------------|-------------|------|----------|------|-------|------------| | $\mathbf{f}_{\mathbf{CC}}$ | Frequency | | 3.579545 | | MHz | | | | | | ±10 Hz | | | | | t <sub>r</sub> | Rise Time | | | 10 | ns | | | tf | Fall Time | | | 10 | ns | | | $PW_{CC}$ | Pulse Width | | 140 | | ns | | | V <sub>IL</sub> | Zero Level | | | 0.6 | v | | | V <sub>IH</sub> | One Level | 4.0 | | | V | | | DR | Duty Ratio | 40% | 50% | 60% | | | #### Composite Video Timing (Figure 2) | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |-----------------------------------|------------------------------------------------|------|----------|-------|-------|------------| | tsync | Sync duration | | 4.888889 | | μs | | | $ m t_{fp}$ | Front Porch duration | | 1.536508 | | μs | | | tBLANK | Horizontal Blank Duration | | | 11.44 | μs | | | t <sub>rs</sub> , t <sub>fs</sub> | Rise time and Fall time of<br>Horizontal Sync | | | 250 | ns | | | t <sub>rv</sub> , t <sub>fv</sub> | Rise time and Fall time of<br>Horizontal Blank | | | 340 | ns | | Chroma R and Chroma B Output Timing; C<sub>L</sub> = 10pF; 1K Load (Figure 3.) | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |--------------------------------------|----------------------------|------|----------|------|-------|----------------------| | t <sub>rB</sub> , t <sub>fB</sub> | Color Signals rise and | | <u>'</u> | | | Load = $R-Y$ , $B-Y$ | | $t_{ m rR}$ , $t_{ m fR}$ | fall time | | 50 | | ns | input of LM1889 | | $\iota_{\mathrm{scB}}$ | Color Burst to Sync lag | | 410 | | ns | | | $t_{ m BURST}$ | Color Burst Duration | | 2.45 | | μs | | | $t_{fcB}, t_{reB}$ | Color Burst rise and fall | 1 | · — - ! | | | | | | times | | 175 | | ns | | | $t_{\mathrm{cL1}}, t_{\mathrm{cL2}}$ | Video to color signals lag | | 75 | | ns | | #### Voltage Levels Video (Y) and Chroma (R—Y, B—Y) Output Levels (Figure 3.) $C_L$ = 10pF; Video Clock = 5.6MHz; $T_A$ = 25° C; $V_{CC}$ = 5V ± 5% | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |-----------------------------|----------------|------|------|----------|-------|------------| | V <sub>SYNC</sub> | Sync Voltage | 0 | 0.1 | 0.5 | v | | | V <sub>BLANK</sub> | Blanking Level | | 1.5 | | v | | | VBLACK | Black Level | | 1.7 | | v | | | VWHITE | White level | 2.4 | 4.0 | $v_{cc}$ | V . | | | $\overline{V_{B1}, V_{R1}}$ | · - | 2.4 | 4.0 | $v_{cc}$ | v | | | $V_{B0}, V_{R0}$ | | | 2.0 | | V | | | $V_{B3}, V_{R3}$ | | 0 | 0.1 | 0.5 | V | | | $V_{BURST}$ | | | 0.4 | | v | * | | V <sub>CHROMA BIAS</sub> | | | 2.0 | | v | | Video Display Format Timing (Figure 4.) | Symbol | Parameter | Тур. | Units | Conditions | |-----------------|--------------------------------------------|-----------|-------------------|------------| | Н | Horizontal Scan Time | 63.55557 | μs | | | V | Field Time | 16.683337 | ms | | | F | Frame Time | 33.366674 | ms | | | I/V | Field Rate | 59.94004 | sec <sup>-1</sup> | , , | | tACTIVE | Active Display Duration | 41 | μs | | | tVIDEO | Active Display + Border<br>Duration | 52.8 | μs | | | t <sub>RP</sub> | Row Preset Period<br>(12 Horizontal Scans) | 762.66684 | μs | | #### Pin Description (Figure 2.) | V <sub>CC</sub> | +5V | |------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $V_{SS}$ | 0V | | CC | (Color Burst Clock 3.579545 MHz) | | VC | (Video Clock Oscillator = 6MHz) | | A0 A11 | (Address Lines to Display Memory; high-impedance during $\overline{\mathrm{MS}}$ low) | | D0 - D5 | (Data from Display Memory RAM or ROM; D4 — D6 — Color Data in Semigraphics) | | D6, D7 | (Data from Display Memory in GRAPHIC Mode; Data also in ALPHANUMERIC Mode; Color Data in ALPHA SEMIGRAPHIC $\pm$ 6) | | R - Y, B - Y, Y | (Color and Composite Video) | | CHB | (Chroma Bias; References $R = Y$ and $B = Y$ Levels) | | RP | (Row Presct in any ALPHA Mode; goes low in all modes every 12 lines) | | $\overline{ ext{HS}}$ | (Horizontal Sync) | | INV | (Inverts Video in all FULL ALPHA Modes; no effect in Semigraphics or Graphics Mode) | | EXT/INT | (Switches to External ROM in ALPHA Mode; between SEMIG - 4 and SEMIG - 6 in Semigraphics; no effect in all Graphics Modes) | | A/S | (Alpha/Semigraphics: Selects between FULL ALPHA and SEMIGRAPHICS in ALPHA Modes; no effect in all Graphics Modes) | | $\overline{ ext{MS}}$ | (Memory Select; forces VDG Address Buffers to high-impedance state; also used as a strobe in TEST and RESET functions). The TV screen is forced black when $\overline{\rm MS}$ = low | | $\overline{\mathrm{A}}/\mathrm{G}$ | (Switches between ALPHA and GRAPHIC Modes) | | FS | (Field Synchronization; LOW during vertical blanking time) | | CSS | (Color Set Select: Selects between two ALPHA Display Colors; between two Color Sets in SEMIGRAPHICS = 6 and FULL GRAPHICS; selects Border Color in 8 Graphic Modes) | | GM1, GM2<br>GM4 | (Graphics Mode Select; select one of eight Graphic Modes; no affect in Alpha and Semi-graphic Modes; GM1, GM2 select TEST and RESET mode when $\overline{A}/G = 0$ and $\overline{MS}$ pin is strobed low) | #### Internal Description Internally the VDG is the combination of four integrated subsystems (timing and control, MUX, address buffers and shift registers to form the VDG function. A block diagram of the VDG is shown on Page 1. Each subsystem is described below. #### Timing and Control The timing and control subsystem of the VDG uses the 3.58MHz color frequency to generate timing information. It accepts the color clock (generated off-chip) (CC) input and generates timing for the horizontal sync, horizontal blank, field sync, vertical blank and row preset signal $(\overline{RP})$ for external character generator ROM. The video clock is generated on-chip by ex- ternal RC and generates addresses A0 — A11 to address the external refresh RAM. The color-set-select (CSS) input to the Timing and Control subsystem of the VDG is used to determine the color-set of the display. The EXT/ $\overline{\text{INT}}$ input has two functions. In the full alphanumeric mode, it is used to select either internal ROM or external ROM. It is also used to select between semigraphic 4 and semigraphic 6 mode in semi-graphic modes ( $\overline{\text{A/S}} = 1$ ). The INV input is utilized by the timing and control subsystem to invert the display while in full alpha mode. #### Internal Description (Continued) A/G, A/S, GM1, GM2, GM4 inputs to the timing and control subsystem determine which of the fourteen VDG modes is to be used (Table 1). #### MUX The MUX provides the function of selecting the data source to be displayed. The source can be either internal ROM or external ROM or RAM. For the internal alphanumeric mode, the data source is the internal ROM. For all other modes (semigraphic and graphics) the data source is external ROM/RAM. #### Address Buffers The address buffers provide the buffering required for external drive (ROM/RAM). The buffers are tristated when the $\overline{\rm MS}$ pin goes low and tri-states the buffers so that VDG does not interfere with the MPU operation. The $\overline{\rm FS}$ pin (output) from the VDG signals to the MPU that the TV is in the vertical retrace mode and the MPU can directly change the data in the display memory during that time with no interruption to displayed data. #### Shift Registers The two shift registers serialize bytes coming from internal/external ROM/RAM for conversion to data on the TV screen. The shift registers output also goes to the chroma encoder circuitry to determine the color of each individual dot. Each shift register has 4-bits. #### VDG The VDG has fourteen modes, grouped in three sets. They are: - 4 Alphanumerics Modes □ Normal internal alpha □ Inverted internal alpha □ Normal external alpha □ Semigraphics 4 □ Semigraphics 6 - ☐ Inverted external alpha8 Full-graphics Modes - □ 4 Graphics four-color modes - ☐ 4 Graphics two-color modes The six alphanumeric modes can be switched among themselves on a character-by-character basis. Switching within the six alphanumeric modes is referred to as minor-mode switching. All other mode switching is referred to as major-mode switching. The display can be major-mode switched on after any multiple of twelve rows have been completed. This is signalled to the MPU by RP output going low. Switching among the full-graphics modes is permitted at the end of every twelfth row just as in major-mode switching. Table 1 tabulates the modes of the VDG. The data structures for each mode are listed in Table 7. Table 2 and Table 3 show the Alpha Select Mode and Graphic Select Mode configurations respectively. Table 4 gives the Two-color Graphics and Full-alpha Color Specification. Table 5 shows the semigraphics and Four-color Graphics Color Specification. Table 1. VDG Modes | | Mode | Description | Memory | |-------------|-------------------------------------------|-------------------------------------------------------------------------------------------|-------------| | I,<br>II. | ALPHA INTERNAL<br>ALPHA INTERNAL INVERTED | 32 x 16 BOXES: 5 x 7 CHARACTER<br>IN 8 x 12 BOX | 512 x 7 — 8 | | III.<br>IV. | ALPHA EXTERNAL<br>ALPHA EXTERNAL INVERTED | 32 x 16 BOXES: 5 x 7 OR 7 x 9 CHARACTERS<br>IN 8 x 12 BOX OR FULL 8 x 12 LIMITED GRAPHICS | 512 x 7 - 8 | | V. | ALPHA SEMIGRAPHICS 4 | 32 x 16 BOXES: 2 x 2 ELEMENTS PER BOX;<br>EIGHT COLORS PLUS BLACK | 512 x 4 - 7 | | VI. | ALPHA SEMIGRAPHICS 6 | 32 x 16 BOXES 2 x 3 ELEMENTS PER BOX;<br>FOUR COLORS PLUS BLACK | 512 x 6 - 8 | | VII. | GRAPHICS D | 64 x 64 ELEMENTS: FOUR COLORS PER ELEMENT | 1K x 8 | | VIII. | GRAPHICS 1 | 128 x 64 ELEMENTS: TWO COLORS PER ELEMENT | 1K x 8 | | IX. | GRAPHICS 2 | 128 x 64 ELEMENTS: FOUR COLORS PER ELEMENT | 2K x 8 | | X. | GRAPHICS 3 | 128 x 96 ELEMENTS: TWO COLORS PER ELEMENT | 1.5K x 8 | | XI. | GRAPHICS 4 | 128 x 96 ELEMENTS: FOUR COLORS PER ELEMENT | 3K x 8 | | XII. | GRAPHICS 5 | 256 x 96 ELEMENTS: TWO COLORS PER ELEMENT | 3K x 8 | | XIII. | GRAPHICS 6 | 128 x 192 ELEMENTS: FOUR COLORS PER ELEMENT | 6K x 8 | | XIV. | GRAPHICS 7 | 256 x 192 ELEMENTS: TWO COLORS PER ELEMENT | 6K x 8 | Table 7. Detailed Description of VDG Model | | | YDG P | INS | | | _ | | COLOR | | Ţ | V SCREEN | <u> </u> | | |------------|--------|-------|-----|-------|----------|-------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | UG A/S | INT/EX | T GM | GM: | 2 GM1 | cas | MY | | SACK:<br>GROUND | BORDER | DISPLAY MODE | DETAIL | ZUB ATAG 20Y | COMMENTS | | ų n | 5 | X | G | 0 | 0 | 0 | Graen .<br>Black !<br>Blue ! | Black<br>Green<br>Black<br>Black | Black<br>Black | 32 Characters<br>in columns<br>16 Characters | 1 4015<br>1 1015<br>1 1 1015 | MOT ASSIMPLY | ALPHANOMERIC INTERNAL mode uses internal<br>character generator with on-drip 64 ASCII char-<br>acter RUM to display each character in 6x7 dat<br>matrix fort. | | 0 0 | ' | × | 0 | 5 | 1 | 1<br>0<br>1 | Sieer<br>Black<br>Green<br>Black | DI est | Black<br>Black | 32 Characters<br>in columns<br>16 Characters<br>in rows | 4 | DIE MOW DF CUSTOM CHARACTERS | ALPHANUMERIC EXTERNAL mode uses external ROM or RAM to display 512 characters in custom fellis each in 8x12 dot mairix | | )<br>o : | 9 | x | 0 | 5 | x | × | L, C, C, L<br>0 X X X<br>1 5 0 0<br>1 2 0 1<br>1 0 1 0<br>1 1 1 0 0<br>1 1 1 0 0<br>1 1 1 1 0 | Green<br>Yellow<br>Cyan<br>Red<br>Blue<br>Cyan/<br>Slue<br>Magenta | e lack | 64 Display<br>elements in<br>columns<br>32 Display<br>elements in rows | 11 to 12 | C2 CT CD LS L2 L1 LB<br>NOT COLON LUMBHRACE<br>USED | SEMISRAPHICS 4 mode subdivides each of the<br>512 (32x/6) Character blocks of 8x12 adds into<br>Sue requel pairs. The dominance of each block<br>betermined by the corresponding bit (L0-L2) on<br>the YOC data bus. Color of each block is deter-<br>mined by 3 bits (C0-C3). | | ) I I | 1 | x | 0 | 5 | 0<br>X | × | | U Stack<br>Green<br>Yearow<br>Cyan<br>Red<br>Sale<br>Cyan/<br>Blue<br>Magenta | Black | 64 Display<br>elements in<br>Columns<br>46 Display<br>elements in lows | 1 0<br>13 12<br>15 14 | COLON LUMINENCE | SEMICRAPHICS 6 made subdivides each of the<br>512 (35x16) character backs of \$412 dats into<br>\$x equal parts. The furniance of each part is<br>\$x equal parts. The furniance of each part is<br>\$etermined by the corresponding bits (1c4-15) or<br>the VDG bus. Cobe of each \$aick is determined<br>by \$2 tirs (CO CT). | | 1 X | x | 0 | 0 | э | 1 | ĸ | C1 C0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 | Veilow<br>Cyan<br>Reú<br>Blue<br>Cyan/<br>Blue | Green<br>Cyan/<br>Blue | 64 Crisplay<br>elements in<br>columns<br>64 Display<br>elements in rows | E3 E2 E1 E0 <br> WHIF BEE EX - C7CG | [21] CO [CO [CO [CO [CO ] | BRAPHICS O more uses a mazinam of 1024 bytes of display RAM in which one pain of bits (CO. C1) specifies on picture element. (Lx.) | | × | x | | ٥ | 1 | 0 | x | | Color<br>Black<br>Greed<br>Glack<br>Cyan/<br>Blue | Green<br>Cyan/<br>Blub | 128 Display<br>elements in<br>colurins<br>64 Display | <u> </u> | िक व्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः विद्याद्धाः व | GRAPHICS 1 mode uses a maximum of 1024<br>bytes of display RAM in which one bit (Lx)<br>specifies are picture element. | | 1 X | x | D | 1 | 0 | Ð<br>1 | × | Same color a<br>Graphics O | 38 | Green<br>Cyan/<br>Brue | 126 Display<br>elements in<br>columns<br>G4 Display<br>elements in rows | £3 £2 £1 £0 | <u>ाक राखाता</u> काटा | URAPHICS 2 mode uses a maximum of 2048 bytes of display RAW in which one pair of bits (CU, C1) specifies one pacture element (Ex.). | | × | × | Đ | , | 1 | 1 | x | Same color a<br>Graphics 1 | as | Green<br>Cyar/<br>Blue | #28 Display<br>elements in<br>columns<br>96 Display<br>elements in rows | [17][6][5][4] [3] [2] [1] [4] | [LT] LE L5 L6 L3 12 L1 L0 | CRAPHICS 3 mode uses a maximum of 1536<br>bytes of display RAM in which one bit (Lx)<br>specifies and picture etement. | | × | × | 0 | , | a | 0 | x | Same color a<br>Graphics 0 | ars | Breen<br>Cyan/<br>Blue | 128 Display<br>elements in<br>columns<br>96 Display<br>elements in rows | E3 E2 E1 E0 | <u>ाः</u> | GRAPHICS 4 mode uses a maximum of 3072<br>bytes of display RAM in which one pair of bits<br>(CO, C1 specifies one picture element (Ex.) | | × | x | 1 | 5 | 1 | 1 | × | Same color a<br>Graphics 1 | 38 | Green<br>Cyan/<br>Blue | 256 Display<br>elements un<br>columns<br>95 Display<br>elements in rows | (राष्ट्राक्षमामासम्हरू)<br>- | [17[18][5][14][15[17][15] | GRAPHICS 5 mode uses a maximum of 3072 bytes of display RAM in which one brill(x) specifies one picture element. | | X | x | 1 | | u | <u> </u> | х | Same color a<br>Graphics D | 35 | Green<br>Cyan/<br>Blue | 128 Display elements in columns 192 Display elements in rows | es es es ed | [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ | GRAPHICS 6 more uses a maximum of 6144 bytes of display HAM in which one pair of bits (CO. CT) specifies one poture element (Ex.) | | 1 X | Х | 1 | 1 | 1 | o<br>i | X | Same color a<br>Graphics 1 | as | Sreen<br>Cyan/<br>Blue | 256 Display<br>elements in<br>columns<br>192 Display<br>elements in rows | ប្រធានប្រាស់ប្រើប្រ | | GRAPHICS 7 mode uses a maximum at 6144<br>hytes of display RAIX in which one bit (LXI<br>speed as que pictaire element | Table 2. Alpha Mode Select | GM2 | GM1 | Ā/G | Ã/S | INT/EXT | INV | MS | MQDE | |-----|-----|-----|-----|---------|-----|-------------|------------------------| | χ | 0 | 0 | 0 | 0 | 0 | <del></del> | INTERNAL ALPHANUMERICS | | X | D | 0 | 0 | 0 | 1 | | INTERNAL INV. ALPHA | | X | 0 | 0 | 0 | 1 | 0 | | EXTERNAL ALPHA | | Х | 0 | 0 | 0 | 1 | 1 | | EXTERNAL INV. ALPHA | | Х | 0 | 0 | 1 | 0 | x | | SEMIGRAPHICS - 4 | | Х | ۵ | 0 | 1 | 1 | Х | | SEMIGRAPHICS - 6 | | 0 | 1 | 0 | х | Х | X | STROBED LOW | TEST ROM | | 1 | 1 | 0 | х | Χ | x | STROBED LOW | RESET | NOTES: 1) GM4 pin has no effect when $\overline{A}/G = 0$ . - 2) Invertipin has no effect except in Internal Alpha or External Alpha. - 3) Under normal operation, care should be taken not to take GM1 pin HIGH, when A/G pin is LOW. If this happens, any of the following conditions will occur depending on the status of MS and GM2 pin: - a) The VDG might go to TEST mode. - b) The VDG might be reset. The VDG will not return to normal operation unless $\overline{A}/G$ and GM1 pins are returned to LOW level and $\overline{MS}$ pin is strobed. 4) X = Don't care. Table 3. Graphic Mode Select | | $\overline{A}/G$ | GM4 | GM2 | GM1_ | MODE MODE | |------------|------------------|-----|-----|------|---------------------| | GRAPHICS 0 | 1 | 0 | 0 | 0 | 64 x 64 4 - COLOR | | GRAPHICS 1 | 1 | 0 | 0 | 1 | 128 x 64 2 - COLOR | | GRAPHICS 2 | 1 | 0 | 1 | O | 128 x 64 4 - COLOR | | GRAPHICS 3 | 1 | 0 | 1 | 1 | 128 x 96 2 COLOR | | GRAPHICS 4 | 1 | 1 | 0 | 0 | 128 x 96 4 ~ COLOR | | GRAPHICS 5 | 1 | 1 | 0 | 1 | 256 x 96 2 - COLOR | | GRAPHICS 6 | 1 | 1 | 1 | 0 | 128 x 192 4 — COLOR | | GRAPHICS 7 | 1 | 1 | 1 | 1 | 256 x 192 2 - COLOR | NOTE: $\overline{A}/S$ , $\overline{INT}/EXT$ , INV pins have no effect when $\overline{A}/G=1$ . Table 4. Two-Color Graphics and Full-Alpha Color Specification | C\$S PIN | COLOR OF 'ON' DOTS | | |----------|--------------------|--| | a | GREEN | | | 1 | CYAN-BLUE | | Table 5. Semigraphics and Four-Color Graphics Color Specification | | | | | | SEMI-<br>GRAPHICS – 4 | SEMI-<br>GRAPHICS 6 | 4-COLOR<br>GRAPHICS | |-----------|---|---|------|-------------|-----------------------|---------------------|---------------------| | | ¬ | _ | | <u></u> | D4 | D6 | EVEN BIT | | | | 1 | | | <b>D</b> 5 | D7 | ODD BIT | | | 1 | l | | <del></del> | D6 | css | CSS | | GREEN | Ó | ŏ | , 0 | COLOR | | | _ | | YELLOW | 1 | 0 | 10 | \$ET | | | | | CYAN | 0 | 1 | i o | 1 | | | | | RED | 1 | 1 | ( 0 | | | | | | BLUE | 0 | 0 | 1.1 | | | | | | CYAN/BLUI | 1 | 0 | 1 | COLOR | | | | | MAGENTA | 0 | 1 | - ∫1 | SET | | | | | ORANGE | 1 | 1 | 1 1 | 2 | | | | NOTE: In Semigraphics = 6, if any bit D0 = D5 is '0', then picture element corresponding to that bit would be black. In Semigraphics = 4, if any bit D0 = D3 is zero, then the picture element corresponding to that dot will be black. Table 6. Two-Color Graphics and Four-Color Graphics Border Color Specification | CSS PIN | BORDER COLOR | | |---------------|--------------------|--| | <b>0</b><br>1 | GREEN<br>CYAN-BLUE | | Typical System: A typical S6800 microprocessor based S68047 system is shown on Figure 5. This system has the capability of displaying internally and externally generated characters, semigraphics 4 and 6 modes with mode switching control from the microcomputer input/output ports. A full graphics system configuration would be similar in complexity with possibly additional display RAM for the denser graphics modes. The National Semiconductor LM1889 RF modulator shown, has an on chip 3.58 MHz oscillator which can provide the microcomputer system clock as well as the color burst reference for the S68047. Other RF modulators are available through various commercial channels. Only 512 bytes are needed to display the 512 character blocks on a TV screen. However, because of current static RAM configurations (ie. 1Kx1 & 1Kx4) the extra 512 bytes available in the 1Kx9 RAM shown can be used as scratchpad by the host microcomputer system. #### Ordering Information | Ordering No. | No. Pins | Package | Temp. Range | Description | |--------------|----------|---------|-------------|--------------------| | S68047 | 40 | Ceramic | 0-70°C | VDG non-interlaced | | S68047P | 40 | Plastic | 0-70°C | VDG non-interlaced | | S68047Y | 40 | Ceramic | 0-70°C | VDG interlaced | | S68047YP | 40 | Plastic | 0-70°C | VDG interlaced | # GENERAL PURPOSE INTERFACE ADAPTER #### **Features** - ☐ Single or Dual Primary Address Recognition - ☐ Secondary Address Capability - ☐ Complete Source and Acceptor Handshakes - ☐ Programmable Interrupts - ☐ RFD Holdoff to Prevent Data Overrun - ☐ Operates with DMA Controller - ☐ Serial and Parallel Polling Capability - ☐ Talk Only or Listen-Only Capability - ☐ Selectable Automatic Features to Minimize Software - ☐ Synchronization Trigger Output - ☐ S6800 Bus Compatible #### General Description The S68488 GPIA provides the means to interface between the IEEE488 standard instrument bus and the S6800. The 488 instrument bus provides a means for controlling and moving data from complex systems of multiple instruments. The S68488 will automatically handle all handshake protocol needed on the instrument bus. #### **Functional Description** The IEEE 488 instrument bus standard is a bit-parallel, byte-serial bus structure designed for communiation to and from intelligent instruments. Using this standard, many instruments may be interconnected and remotely and automatically controlled or programmed. Data may be taken from, sent to, or transferred between instruments. A bus controller dictates the role of each device by making the attention line true and sending talk or listen addresses on the instrument bus data lines; those devices which have matching addresses are activated. Device addresses are set into each GPIA from switches or jumpers on a PC board by a microprocessor as a part of the initialization sequence. When the controller makes the attention line true, instrument bus commands may also be sent to single or multiple GPIAs. Information is transmitted on the instrument bus data lines under sequential control of the three handshake lines. No step in the sequence can be initiated until the previous step is completed. Information transfer can proceed as fast as the devices can respond, but no faster than the slowest device presently addressed as active. This permits several devices of different speeds to receive the same data concurrently. The GPIA is designed to work with standard 488 bus driver Ics (\$3448As) to meet the complete electrical specifications of the IEEE488 bus. Additionally, a powered-off instrument may be powered-on without disturbing the 488 bus. With some additional logic, the GPIA could be used with other microprocessors. The S68488 GPIA has been designed to interface between the S6800 microprocessor and the complex protocol of the IEEE488 instrument bus. Many instrument bus protocol functions are handled automatically by the GPIA and require no additional MPU action. Other functions require minimum MPU response due to a large number of internal registers conveying information on the state of the GPIA and the instrument bus. #### Maximum Ratings | Supply Voltage0.3Vdc to +7.0Vdc | |---------------------------------| | Input Voltage0.3Vdc to +7.0Vdc | | Operating Temperature Range | | Storage Temperature Range | | Thermal Resistance +82.5°C/W | 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. ## Electrical Characteristics ( $V_{CC}$ = 5.0V ±5%, $V_{SS}$ = 0, $T_A$ = 0°C to +70°C unless otherwise noted) | Symbol | Parameter | Min, | Тур. | Max. | Unit | Conditions | |-------------------------|---------------------------------------------|-----------------------|------|------------------------------------------------|------|--------------------------------------------------------------| | V <sub>IH</sub> | Input High Voltage | V <sub>SS</sub> + 2.0 | | $v_{cc}$ | Vdc | · | | $\overline{v_{\rm IL}}$ | Input Low Voltage | V <sub>SS</sub> - 0.3 | | $v_{SS} + 0.8$ | | | | $I_{\rm IN}$ | Input Leakage Current | | 1.0 | 2,5 | μAde | $V_{IN} = 0 \text{ to } 5.25 \text{V}$ | | $\overline{I_{TS1}}$ | Three-State (Off State) Input Current D0-D7 | | 2,0 | 10 | μΛde | V <sub>IN</sub> = 0.4 to 2.4V | | V <sub>OH</sub> | Output High Voltage<br>D0-D7 | V <sub>SS</sub> + 2.4 | | | Vdc | $I_{load} = -205\mu\Lambda$ | | VOL | Output Low Voltage D0-D7 IRQ | | | V <sub>SS</sub> + 0.4<br>V <sub>SS</sub> + 0.4 | Vdc | I <sub>load</sub> = 1.6mA<br>I <sub>load</sub> = 3.2mA | | $I_{LOH}$ | Output Leakage Current (Off State) | | 1.0 | 10 | μAde | V <sub>OH</sub> = 2.4Vdc | | $P_{\mathrm{D}}$ | Power Dissipation | | 600 | | mW | | | CIN | Input Capacitance D0-D7 All Others | | | 12.5<br>7.5 | pF | V <sub>IN</sub> = 0,<br>T <sub>A</sub> = 25°C,<br>f = 1.0MHz | # Bus Timing Characteristics Read (See Figure 3) | Symbol | Parameter | Min. | Typ. | Max, | Unit | Conditions | |-----------------------------------------------------|-----------------------------------------------------------------|------|---------------------------------------|----------|------|---------------------------------------------| | teyeE | Enable Cycle Time | 1.0 | | | μs | <u> </u> | | PWEH | Enable Pulse Width, High | 0.45 | · · · · · · · · · · · · · · · · · · · | <u> </u> | μs | | | PWEL | Enable Pulse Width, Low | 0.43 | | | μs | | | tAS | Setup Time, Address and R/W valid to enable positive transition | 160 | | | ns | See<br>Figure 3 | | tDDR | Data Delay Time | | | 320 | ns | r igure 5 | | tH | Data Hold Time | 10 | | | ns | | | tAH | Address Hold Time | 10 | | | ns | 1 | | tEr, tEf | Rise and Fall Time for<br>Enable input | | | 25 | ns | | | Write (See | Figure 4) | | | · | | | | $t_{cycE}$ | Enable Cycle Time | 1.0 | } | | μς | | | PWEH | Enable Pulse Width, High | 0.45 | :<br>: | | μs | 1 | | PWEL | Enable Pulse Width, Low | 0.43 | | | μs | | | t <sub>AS</sub> | Setup Time, Address and R/W valid to enable positive transition | 160 | | | ns | See<br>Figure 4 | | $t_{ m DSW}$ | Data Sctup Time | 195 | · | | ns | I iguic i | | tH | Data Hold Time | 10 | | | ns | | | t <sub>AH</sub> | Address Hold Time | 10 | 1 | | ns | | | t <sub>Er</sub> , t <sub>Ef</sub> | Rise and Fall Time for<br>Enable input | | - | 25 | ns | | | Output (Se | e Figure 5) | | | | | | | tHD | Output Delay Time | | | 400 | ns | DAV, DAC, RFD<br>EOI, ATN valid | | $t_{\mathrm{T}/\overline{\mathrm{R1}},2\mathrm{I}}$ | $\vec{J}$ | | 1 — | 400 | ns | $T/\overline{R}1$ , $T/\overline{R}2$ valid | #### A.C. Time Values | Symbol* | Parameter | | Min. | Тур. | Max. | Unit | Conditions | |----------------|--------------------------------------------------------------------|-------|------|------|------|------|------------| | T 1 | Settling Time for Multiple Message | SH | | ≥2 | | μs** | | | $\mathbf{t}_2$ | Response to ATN SH, AH, T | , L | | ≤200 | | ns | | | $T_3$ | Interface Message Accept Time † | VII , | | >0 | | ŧ | | | t4 | Response to $\overline{IFC}$ or $\overline{REN}$ False T, TE, L, 1 | LE . | | <100 | | μs | ! | | t <sub>5</sub> | Response to ATN • EOI | PP | | ≤200 | | ns | | <sup>\*</sup> Time values specified by a lower case t indicate the maximum time allowed to make a state transition. Time values specified by an upper case T indicate the minimum time that a function must remain in a state before exiting. - \*\* If three-state drivers are used on the $\overline{DIO} = \overline{DAV}$ and $\overline{EOI}$ lines, $T_1$ may be: - (1) ≥1100ns - (2) Or ≥700ns if it is known that within the controller ATN is driven by a three-state driver. - (3) Or ≥500ns for all subsequent bytes following the first sent after each false transition of ATN [the first byte must be sent in accordance with (1) or (2)]. - † Time required for interface functions to accept, not necessarily respond to interface messages. - f Implementation dependent. MPU bus clock rate — The current 6800 bus clock is $\leq 1$ MHz but part should operate at 1.5MHz (design goal), with appropriate settling times (T1). #### **GPIA/MPU Interface Signals** The S68488 interfaces to the S6800 MPU with an eight-bit bidirectional data bus, a chip select, Read/Write line, reset line, three register select lines, an interrupt request line, two DMA control lines, and an address switch enable line. Bidirectional Data (D0-D7) — The bidirectional data lines allow the transfer of data between the MPU and the GPIA. The data bus output drives are three-state devices that remain in the high impedance (off) state except when the MPU performs a GPIA read operation. Chip Select $(\overline{CS})$ — This input signal is used to select the GPIA. $\overline{CS}$ must be low for selection of the device. Chip select decoding is normally accomplished with logic external to the chip. Read/Write Line (R/W) — This signal is generated by the MPU to control register access and direction of data transfer on the data bus. A low state on the GPIA Read/Write allows for the selection of one of seven write-only registers when used in conjunction with the register select lines RSO, RS1, RS2. A high state on the GPIA Read/Write allows for the selection of one of eight read-only registers when used in conjunction with register select lines RSO, RS1, RS2. Register Select (RS0, RS1, RS2) — The three register select lines are used to select the various registers inside the GPIA. These three lines are used in conjunction with the Read/Write line to select a particular register that is to be written or read. Table 1 shows the register select coding. Table 1. Register Access | RS2 | RS1 | RS0 | R/W | REGISTER TITLE | REGISTER<br>Symbol | |-----|-----|-----|-----|----------------------|--------------------| | 0 | 0 | 0 | 1 | INTERRUPT STATUS | ROR | | 0 | 0 | 0 | 0 | INTERRUPT MASK | ROW | | 0 | 0 | 1 | 1 | COMMAND STATUS | R1R | | 0 | 0 | 1 | 0 | UNUSED | - | | 0 | 1 | 0 | 1 | ADDRESS STATUS | R2R | | 0 | 1 | 0 | 0 | ADDRESS MODE | R 2W | | 0 | 1 | 1 | 1 | AUXILIARY COMMAND | R3R | | 0 | 1 | 1 | 0 | AUXILIARY COMMAND | R3W | | 1 | 0 | 0 | 1 | ADDRESS SWITCH* | R4R | | 1 | 0 | 0 | a | ADDRESS | R4W | | 1 | 0 | 1 | 1 | SERIAL POLL | R5R | | 1 | 0 | 1 | 0 | SERIAL POLL | R5W | | 1 | 1 | 0 | 1 | COMMAND PASS-THROUGH | RER | | 1 | 1 | 0 | 0 | PARALLEL POLL | R6W | | 1 | 1 | 1 | 1 | DATA IN | R7R | | 1 | 1 | 1 | 0 | DATA OUT | R7W | <sup>\*</sup>External to S68488 Interrupt Request $(\overline{IRQ})$ — The $\overline{IRQ}$ output goes to the common interrupt bus for the MPU. This is an open drain output which is wire-ORed to the $\overline{IRQ}$ bus. The IRQ is set false (low) when an enabled interrupt occurs and stays false until the MPU reads from the interrupt status register. Reset — The active low Reset line is used to initialize the chip during power on start up. Reset will be driven by an external power-up reset circuit. DMA Control Lines (DMA Grant, DMA Request)— The DMA request line is used to signal waiting data when Byte In (BI) or Byte Out (BO) is set high for a DMA controller. The DMA request line is set high if either the BI or BO interrupt flags are set in the Interrupt Status Register (ROW) and the corresponding the cates to the co bits in the Interrupt Mask Register (ROR) are set true. The DMA request line is cleared when the DMA grant is made true. The DMA grant line is used to signal the GPIA that the DMA controller has control of the MPU data and address lines.\* DMA Grant must be grounded when not in use! Address Switch Enable $(\overline{ASE})$ — The $\overline{ASE}$ output is used to enable the device address switch three-state buffers to allow the instrument address switch to be read on the MPU bus. Clock Input (Clk) — The clock input is normally a derivative of the MPU \$\phi 2\$ clock. #### GPIA/488 Interface Bus Signals The GPIA provides a set of eighteen interface signal lines between the S6800 and the IEEE Standard 488 bus. Signal Lines (IB0-IB7) — These bidirectional lines allow for the flow of seven bit ASCII interface messages and device-dependent messages. Data appears on these lines in a bit-parallel byte-serial form. These lines are buffered by the transceivers and applied to the 488 but (DIO1-DIO8). Byte Transfer Lines (DAC, RFD, $\overline{DAV}$ ) — These lines allow for proper transfer of each data byte on the bus between sources and acceptors. RFD goes passively true, indicating that all acceptors are "ready for data." A source will indicate the "data is valid" by pulling $\overline{DAV}$ low. Upon the reception of valid data by all acceptors, DAC will go passively true, indicating that the "data has been accepted" by all acceptors. Bus Management Lines $(\overline{ATN}, \overline{IFC}, \overline{SRQ}, \overline{EOI}, \overline{REN})$ —These lines are used to manage an orderly flow of information across the interface lines. Attention $(\overline{ATN})$ — This is sent true over the interface to disable current talker and listeners, freeing the signal lines $(\overline{IB0} \cdot \overline{IB7})$ . During the $\overline{ATN}$ , active state devices monitor the DIO1 for addressing or an interface command. Data flows on the DIO1 lines when $\overline{ATN}$ is inactive (high). Interface Clear $(\overline{IFC})$ — This is used to put the interface system into a known quiescent state. Service Request $(\widetilde{SRQ})$ — This is used to indicate a need for attention in addition to requesting an interruption in the current sequence of events. This indicates to the controller that a device on the bus is in need of service. Remote Enable ( $\overline{REN}$ ) — This is used to select one of two alternate sources of device programming data. local or remote control. End of Identify (EOI) - This is used to signal the end of a multiple byte transfer sequence and, in conjunction with ATN, executes a parallel polling sequence. Transmit/Receive Control Signals $(T/\overline{R}1, T/\overline{R}2)$ = These two signals are used to control the quad transceivers which drive the interface bus. It is assumed that appropriate transceivers will be used where each transceiver has a separate transmit/receive control pin. These pins can support one TTL load each. The outputs can then be grouped as shown in the Block Diagram with SRQ hardwired high to transmit. The transmit/ receive inputs of REN, IFC, and ATN are hardwired low to receive. ROI is controlled by $T/\overline{R}1$ through the S3448A (or an equivalent), allowing it to transmit or receive. T/R1 operates exactly as T/R2 except during the parallel polling sequence. During parallel poll, $\overline{\mathrm{EOI}}$ will be made an input by $\mathrm{T}/\overline{\mathrm{R}}\mathbf{1}$ while $\overline{\mathrm{DAV}}$ and IBO-IB7 lines are outputs. #### GPIA INTERNAL CONTROLS AND REGISTERS\* There are fifteen locations accessible to the MPU data bus which are used for transferring data to control the various functions on the chip and provide current chip status. Seven of these registers are write only and eight registers are read only. The various registers are accessed according to the three least significant bits of the MPU address bus and the status of the Read/Write line. One of the fifteen registers is external to the IC but an address switch register is provided for reading the address switches. Table 2 shows actual bit contents of each of the registers. \*Note: Upper and lower case type designations will be used with the register bits to indicate remote or local messages, respectively. Table 2 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | _ | |-----|----------|------|-------------|------|------|------|-------------|------|------------------------| | ROW | IRQ | BO | GET | | APT | CMD | END | Bl | Interrupt "Mask" Reg. | | ROR | INT | во | GET | | APT | CMD | END | ВІ | Interrupt Status Reg. | | RIR | UACG | REM | LOK | | RLC | SPAS | DCAS | UUCG | Command Status Reg. | | R1W | | | | | | | | | Unused | | R2R | ma | to | lo | ATN | TACS | LACS | LPAS | TPAS | Address Status Reg. | | R2W | dsel | to | lo | | hide | hida | | apte | Address Mode Reg. | | R3R | Borne | DAC | DAV | RFD | | rtl | ulpa | funt | Austilians Command Day | | R3W | 3W Reset | rfdr | feoi | dacr | msa | | dacd | fget | Auxiliary Command Reg. | | R4R | ี บท3 | UD2 | U <b>D1</b> | AD5 | AD4 | AD3 | AD2 | AD1 | Address Switch Reg. | | R4W | Isbe | dal | dat | AD5 | AD4 | AD3 | AD2 | AD1 | Address Register | | R5R | S8 | SROS | S6 | S5 | S4 | S3 | S2 | l S1 | Casiol Dall Dog | | R5W | 36 | rsv | 50 | 33 | 54 | 33 | 32 | 31 | Serial Poll Reg. | | R6R | B7 | B6 | B5 | B4 | В3 | B2 | B1 | В0 | Command Pass-thru Reg. | | R6W | PPR8 | PPR7 | PPR6 | PPR5 | PPR4 | PPR3 | PPR2 | PPR1 | Parallel Poll Reg. | | B7R | _D17 | D16 | D15 | D14 | D13 | D12 | D <u>11</u> | D10 | Data In Register | | R7W | D07 | 900 | D05 | D04 | D03 | 002 | D01 | 000 | Data Out Register | Data-In Register R7R - The data-in register is an actual eight-bit storage register used to move data from the interface bus when the chip is a listener. Reading the register does not destroy information in the data-out register. DAC (data accepted) will remain low until the MPU removes the byte from the data-in formation has been processed. register. The chip will automatically finish the handshake by allowing DAC to go high. In RFD (ready for data) holdoff mode, a new handshake is not initiated until a command is sent allowing the chip to release holdoff. This will delay a talker until the available in- #### Data-In Register (Read Only) | İ | 017 | DIE | D15 | D14 | DI3 | D12 | 1ום | D10 | |---|-----|-----|-----|-----|-----|-----|-----|-----| | | | | | | | | | | DIO-DI7 correspond to DIO1-DIO8 of the 488-1975 Standard and $\overline{180}$ - $\overline{187}$ of the S68488. Data Out Register R7W — The data-out register is an actual eight-bit storage register used to move data out of the chip onto the interface bus. Reading from the data-in register has no effect on the information in the data-out register. Writing to the data-out register has no effect on the information in the data-in register. ## Data Out Register (Write Only) | D07 | D06 | 005 | D04 | 003 | D02 | DQ1 | 000 | |-----|-----|-----|-----|-----|-----|-----|-----| D00-D07 correspond to the D101-D108 of the 488-1975 Standard and $\overline{\text{IB0}}$ - $\overline{\text{IB7}}$ of the S68488. Interrupt Mask Register ROW — The Interrupt Mask Register is a seven-bit storage register used to select the particular events that will cause an interrupt to be sent to the MPU. The seven control bits may be set independently of each other. If dsel (bit 7 of the Address Mode Register) is set high, CMD bit 2 will interrupt on SPAS or RLC. If dsel is set low, CMD will interrupt on UACG, UUCG, and DCAS in addition to RLC and SPAS. The Command Status Register R1R may then be used to determine which command caused the interrupt. Setting GET bit 5 allows an interrupt to occur on Group Execute Trigger Command. END bit 1 allows an interrupt to occur if EOI is true (low) and ATN is false (high). APT bit 3 allows an interrupt to occur, indicating that a secondary address is available to be examined by the MPU if apte (bit 0 of Address Mode Register) is enabled and listener or talker primary address is received and a Secondary Command Group is received. A typical response for a valid secondary address would be to set msa (bit 3 of Auxiliary Command Register) true and dacr (bit 4 Auxiliary Command Register) true, releasing the DAC handshake. Bl indicates that a data byte is waiting in the data-in register. BI is set high when data-in register is full. BO indicates that a byte from the data-out register has been accepted. BO is set when the data-out register is empty. IRQ enabled high allows any interrupt to be passed to the MPU. #### Interrupt Mask Register (Write Only) | IRQ BO GET X | APT { | CWD END | ВІ | |--------------|-------|---------|----| |--------------|-------|---------|----| IRQ - Mask bit for IRQ pin BO — Interrupt on byte output GET — Interrupt on Group Execute Trigger APT — Interrupt on Secondary Address Pass-Through CMD - Interrupt on SPAS + RLC + dsel (DCAS + UUCG + UACG) END — Interrupt on EOI and ATN BI Interrupt on byte input Interrupt Status Register ROR — The Interrupt Status Register is a seven-bit storage register which corresponds to the interrupt mask register with an additional bit INT bit 7. Except for the INT bit, the other bits in the status register are set regardless of the state of the interrupt mask register when the corresponding event occurs. The $\overline{IRQ}$ (MPU interrupt) is cleared when the MPU reads from the register. INT bit 7 is the logical OR of the other six bits ANDed with the respective bit of ROW. ## Interrupt Status Register (Read Only) INT - Logical OR of all other bits in this register ANDed with the respective bits in the interrupt mask register BQ — A byte of data has been output F - A Group Execute Trigger has occurred APT — An Address Pass-Through has occurred CMD - SPAS + RLC + dsel (OCAS + UUCG + UACG) has occurred END — An EOI has occurred with $\overline{ATN} = 0$ B! — A byte has been received Serial Poll Register R5R/W — The Serial Poll Register is an eight-bit storage regiter which can be both written into and read by the MPU. It is used for establishing the status byte that the chip sends out when it is serial poll enabled. Status may be placed in bits 0 through 5 and bit 7. Bit 6 rsv (request for service) is used to drive the logic which controls the SRQ line on the bus telling the controller that service is needed. This same logic generated the signal SRQS which is substituted in bit 6 position when the status byte is read by the MPU IB0-IB7. In order to initiate a rsv (request for service), the MPU sets bit 6 true (generating rsv signal) and this in turn causes the chip to pull down the SRQ line. SRQS is the same as rsv when SPAS is false. Bit 6 as read by the MPU will be the SPQS (Service Request State). #### Serial Poll Register (Read) | S8 SROS S6 S5 S4 S3 S2 S1 | | S8 | SRQS | S6 | S <b>5</b> | S4 | S3 | S2 | \$1 | |---------------------------|--|----|------|----|------------|----|----|----|-----| |---------------------------|--|----|------|----|------------|----|----|----|-----| \$1-S8 - Status bits SROS - Bus in Service Request State #### Serial Poll Register (Write) | S8 | rsv | S6 | S5 | S4 | S3 | S2 | S1 | |----|-----|----|----|----|----|----|----| | | | | | | | | | \$1-\$8 - Status bits rsv - Generate a service request Parallel Poll Register R6W — This register will be loaded by the MPU and the bits in this register will be delivered to the instrument but IBO-IB7 during PPAS (Parallel Poll Active State). This register powers up in the PPO (Parallel Poll No Capability) state. The reset bit (Auxiliary Command Register bit 7) will clear this register to the PPO state. The parallel poll interface function is executed by this chip using the PP2 subset (Omit Controller Configuration Capability). The controller cannot directly configure the parallel poll output of this chip. This must be done by the MPU. The controller will be able to indirectly configure the parallel poll by issuing an addressed command which has been defined in the MPU software. # Parallel Poll Register (Write Only) | PP8 | PP7 | PP6 | PP5 | PP4 | PP3 | PP2 | PP1 | |-----|-----|-----|-----|-----|-----|-----|-----| Bits delivered to bus during Parallel Poll Active State (PPAS) Register powers up in the PPO state Parallel Poll is executed using the PP2 subset Address Mode Register R2W — The address mode register is a storage register with six bits for control: to, lo, hlde, hlda, dsel, and apte. The to bit 6 selects the talker/listener and addresses the chip to talk only. The lo bit 5 selects the talker/listener and sets the chip to listen only. The apte bit 0 is used to enable the extended addressing mode. If apte is set low, the device goes from the TPAS (Talker Primary Address State) directly to the TADS (Talker Addressed State). The hlda bit 2 holds off RFD (Ready for Data) on ALL DATA until rfdr is set true. The hlde bit 3 holds off RFD on EOI enabled (low) and ATN not enabled (high). This allows the last byte in a block of data to be continually read as needed. Writing rfdr true (high) will allow the next handshake to proceed. #### Address Mode Register (Write Only) | dsel | to | lo | Х | hdle | hdla | х | apte | |------|----|----|---|------|------|---|------| dsel — Configure for automatic completion of handshake sequence on occurrence of GET, UACG, UUCG, SDC, or DCL commands to — Set to talk-only mode. lo — Set to listen-only mode. hdle — Hold-off RFD on end. note — Hold-off RFO on all data. Hola — Hold-off RFO on all data. apte — Enable the address pass-through feature. Address Status Register R2R — The address status register is not a storage register but simply an eight-bit port used to couple internal signal nodes to the MPU bus. The status flags represented here are stored internally in the logic of the chip. These status bits indicate the addressed state of the talker/listener as well as flags that specify whether the chip is in the talk only or listen only mode. The ATN, bit 4, contains the condition of the Attention Line. The ma signal is true when the chip is in: TACS — Talker Active State TADS — Talker Addressed State LACS — Listener Active State LADS — Listener Addressed State SPAS — Serial Poll Active State #### Address Status Register (Read Only) ma — My address has occurred. to - The talk-only mode is enabled. The listen-only mode is enabled. ATN — The Attention command is asserted. TACS - GPIA is in the Talker Active State. LACS - GPIA is in the Listener Active State. LPAS — GPIA is in the Listener Primary Addressed State. TPAS - GPIA is in the Talker Primary Addressed State. Address Switch Register R4R — The address switch register is external to the chip. There is an enable line (ASE) to be used to enable three-state drivers connected between the address switches and the MPU. When the MPU addresses the address switch register, the enable line directs the switch information to be sent to the MPU. The five least significant bits of the eight-bit register are used to specify the bus address of the device, and the remaining three bits may be used at the discretion of the user. The most probable use of one or two of the bits is for controlling the listener only or talk only functions. #### Address Switch Register (Read Only) | UD3 UD2 UD | AD5 AD4 | A03 A02 | AD1 | |------------|---------|---------|-----| |------------|---------|---------|-----| AD1-AD5 — Device address. UD1-UD3 — User definable bits. When this "register" is addressed, the $\overline{ASE}$ pin is set, allowing external address switch information from bus device to be read. Address Register R4W — The Address Register is an eight-bit storage register. The purpose of this register is to carry the primary address of the device. The primary address is placed in the five least significant bits of the register. If external switches are used for device addressing, these are normally read from the Address Switch Register and then placed in the Address Register by the MPU. AD1 through AD5 bits 0.5 are for the device's address. The Isbe bit 7 is set to enable the Dual Primary Addressing Mode. During this mode, the device will respond to two consecutive addresses, one address with AD1 equal to 0 and the other address with AD1 equal to 1. For example, if the device's address is HEX 0F, the Dual Primary Addressing Mode would allow the device to be addressed at both HEX 0F and HEX 0E. The dal bit 6 is set to disable the listener and the dat bit 5 is set to disable the talker. This register is cleared by the Reset input only (not by the reset bit of the Auxiliary Command Register bit 7). When $\overline{\text{ATN}}$ is enabled and the primary address is received on the $\overline{\text{IB0-7}}$ lines, the S68488 will set bit 7 of the address status register (ma). This places the S68488 in the TPAS or LPAS. When $\overline{ATN}$ is disabled, the GPIA may go to one of three states: TACS, LACS or SPAS. #### Address Register (Write Only) | Isbe del dat ADS AD4 AD3 AD2 AD1 | |----------------------------------| |----------------------------------| Isbe — Enable dual primary addressing mode. dal — Disable the listener. dat - Disable the talker. AD1-AD5 - Primary device address, usually read from address switch register. Register is cleared by the Reset input pin only. Auxiliary Command Register R3R/W — Bit 7, reset, initializes the chip to the following states: (Reset is set true by external Reset input pin and by writing into the register from the MPU.) SIDS — Source Idle State AIDS — Acceptor Idle State TIDS — Talker Idle State LIDS — Listener Idle State LOCS - Local State NPRS — Negative Poll Response State PPIS — Parallel Poll Idle State $PUCS \quad -Parallel \ Poll \ Unaddressed \ to \ Configure$ State PPO — Parallel Poll No Capability rfdr (release RFD handshake) bit 6 allows for completion of the handshake that was stopped by RFD (Ready for Data) holdoff commands hlda and hlde. fget (force group execute trigger) bit 0 has the same effect as the GET (Group Execute Trigger) command from the controller. rtl (return to local) bit 2 allows the device to respond to local controls and the associated device functions are operative. dacr (release DAC handshake) bit 4 is set high to allow DAC to go passively true. This bit is set to indicate that the MPU has examined a secondary address or an undefined command. ulpa (upper/lower primary address) bit 1 will indicate the state of the LSB of the address received on the DIO1-8 bus lines at the time the last Primary Address was received. This bit can be read but not written by the MPU. msa (valid secondary address) bit 3 is set true (high) when TPAS (Talker Primary Addressed State) or LPAS (Listener Primary Addressed State) is true. The chip will become addressed to listen or talk. The primary address must have been previously received. RFD, $\overline{DAV}$ , DAC (Ready for Data, Data Valid, Data Accepted) bits assume the same state as the corresponding signal on the S68488 package pins. The MPU may only read these bits. These signals are not synchronized with the MPU clock. dacd (data accept disable) bit 1 set high by the MPU will prevent completion of the automatic handshake on Addresses or Commands, dacr is used to complete the handshake. feoi (forced end or identify) bit 5 tells the chip to send $\overline{EOI}$ low. The $\overline{EOI}$ line is then returned high after the next byte is transmitted. NOTE: The following signals are not stored but revert to a false (low) level one clock cycle (MPU $\phi$ 2) after they are set true (high): - 1, rfdr - 2. feoi - 3. daer These signals can be written but not read by the MPU. #### **Auxiliary Command Register** | DECET | rfdr | feoi | daer | | m | dacd | | WRITE | |-------|------|------|------|-----|---|------|------|-------| | NESE! | DAC | DAV | RFE | msa | m | ulpa | TGRT | READ | reset - initialize the chip to the following status: (1) all interrupts cleared (2) following bus states are in effect: SIDS, AIDS, TIDS, LIDS, LOCS, PPIS, PUCS, and PPO (3) bit is set by Reset input pin msa — if GPIA is in LPAS or TDAS, setting msa will force GPIA to LADS or TADS rtl - return to local if local lockout is disabled ulpa - state of LSB of bus at-last-primary address receive time fget - Force group execute trigger command from the MPU has occurred rfdr - continue handshake stopped by RFD holdoff feoi - set EOI true, clears after next byte transmitted dact - MPU has examined an undefined command or secondary address dacd — prevents completion of automatic handshake on Addresses or Commands Command Status Register R1R — The command status register flags commands or states as they occur. These flags or states are simply coupled onto the MPU bus. There are five major address commands. REM shows the remote/local state of the talker/listener. RLC bit 3 is set when a change of state of the remote/local flip-flop occurs and reset when the command status register is read. DCAS bit 1 indicates that either the device clear or selected device clear has been received activating the device clear function. SPAS bit 2 indicates that the SPE command has been received activating the device serial poll function. UACG bit 7 indicates that an undefined address command has been received and depending on programming the MPU decides whether to execute or ignore it. UUCG bit 0 indicates that an undefined universal command has been received. # Command Status Register (Read) UACG - Undefined Addressed Command REM - Remote Enabled LOK - Local Lockout Enabled RLC - Remote/Local State Changed SPAS - Serial Poll Active State is in effect DCAS - Device Clear Active State is in effect DUCG - Undefined Universal Command Command Pass-Through Register R6R — The command pass-through is an eight-bit port with no storage. When this port is addressed by MPU it connects the instrument data bus ( $\overline{\text{IBO-IB7}}$ ) to the MPU data bus D0-D7. This port can be used to pass commands and secondary addresses that aren't automatically interpreted through to the MPU for inspection. # Command Pass-Through Register (Read Only) | В7 | <b>B</b> 6 | B5 | В4 | <b>B</b> 3 | B2 | B1 | В0 | | |----|------------|----|----|------------|----|----|----|--| An eight-bit input port used to pass commands and secondary addresses to MPU which are not automatically interpreted by the GPIA. UART PIN/PACKAGE CONFIGURATION (Available in Pkgs. 3M, 1T · see Sec. 1) #### **FEATURES** - 12.5 K Baud Data Rates - 5-8 Bit Word Length - Parity Generation/Checking Odd, Even, None - Framing and Overflow Error Detection - 1, 1.5, or 2 Stop Bits - Double Buffered Input/Output - Independent Transmit/Receive Rates - Start and Stop Bits Generated and Detected - interchangeable with TMS6011, COM2017, TR1602, AY-5-1013 - Tri-State Outputs #### FUNCTIONAL DESCRIPTION The S1883 Universal Asynchronous Receiver Transmitter (UART) is a single chip MOS/LSI device that totally replaces the asynchronous parallel to serial and serial to parallel conversion logic required to interface a word parallel controller or data terminal to a bit serial communication network. For asynchronous data transmission with a non-contiguous data bit stream, the UART automatically inserts a START bit preceding each character and under program control 1, 1.5, or 2 stop bits at the end of each character. To detect incoming characters in a noisy environment the UART employs a START bit detection network and allows errorless recovery of data with up to 42% distortion. The UART will transmit or receive data characters of 5, 6, 7, or 8 bit length. Options allow the generation and checking of odd, even parity or no parity. The odd or even parity bit is automatically added to the character length for transmission. (USRT) #### FUNCTIONAL DESCRIPTION The S2350 Universal Synchronous Receiver Transmitter (USRT) is a single chip MOS/LSI device that totally replaces the serial to parallel and parallel to serial conversion logic required to interface a word parallel controller or data terminal to a bit-serial, synchronous communication network. The USRT consists of separate receiver and transmitter sections with independent clocks, data lines and status. Common with the transmitter and receiver are word length and parity mode. Data is transmitted and received in a NRZ format at a rate equal to the respective input clock frequency. Data messages are transmitted as a contiguous character stream, bit synchronous with respect to a clock and character synchronous with respect to framing or "sync" characters initializing each message. The USRT receiver compares the contents of the internal Receiver Sync Register with the incoming data stream in a bit transparent mode. When a compare is made, the receiver becomes character synchronous formatting a 5, 6, 7, or 8 bit character for output each character time. The receiver has an output buffer register allowing a full character time to transfer the data out. The receiver status outputs indicate received data available (RDA), receiver overrun (ROR), receive parity error (RPE) and sync character □ Plugs into MDC-100 ☐ Data-dependent clock ☐ Outbound trigger ☐ Trace memory hold 1024 steps ☐ All patterns 40 channels wide ☐ Two separate event qualifiers # AMI Microcomputer **Development Center** An intelligent stand-alone software debugging station, serving completely the combined needs of the design engineer and the programmer. It consists of a \$6800 based CRT/keyboard microcomputer terminal, a dual drive floppy disk memory, and an optional hard copy printer. A program in development (or in operation) can be viewed on the CRT and edited on the keyboard. Program files can be assembled and stored in the floppy disk memory, under control of the disk memory operating system software. The modular bus oriented card cage in the CRT terminal provides versatile facilities for developing and testing 6800 hardware. Board to provide a direct link between the MDC and the user's prototype. As stand-alone systems, the S2000 designer can use the capabilities of either the low-cost SES-2000 hardware emulator - which is a pin-for-pin substitute for an S2000 microcomputer chip and contains its own EPROM memory - or the TES-S2000 functional go/no-go tester. #### CRT/Keyboard Terminal Floppy Disk Memory □ Capability for generating 256 unique ASCII input ☐ IBM 3740 data format compatible characters ☐ Data storage capacity of 256,256 bytes per ☐ 12-inch diagonal CRT display — 25 lines of 80 diskette characters ☐ Fully supported by FDOS-II Disk Operating and ☐ 16K bytes of user available RAM, expandable to File Management System software Optional Matrix Printer ☐ Full cursor and editing controls □ 132 column □ Special function controls Dot matrix, impact printing ☐ Peripheral interconnects ☐ 120 or 180 characters per second Logic Analyzer S2000 Support ☐ General-purpose logic analyzer S2000 Designers can use the DEV-2000 Development # **MDC** Hardware Capabilities The AMI MDC is a multifunction development center that single-handedly satisfies your requirements for software development, hardware development, and prototype checkout. The MDC can also double as a stand-alone communications terminal, a general purpose data processing system, or as an incoming parts tester. Software Development — write, debug and operate S6800 and S2000 programs on the CRT terminal, using its internal RAM and the dual drive floppy disk for storage. The MDC comes with a full complement of support software, including the FDOS-II Disk Operating and File Management System, a Text Editor, an Assembler, Debugger, Trace, Telecommunications and Utilities. Hardware Development — breadboard such cicruitry as interfaces or memories right on the MDC wirewrap prototyping board and plug into the CRT terminal card cage to operate with the MDC's \$6800-based central processor in solving development problems. Use the control panel type functions of the CRT terminal for single step, stop-on-address, display, alter, and other similar program operations. The bus oriented card cage, position interchangeable plug-in card modules, and an extender card provide the flexibility to make hardware development easy. There is also a complete keyboard control led PROM programmer within the CRT terminal. **Prototype Checkout** — with the advantages of a realtime test environment, rapid test program retrieval, single or multiple step execution, and hardware as well as software breakpoints, the checkout of prototype S2000 and S6800 circuitry is easy and efficient. Stand-alone Communications Terminal — the CRT terminal has both RS-232 and current loop interfaces, supported by telecommunications firmware, for operation as a general purpose stand-alone intelligent terminal. # **MDC Software Capabilities** The AMI MDC offers total facilities for rapidly developing applications and systems software. The entire MDC software system is at the user's instant disposal — a few simple keystrokes are needed to instantly access and execute any program. The FDOS-II disk based operating system provides complete system resource control to the programmer. FDOS-II Disk Operating and File Management System — contains a resident module for bootstrapping the floppy disk memory and for disk I/O handling. It also contains an executive that performs all of the disk memory command line interpretations, file management and operational functions of the dual disk system. In addition, there are utility I/O and EPROM programming routines in FDOS-II. The Text Editor — program provides the means for rapidly creating, examining and modifying stored files. The total capability of MDC's Text Editor exceeds that of many large minicomputer systems, and includes such features as storing searches and string substitutions. The Symbolic Assembler — translates assembler language statements into executable machine language code. In conjunction with FDOS-II Operating and File Management Systems, assembling has been reduced to a series of simple operator keystrokes. Results of the assembly, automatically stored on disk, are immediately available for reference or execution. MDC's Extensive Debug Program — effectively automates the functions of a computer control panel. Given control by simply pressing the DEBUG key or via program traps, Debug immediately responds with the display of machine and program status. Addition functions include: Register/data display and modification Instruction/subroutine step User definable debug macros Snapshot debug data of a running program Breakpoints (stop-on-address compare) Comment and header line displays MDC's Trace Package — gives Debug the ability to display a trace of machine register contents, instruction mnemonics and operands before execution of any instruction or subroutine in the user's program. Microprocessor debugging has never been made easier. MDC's Test Programs — are a set of self-test and diagnostics which verify that the hardware associated with the MDC is operating correctly. The programs are also helpful in isolating malfunctioning components. The program for testing the basic hardware is resident in EPROM and is activated by the keyboard TEST key. # MICROCOMPUTER BOARDS/KITS #### **Features** - ☐ Expandable to 4K Bytes ROM - ☐ Expandable to 2K Bytes EPROM - ☐ Expandble to 1K Bytes RAM - ☐ EPROM Programming for S6834 - ☐ Expandable to 3 PIA's = 58 I/O Lines - ☐ TTY Current Loop or RS232 Interface - □ ROM Subroutine Program Library - □ Selectable DMA Mode #### **General Description** The EVK Series Board is a single PCB, hardware/software system that can be used as a general purpose microcomputer. It allows system development using a functionally compatible system and reduced development time. With this system the basic 6800 family of parts can also be evaluated. The 10-1/2"x12" card has two edge connectors, one for the MPU Bus and one for the I/O. The EVK 300 is a fully assembled and tested board, while the EVK 200, EVK 100 and EVK 99 are in kit form. All kits are fully expandable to EVK 300 capabilities. #### System Specifications All of the S6800 microprocessor lines are available at the bus edge connector and are buffered to allow 40mA of drive capacity for expanding the development system. The standard system clock is adjustable from 300kHz to 1MHz by using the potentiometers on the board. An optional 1MHz crystal may be selected to control the accuracy for those applications requiring critical timings. An on-board interval timer gives 1ms and 100µs timing marks for general use and for EPROM programming. Three types of DMA operation are possible using the EVK Board: Halt Processor, Cycle Steal or Multiplexing. #### Memory Memory and I/O addresses are assigned to the upper 8K bytes of the available memory space. (See memory map for address assignments.) This gives the system developer the flexibility to use the remaining 56K bytes as he wishes. All of the memory and I/O on the board may be disabled externally by an edge connector line called MEMORY DISABLE, leaving the MPU free to operate totally in an external memory. The S6830 ROMs contain the Prototype Operating Library (PROTO) and a ROM Subroutine Library (RS)<sup>3</sup>. An optional Assembler/Disassembler (M/AD) S6831 ROM is available to operate with PROTO. The 2K of EPROM locations may also be used for program verification. The RAM is assigned to the upper 1K of available memory space. The PROTO and (RS)<sup>3</sup> programs require about 256 bytes of this RAM so the rest is available for general programming. With all restart vectors automatically assigned to the upper memory addresses, restart vectoring is forced from a set of 16 switches. This allows the restart address to be vectored to any memory location. The RAM has further been divided into two 512 byte sections such that the upper 512 bytes remain fixed in the assigned address block and the lower 512 bytes are moveable through a switch selection option. 512 bytes of RAM are relocatable to the lowest address space to take advantage of the \$6800's direct addressing mode. This is only recommended if no external memory is added. When adding external memory, it is advisable to use the RAM in the upper address space and the external memory as the low addresses. #### 1/0 An S6850 ACIA is used to provide a 20mA current loop interface to a TTY or RS232 terminal. A 20mA current loop interface and an EIA RS232 interface are both available on the board. A bit rate generator allows operation using any of the standard communication frequencies (see table) so a large variety of terminal types can be used. Three S6820 PIAs allow up to 58 I/O lines, giving flexibility in I/O through the parallel interfaces. #### **EPROM Programming** Unique to the AMI EVK Board is the ability to program S6834 EPROMs (512 x 8) on the board. The programming software can program an EPROM from any memory location, RAM, ROM or EPROM. It can verify a word and, if desired, change a single bit in the EPROM, provided that the change is from LOW to HIGH. #### Software The EVK Board Software is comprised of a TTY Operating Program (PROTO) and is supported by a ROM Subroutine Library (RS)<sup>3</sup>. #### **EVK Capabilitles** | | | | | | | | · | | | | | | |---------|-------------|--------------|--------------|-----|---------------------|------------------------------------|----------------------------------|--------------------|---------------------------------|-----------------------------|-------------------|---------------| | | ROM | RAM | EPROM | PIA | TTY<br>CURR<br>LONP | ROM<br>SUB-ROUTINE<br>PROG LIBRARY | TOTALLY<br>BUFFERED<br>MPU LINES | SGL<br>+5V<br>P.S. | BESTART<br>ADDRESS<br>SELECTION | SELECT-<br>ABLE<br>DMA MODE | INTERVAL<br>TIMER | TINY<br>BASIC | | EVK 99 | 2K<br>bytes | 512<br>bytes | | 1 | | | - | 1/ | | | | , | | EVK 100 | 2K<br>bytes | 512<br>pytes | | | | | - | - | - | | | | | EVK 200 | 4K<br>bytes | 1X<br>bytes | 512<br>hytes | 3 | _ | - | - | , | - | 10 | | | | EVK 300 | 4K<br>hytes | i K<br>bytes | 2K<br>bytes | 3 | 10 | | - | | - | 10 | | 1,, | <sup>\*</sup>AMI 6800 Tmy BASIC <sup>-</sup> A high level interpretive language derived from the standard (actinionth BASIC, Furnished to EVK 300 users at an charge upon submittal of warranty registration. AMI's S2000 Family Compared to Other Major Low-End Single-Chip Microcomputers | | | | | | MEM | ORY | | | | | | | INPU | T/OUTP | UT | | | | | | | | IARE TH | AT SAYE | S ROM : | SPACE | | DEVELO | PMENT | SYSTEMS | (\$8K - \$15K | |--------------|-----------|----------|------------------------------------------|----------------------------------------|----------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------|----------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------|------------------------|-----------------------|------------------------|---------------|---------------------|---------------| | | | / | T. T | ************************************** | Cr. Cr. Marketi. Am. | CE THE CASE. | Commence of the Control Contr | | The Control of Co | Salvania de la constanta | A COMPANY OF THE PARTY P | A COLOR OF THE SECTION SECTIO | TOWN THES | Strate 1 | Singular Singular | The Control of Co | CONTROL CONTROL | WOULD THE PARTY TO THE PARTY PAR | | /Second Second | Percentant Control Control | | San Carlon Carlo | Sug List Man | 17 17 M | | | ASSERVED ON THE PARTY. | Son Transport | (Mark Significance) | i decembra | | | \$2000 | 16 | 64x4 | YES | 4,5 | - | - | ı | - | YES | ı | 50/60 | 9 | 13 | 8 | YES | YES | 2000A | - | YES | 3 | 2 | 256 | _ | 49 | YEŞ | YES | YES | YES | YES | | | AMI | \$2150 | 1.5K | B0x4 | YES | 4.5 | _ | - | ١ | _ | YES | | 54/80 | 9 | 13 | | YES | YES | 2150A | _ | YES | 3 | 2 | 320 | _ | 49 | YES | YES | YES | YES | YES | | | | \$2200 | 2K | 128x4 | YEŞ | 4.5 | 6 BJT | 45 | | YES | YES | YES | PROG | U | 13 | 24 | YES | YES | 2200A | 3 | YES | 5 | 6 | 512 | YES | 59 | YES | YES | YES | YES | YES | | | | S2400 | 4K | 128x4 | YES | 4.5 | 8 BIT | 45 | 8 | YES | YES | YES | PROG | 0 | 13 | 24 | YES | YES | 2490A | 3 | YES | 5 | 6 | 512 | YES | 59 | YES | YES | YES | YES | YEŞ | | | | | <u> </u> | | _ | | ļ | | | | | | | | | | | | | | | | | _ | | | | <u> </u> | | | | | | INTEL | 8421 | 1K | 64x8 | NO | 10.0 | _ | _ | _ | | YEŞ | _ | BEIT | 0 | • | 20 | _ | _ | _ | - | - | 8 | 0 | 0 | YES | 65+ | YES | YES | YES | AEZ | | | | | 8022 | 2K | 64x8 | NO | 10.0 | \$ BIT | 4D | 2 | _ | YE\$ | _ | B BIT | 0 | 0 | 24 | | | _ | - | ļ <del>.</del> | . 8 | 0 | 0_ | YES | 65+ | AEE | YES | AE2 | YES | - | | | | MK 3878 | 2K | 8418 | NO | 2.0 | _ | _ | _ | _ | _ | _ | 8 BIT | 0 | 0 | 32 | _ | YES | | _ | ļ. — | . 1 | 4 | 0_ | YE\$ | 60+ | | YES | YEŞ | YES | | | | | MK 3876 | 2K | | NO | 2.4 | | | _ | _ | | _ | B BIT | D | 0 | 32 | | YES | _ | _ | _ | 1 | 4 | 0 | YES | 60+ | _ | YES | TES | YES | _ | | | ******** | MK 3672 | 4K | 120x8 | NO. | 2.0 | _ | _ | _ | _ | _ | _ | â BIT | 0 | 0 | 35 | _ | YES | _ | _ | _ | 1 | 4 | | YES | 6D+ | _ | YES | 83Y | YES | _ | | | MOTOROLA | B885 | 1.1K | 54x8 | NO | 2.1 | _ | | _ | | _ | | â BIT | • | | 20 | _ | _ | _ | _ | _ | MAR | 5 | YES | _ | 58 | YES | YES | YES | YE\$ | - | | | MATIONAL | COP 410L | 512 | 3214 | NO | 16.0 | <u> </u> | _ | _ | _ | _ | _ | _ | 0 | 4 | 12 | | YE\$ | | | $\vdash$ | 2 | 0 | 128 | NO | 43 | YES | YES | YES | _ | | | | NATIONAL | CDP 420 | 1K | 64x4 | NO | 4.0 | _ | _ | | _ | _ | _ | _ | 4 | 4 | 12 | _ | YES | _ | 1 | _ | : 3 | D | 255 | NO | 57 | YES | YE\$ | YES | | _ | | | | COP 440 | 2K | 128x4 | MO | 4.0 | _ | _ | _ | _ | | _ | _ | В | 8 | . 18 | _ | YES | _ | 1 | _ | 3 | 0 | 512 | NÓ | THA | YES | YES | YES | _ | | | | | MM 75 | 640 | 4824 | NO_ | 12.5 | <u> </u> | | . – | - | _ | _ | | 5 | 0 | . 17 | . – | ! =_ | YE\$ | _ | YES | 1 | D | 192 | YES | 69 | CHT | YES | YES | YES. | _ | | | ROCKWELL | 14M 76E | 1K | 4814 | NG | 12.5 | 1- | | - | _ | 1 | _ | _ | 11 | 2 | 18 | _ | _ | YES | _ | YES. | 1 | 0 | 192 | YES | 69 | CAT<br>CAT | YES | YES | YES | | | | | MM 77 | 1.3K | 9614 | NG | 12.5 | <u> </u> | _ | _ | _ | _ | . – | ļ. <u> </u> | 11 | 2 | 18 | _ | | YES | _ | - | 2 | 0 | 384<br>512 | YES | 69 | #0<br>CHT<br>10<br>CRT | YES | YES | YES | - <u>-</u> | | | <del>.</del> | MM 78 | 2K | 12814 | NO | _ | - | - | _ | _ | | _ | _ | 11 | 2 | 18 | | YES | _ | _ | - | 2 | 0 | _ | | 43 | _ | | _ | - | _ | | | TEXAS | TMS 1000 | 1K<br>1K | 5414 | NQ | 15.0<br>15.0 | _ | _ | _ | _ | _ | | _ | 4 | 19 | 0 | _ | <u> </u> | YES | | PLA | 1 | 0 | 256<br>256 | MD | <br>43 | - | TAPE<br>TAPE<br>PAPER | YES | <u> </u> | | | | INSTRUMENTS | TM\$ 1270 | | 54x4 | NO | | ⊢ | | | _ | _ | | | • | ⊢ | _ | _ | YES | 100 | <u> </u> | PLA | H | | 512 | MO | 55 | <u> </u> | TAPE | YES | | _ | | | | TMS 1300 | 2K | 128k4 | NO | 15.0 | _ | _ | _ | _ | _ | _ | _ | • | 24 | Œ | _ | 160 | | | FLA | ' | 0 | 21Z | nu | 100 | _ | PAPER | rEO | _ | | | #### 62000 FAMILY DESIGN SUPPORT The S800 single only microcomplete is fully supported by a proven army of development after this methods. A M13 Magnor of the province and the microcomplete continues and the second continues and the second continues and the second continues and the second continues and the second continues and the second continues by AMI Applications Engineering staff. Microscoppine Chapters Live Heat? Add McCr. s. tall year-pay, dashbast rezemanyus de telepase Live Heat in Heat? Add McCr. s. tall year-pay, dashbast rezemanyus de telepase Live Heat in He Development Schreum AFDC's stablard sefenare nethines a tremperhanium frost-liquid and REUM Programmer packing their empore Schlott arrival development. In audition, approximated Schlott Schlott schreider as MACRO-Assemites. Lander, and a soph second hipproximadevelopment. Cost astendion, commission methodologistics at the available on a major interhang senses SES-2000 Emplator Sourd The SES-2000 Person for again the pin does join sold tage for a SESA in concern place does whether controlled and for a SESA in concern place does whether controlled and particular controlled and in the SESA in the Controlled and particular controlled and in 18 MIN district surprace with making proper managers. For high militage policy in the SES 2001A27776, province destinance united these are with funmental day pays. Customer Assertance AMC 92002 Applications Engineering staff are e-villable for resolutions or gazeng all appropria? SAGD usage, AMC 3 varies there is alternational orderes as any species modifications in the SAGD for the high volume applications. MDC-HB Lage Analyzer The MDC-HB Lage Analyzer Gothelded to a perspectful device of the AHI M-(costingue) Devi Approvi Corne (MDC) | Features instante - CL Control 804 Premior CO Parallel Inguis - Topians their Order Control of Programmatic Startes Detailed to Control Detailed to 4666 Class Pendos - Scrupuse Display of Captures Data Under Computer MIX: Sciences MILE, Servage. Dup by her mains (Josefathach e., Capaured Data Can the languaged marking of time, threat. Binners, ASCII and Spotral of main for Support of Sig00, S0520, S2000. Sig1(4) as - mint, as: U han U nak Samanas U han U nak Samanas U lapan Wilaya Ranga A = 10 m =45 min U Adjustoka nga Harsholds U Dana Dependent (Japan for Praggerin) an Gacillenense American Microsystems, Inc. 3800 Humestead Road Santa Clara, Califernia 95051 (408) 246-0330 TWX 910-338-0018 # S2000 Family October 1978 # S2000 SINGLE-CHIP MICROCOMPUTER FAMILY #### S2000 Single-Chip Microcomputer Family AMI's S2000 family of single-chip microcomputers offers a wide range of capability to the user seeking flexible, adaptable system(s) at low cost. The S2000 family provides the ideal solution to appliance and industrial/process-control applications. With versatile keyboard-oriented inputs, and outputs which can drive either LED or fluorescent displays directly, the S2000 family is designed specifically to minimize system parts count and cost. Table I. \$2000 Family Features | " | \$2000 | S2150 | \$2200 | S2400 | |--------------------------------------------------------|---------|---------|--------|---------| | ROM (x8) | 1K | 1.5K | 2K | 4K | | RAM (x4) | 64 | 80 | 128 | 128 | | Interrupts | _ | _ | 3 | 3 | | A/D CONV (8 Channel) | _ | | 8-Bit | 8-Bit | | Counter/Timer | ÷50/+60 | +50/+60 | 8-Bit | 8-Bit | | Max Subroutine Levels | 3 | 3 | 5 | 5 | | Instructions | 51 | 51 | 59 | 59 | | Cycle Time (µs) | 4.5 | 4.5 | 4.5 | 4.5 i | | High Voltage<br>(Fluorescent Display<br>Drive Version) | S2000A | S2150A | S2200A | \$2400A | The S2000 family provides the advantages of computer architecture to low cost, minimum-parts-count display/keyboard oriented control systems. #### \$2000/2150 Features 4V - 82150 | 74 | 00017100 L 00f0162 | |----|-------------------------------------------------------------------------| | | 1024 x 8 Program ROM On-Chip; Externally Expandable to 8192 x 8 — S2000 | | | 1536 x 8 Program ROM On-Chip; Externally Expandable to 8192 x 8 — S2150 | | | 64 x 4 Scratchpad RAM On Chip - S2000 | | | 80 x 4 Scratchpad RAM On-Chip - S2150 | | | 13 Outputs and Inputs, Plus 8 Bi-Directional<br>Three-State Lines | | | Touch Control <sup>™</sup> Capacitive Touchplate Interface | | | Seconds Timer for Both 60Hz and 50Hz Lines | | | 7-Segment Decoder and LED Display Drivers<br>On Chip | | П | Single 9.0 Volt Supply | | | Fast 4.5 µs Execution Cycle | | | Three-Level Subroutine Stack | | | TTL-Compatible Outputs | | | Reset, Test, and Single Step Modes | | | Access to All Internal Registers and Memory | □ Crystal Input for Accurate Clocking - S2150 □ Low Power RAM Retention, 20μA/Bit Typ @ #### S2000A/2150A Vacuum Fluorescent Display The S2000A/2150A are identical to the S2000/2150 but provide high voltage fluorescent display capability. The output buffer drive $(V_{DD})$ is changed to a vacuum fluorescent drive $(V_{FD})$ and typically tied to 32 volts. The $D_0$ through $D_7$ and $A_0$ through $A_4$ are changed from LED drivers (nominal 5 volts) to vacuum fluorescent drivers (nominal 26 volts). #### \$2200/2400 Features The S2200/2400 provide a quantum jump in chip features beyond the S2000. In addition to all the features the S2000 offers, the S2200 gives the added flexibility of interrupts and the sophistication of an onchip A/D or D/A converter capable of multiplexing 8 channels of analog data making it suitable for a wide range of applications. | | 2048 x 8 Program ROM On Chip Expandable<br>to 8192 x 8 — S2200 | |--------|---------------------------------------------------------------------------------------| | П | 4096 x 8 Program ROM On-Chip; Externally<br>Expandable to 8192 x 8 — S2400 | | $\Box$ | 128 x 4 Scratchpad RAM On Chip | | | RAM Save Power Down Mode (Mask Option) | | | Two-Level Maskable Priority Interrupt<br>System with Provision for Software Interrupt | | | Programmable 8-Bit Timer/Event Counter On<br>Chip | | | 13 Outputs, 9 Inputs, Plus 8 Bi-Directional<br>Three-State Lines | | | Touch Control <sup>TM</sup> Capacitive Switch Interface | | | 7-Segment Display Decoders and LED Drivers | | | TTL-Compatible Outputs | | | Single + 9V Power Supply | | | 4.5 µs Cycle Time | | | 59 Instructions — 52 Single Byte and Single Cycle | | | 3-Level Subroutine Stack | | | 2-Level Interrupt Stack | | | Built-In Production Test Mode | | | Single-Step Capability | | | Power-Fail Detect, RAM Keep-Alive and<br>Power-On Reset Circuitry | | | 8-Bit A/D Converter (Up to 8 Channels) | | | D/A Converter Capability (Mask Option) | | | Up to 256 General Purpose Flags | | | 6 Special Flags | | | Table Look-Up Capability | | | S2200A/2400A Vacuum Fluorescent Display | Capability #### S2000 Family | | S2000 | S2000A | S2150 | S2150A | S2200 | S2200A | 82400 | S2400A | |-------------------------------------|---------|---------|---------|---------|-----------|-----------|-----------|-----------| | Product<br>Characteristics | | | | | | | | | | ROM (Bytes) | 1 K | 1K | 1.5K | 1.5K | 2K | 2K | 4K | 4K | | RAM (Nibbles) | 64 | 64 | 80 | 80 | 128 | 128 | 128 | 128 | | A/D Converter (8-Bit) | _ ; | _ | _ | _ | YES | YES | YES | YES | | Timer | 50/60Hz | 50/60Hz | 50/60Hz | 50/60Hz | PROG 8BIT | PROG 8BIT | PROG 8BIT | PROG 8BIT | | Interrupts | _ | _ | _ | _ | 3 | 3 | 3 | 3 | | Power Fail Detect | _ | _ | _ ' | _ | YES | YES | YES | YES | | High Voltage Outputs | | YES | _ | YES | _ | YES | | YES | | Crystal Clock Option | - | _ | YES | YES | YES | YES | YES | YES | | TouchControl Inputs | YES | Levels of Subroutine | 3 | 3 | 3 | 3 | 5 | 5 | 5 | 5 | | # of Flags | 2 | 2 | 2 | 2 | 262 | 262 | 262 | 262 | | Power Down<br>RAM Option | _ | _ | YES | YES | YES | YES | YES | YES | | D/A Converter Option | _ | _ | _ | _ | YES | YES | YES | YES | | Zero - Crossing<br>Detect | YES | Cycle Time (µsec) | 4.5 | 4.5 | 4.5 | 4.5 | 4.5 | 4.5 | 4.5 | 4.5 | | Instructions - Total | 51 | 51 | 51 | 51 | 59 | 59 | 59 | 59 | | Single Cycle & Byte | 49 | 49 | 49 | 49 | 52 | 52 | 52 | 52 | | Development Support | | · | L | | | | | · · | | Microcomputer<br>Development Center | YES | Logic Analyzer | YES | Hardware Emulator | #2150 | #2150A | #2150 | #2150A | #2400 | #2400A | #2400 | #2400A | #### S2000 Family Support The S2000 single-chip microcomputer family, unlike many microprocessors, does not leave the designer or industrial OEM unsupported. The S2000 Family features a proven array of development aids: Microcomputer Development Center (MDC) — AMI's MDC is a fully equipped, dual-floppy disk-based microcomputer development facility, complete with FDOS-II Floppy-Disk-Operating and File Management System. Controlled from its CRT terminal, MDC provides instant access to program and data files resident on removable diskettes. Development Software — The MDC's software includes selfdiagnostics and a comprehensive Text Editor and PROM programmer package that support \$2000 software development. In addition, \$2000 software includes a MACRO Assembler, Loader, and Instruction Simulator. Cross-Assemblers editor and simulator debug - Available on a major timesharing service. Logic Analytzer — The MDC-140 Logic Analyzer is an advanced debug tool connected as a peripheral device of the AMI Microcomputer Development Center (MDC). Features include: - -Captures 1024 Events of 40 Parallel Inputs - Captures Data Under Control of Programmable Start on Data Content - -Delay of 1024 to +64K Clock Periods - -Setup and Display of Captured Data Under Control of MDC - Display Format is User-Definable; Captured Data Can Be Displayed in a Mix of Hex, Octal, Binary, ASCII and Special Formats for Support of S6800, S6820, S2000, 8080, etc. - Four Clock Sources - -Input Voltage Range = -15 to +15 volts - -Adjustable Input Thresholds - Data-Dependent Output for Triggering an Oscilloscope SES-2150(A)/SES-2400(A) — The SES-2150/2400 Emulator boards are pin-for-pin substitutes for S2000 microcomputer family chips. The Emulator Boards use conventional UV erasable PROMs for program storage. In addition, a specialized module is used to provide emulation of the S2150A/S2400A high voltage vacuum fluorescent display drivers. Customer Assistance — AMI's S2000 Family Applications Engineering Staff is readily available for consultation regarding any aspects of S2000 Family usage. The AMI staff is also available to discuss any special modifications to the S2000 for high volume applications. # \$2000 Family Instruction Set Summary The S2000 and S2150 contain 51 instructions, all single byte, with 49 that are single cycle. The S2200 and S2400 contain 59 instructions, of which 52 are single cycle and single byte. Nearly all \$2000/2150 instructions are common to the entire family, which allows the programmer to develop software expertise and easily move up the \$2000 product line. #### Register Instructions | S2000/2150 | S2200/2400 | | |------------|------------|-----------------------------------------------------------------------------------------| | LAI X | LAI X | X-ACC, 0≤X≤15; (In S2000/2150 Select I and K Inputs also) | | LAB | LAB | BL-ACC . | | LAE | LAE | E-ACC | | XAB | XAB | BL ACC | | XABU | XABU | BU ACC, (IN S2150, BITS 2, 1, AND 0; IN OTHERS, BITS 1 AND 0 ONLY) | | XAE | XAE | ACC→E | | LBE Y | LBE Y | $Y \rightarrow BU, E \rightarrow BL, 0 \le Y \le 3$ | | LBZ Y | LBZ Y | $Y \rightarrow BU, 0 \rightarrow BL, 0 \le Y \le 3$ | | LBF Y | | $Y - BU, 15 - BL, 0 \le Y \le 3$ | | LBEP Y | | $Y \rightarrow BU, E \rightarrow 1 \rightarrow BL, 0 \le Y \le 3$ | | | SRB | 1-BA | | | RRB | 0-BA | | | LMDI X + | $X(6) \rightarrow BA$ , $X(5-4) \rightarrow BU$ , $X(3-0) \rightarrow BL$ | | | RAR | $ACC(I) \rightarrow ACC(I-1)$ , $ACC(0) \rightarrow CARRY$ , $CARRY \rightarrow ACC(3)$ | | | XAK | KSR ACC | | | LANG | ACC - AR (3 - 0), RAM - AR(7 + 4) | | | LNMA | $ACC \rightarrow NR(3-0)$ , $RAM \rightarrow NR$ (7 – 4), THEN $NR \rightarrow BIN$ | | | MOD | ACC - MOD(3 - 0), $RAM - MOD(7 - 4)$ | | | RBIN | $BIN(3-0) \rightarrow ACC$ ; $BIN(7-4) \rightarrow RAM$ | #### **RAM Instructions** | S2000/2150 | S2200/2400 | | |------------|------------|-----------------------------------------------------------------------| | LAM Y* | LAM Y* | RAM – ACC, BU ⊕ Y → BU | | XC Y* | XC Y* | RAM ACC, BU @ Y BU | | XCI Y* | XCI Y* | ACC-RAM, BL + 1-BL, BU $\oplus$ Y-BU SKIP IF BL = 0 (AFTER INCREMENT) | | XCD Y* | XCD Y* | ACC-RAM, BL-1-BL, BU & Y-BU SKIP IF BL = 0 (BEFORE DECREMENT) | | STM Z | STM Z | 1-RAM BIT Z, 0≤Z≤3 | | RSM Z | RSM Z | $0 \rightarrow RAM BIT Z, 0 \le Z \le 3$ | | | LMA | ACC-RAM | | | STMI Z ÷ | $1-RAM$ BIT Z, $0 \le Z \le 255$ , (RAM BANK 1) | | | RSMIZ+ | $0-RAM BIT Z$ , $0 \le Z \le 255$ , (RAM BANK 1) | #### Input/Output Instructions | S2000/2150 | S2200/2400 | | |------------|------------|---------------------------------------------------| | INP | IND | D3-D0-ACC, D7-D4-RAM | | OUT | OUT | ACC - D3-D0, RAM - D7-D4 (NOT LATCHED) | | DISN | DISN | ACC-SEGMENT DECODER-DISPLAY LATCH-D6-D0, | | | | CARRY-DISPLAY LATCH-D7 | | DISB | DISB | ACC-DISPLAY LATCH-D3-D0, RAM-DISPLAY LATCH-D7-D4 | | MVS | MVS | A-LINE MASTER STROBE LATCH A LINES | | PSH | PSH | PRESET HIGH [BL]-MASTER STROBE LATCH | | PSL | PSL | PRESET LOW [BL]-MASTER STROBE LATCH | | EUR | | (EUROPEAN) SET 50/60Hz AND DISPLAY LATCH POLARITY | | | INK | K3-K0 ACC, K7-K4 RAM | <sup>+8</sup> bits in the second byte of an instruction. <sup>\*</sup>Assembled code contains complement of those arguments (the assembler does it automatically). # S2000/S2150 and S2200/S2400 Instruction Set Summary # **Program Control Instructions** | S2000/2150 | S2200/2400 | | |------------|------------|----------------------------------------------------------------------------------------| | PP X* | PP X* | IF PREVIOUS INSTRUCTION = PP, X→PPR (0 ≤ X ≤ 15) | | | | IF PREVIOUS INSTRUCTION = PP, $X - PBR (0 \le X \le 7)$ | | JMP X | JMP X | JUMP TO LOCATION X, $X - LR$ ( $0 \le X \le 15$ ) | | | | EXCEPT IF PREVIOUS INSTRUCTION = PP | | JMS X | JMS X | JUMP TO SUBROUTINE AT X, LR + 1→L STACK, PR→P STACK, | | | | X-LR, 15-PR EXCEPT IF PREVIOUS INSTRUCTION = PP | | RT | RT | L STACK-LR, P STACK-PR | | RTS | RTS | L STACK→LR, P STACK→PR, SKIP INSTR. | | NOP | NOP | NO OPERATION | | | RTI | RETURN FROM INTERRUPT, RESTORE REGISTERS | | | TLU | IF PREVIOUS INSTRUCTION WAS A PP, DO A TABLE LOOK-UP | | | | SEQUENCE: | | | | PC+1-STACK | | | | $RAM \rightarrow PC(3-0)$ , $ACC \rightarrow PC(7-4)$ , $PPR(3-2) \rightarrow PC(9-8)$ | | | | ROM(7-4)-RAM, $ROM(3-0)-ACC$ | | | | STACK-PC. | | | | IF PREVIOUS INSTRUCTION WAS NOT A PP. DO AN INDEXED | | | | SUBROUTINE CALL: | | | | PC+1-STACK | | | | $RAM \rightarrow PC(3-0)$ , $ACC \rightarrow PC(7-4)$ | # Skip Instructions (Skip 1 Non-PP Instruction) (RAM = Memory at BU,BL) | S2000/2150 | S2200/2400 | | |------------|------------|-----------------------------------------------------------------------| | SZC | SZC | SKIP IF CARRY = 0 | | SZM Z | SZM Z | SKIP IF RAM BIT $Z = 0$ , $0 \le Z \le 3$ | | SZK | SZK | SKIP IF K BIT(S) = $0$ , (BIT(S) IN LAST LAI) | | SBE | SBE | SKIP IF $BL = E$ | | SAM | SAM | SKIP IF ACC = RAM | | SZI | | SKIP IF I $BIT(S) = 0$ , ( $BIT(S)$ IN LAST LAI) | | SOS | | SKIP IF SF = 1, 0 – SF. (SF = 'SECONDS' FLAG OUTPUT OF $\pm 50t + 60$ | | | | COUNTER) | | TF1 | | SKIP IF FLAG 1 = 1 | | TF2 | | SKIP IF FLAG 2 = 1 | | | SZMI Z + | SKIP IF RAM RIT = 0, (IN RAM BANK 1) $0 \le Z \le 255$ | | | SKFL X + | SKIP IF FLAG = 1 | # **Arithmetic and Logical Instructions** | S2000/2150 | S2200/2400 | | |------------|------------|------------------------------------------------| | ADCS | ADCS | RAM + ACC + CARRY → ACC + C, SKIP IF SUM ≤ 15 | | ADIS X | ADIS X | X + ACC→ACC, SKIP IF SUM ≤ 15, CARRY UNALTERED | | ADD | ADD | ACC + RAM → ACC, CARRY UNALTERED | | AND | AND | ACC & RAM ~ ACC | | XOR | XOR | ACC ⊕ RAM→ACC | | STC | STC | 1-CARRY | | RSC | RSC | 0-CARRY | | CMA | CMA | 15 - ACC - ACC (LOGICAL 1's COMPLEMENT ACC) | | SF1 | 1 | 1-FLAG 1 | | RF1 | | 0-FLAG 1 | | SF2 | İ | 1-FLAG 2 | | RF2 | | 0→FLAG 2 | | | SFLG X + | 1-FLAG X | | | RFLG X + | 0→FLAG X | <sup>+8</sup> bits in the second byte of an instruction <sup>\*</sup>Assembled code contains complement of those arguments (assembler does it for you). # Pin Descriptions — S2000/2150 | PIN NO. | NAME | DESCRIPTION | |--------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | $V_{SS}$ | Most negative power-supply input. Typically grounded. | | 29 | v <sub>GG</sub> | Most positive power-supply input. Typically +9V. | | 12 | V <sub>DD</sub> (S2000)<br>V <sub>FD</sub> (S2000A) | Power supply input for all output buffers. Typically tied to $V_{GG}$ or to a +5V supply. Power supply input for HV drive. Typically +32V | | $\begin{array}{c} 4 - 2, \\ 40 - 36 \end{array}$ | D0 - D7 | D Lines for input and output. Output during instructions OUT, DISN, DISB. Input during INP. Float at reset time or after an MVS instruction; or if RUN pin is low; or after a PSL with BL = 14. Display Latch outputs (DISN, DISB) can be inverted using EUR. | | 20 13<br>11 - 7 | A0 - A12 | A Lines for addressing and control. Changed by MVS as set up by PSH/PSL. When external program ROM is used, these lines output the contents of the Program Counter during the first half of each instruction cycle. | | 5 | ROMS | ROM source control. Tied to a logic 1 or 0 to indicate internal ROM only, or internal plus external. Tied to SYNC to override Bank 0 with an external program, and to inverted SYNC to verify internal ROM contents. | | 6 | EXT | Active-low strobe output for D Lines. Generated by an OUT instruction during time T7.* | | 35 | SYNC | Synchronization output for external devices or for external ROM control. Continuous square wave, low in T1 and T3, high in T5 and T7.* $f_{CLK}+f_{SYNC}=4$ for S2000, 8 for S2150. | | 34 | RUN | Run/Wait control for prototyping and single-step testing. Logic 1 to run, logic 0 to wait with D Lines floating. | | 22 | POR | Power-On-Reset. Needs only an external capacitor, typically .05 microfarad. A pullup to $V_{\rm GG}$ (15 $\mu A$ nominal) is provided internally. | | 23 | CLK | On-chip oscillator connection. Runs at ~850kHz when connected to $V_{SS}$ through 47pf and to $V_{GG}$ through 30k $\Omega$ on the S2000. Crystal control possible; consult AMI. | | 21 | STATUS | Monitors internal status for special designs. Logic 1 vs. logic 0 indicates: (during T1)* D Lines floating or not floating; (T3) BL equal or not equal to 13 for multiplex control; (T5) Carry is 1 or 0; (T7) Next instruction will or won't be skipped. On the S2150 a mask option allows use as a crystal oscillator pin. | | 24 | KREF | K Lines voltage comparator reference input. Typically +3.0V, supplied by an external resistor divider. | | 30 33 | K1, K2<br>K4, K8 | K Lines, tested by SZK instruction. Any combination of these lines, selected by the last executed LAI instruction, are gated into the signal input of the voltage comparator. Unselected K Lines are discharged to $V_{\rm SS}$ , at $160 \mu \rm A$ typical. | | 25 - 28 | I1, I2,<br>I4, I8 | I Lines, with internal pull-ups of $100\mu A$ nominal. Any combination of these lines, selected by the last executed LAI instruction (S2000, S2150), are gated into a common node tested by the SZI instruction. I8 also clocks a seconds timer whose output is tested using SOS. | <sup>\*</sup>T1 is the first quarter-cycle following the falling edge of the SYNC output, T3 is the second, T5 is the third, and T7 is the fourth. # \$2000/2150 # Absolute Maximum Ratings (All voltages measured with respect to $V_{\rm SS}$ ) | Storage Temperature | 55°C to +125°C | |----------------------------------------------|--------------------------| | Operating Temperature | | | Operating Temperature (special request) | | | Maximum Positive Voltage | + 18V | | Maximum Negative Voltage | 0.3V | | Maximum Output Currents | (See "Conditions" below) | | IDD Supply Current (depends on output loads) | + 75mA | | Total Average Power Dissipation | + 700mW | | | | #### \$2000/2150 #### **Electrical Characteristics** $(V_{SS} = 0V, \, V_{GG} = +7.5V \,\, to \,\, +10.0V, \, V_{DD} = 5V *, \, T_A = 0 ^{\circ}C \,\, to \,\, +70 ^{\circ}C, \, f_{SYNC} = 125 kHz \,\, to \,\, 225 kHz)$ | <del></del> | Parameter | Min. | Typ. | Max. | Units | Conditions | |-------------|-------------------------------------------------------------|-----------------|------|------------------|------------|-------------------------------| | INPUTS | K <sub>1</sub> thru K <sub>8</sub> | | | | ! | 2.8 < K <sub>REF</sub> < 3.2V | | | Low Level | 0 | | $K_{REF} - 0.5$ | v : | | | | High Level | $K_{REF} + 0.5$ | | $v_{GG}$ | <b>v</b> ] | | | INPUTS | I <sub>1</sub> thru I <sub>8</sub> , POR<br>Schmitt-trigger | | | | | (Note 1) | | | Low Level | 0 | | 1.7 | V | | | | High Level | 5.3 | | $v_{GG}$ | : <b>v</b> | | | INPUTS | ROMs, RUN | | | | i | | | | Low Level | 0 | | 0.8 | v | | | | High Level | 3.5 | | ${ m v_{GG}}$ | | | | INPUTS | Do thru D7 | | | | | | | | Low Level | 0 | | 0.8 | v | | | | High Level - Program | 5.0 | | $V_{GG}$ | v | | | | High Level — Data | 3.5 | | $V_{GG}^{GG}$ | · V | | | OUTPUTS | A <sub>0</sub> thru A <sub>3</sub> | - | | | Ī T | | | | High Level | 3.5 | | *V <sub>DD</sub> | v | $I = -5mA^{**}$ | | | Low Level | 0 | | 0.8 | v | $I= +25mA^{**}$ | | OUTPUTS | $A_4$ thru $A_{12}$ $\overline{\text{EXT}}$ , SYNC, & S | | | | | | | | High Level | 3.5 | | *V <sub>DD</sub> | v | $I = -5mA^{**}$ | | | Low Level | 0 | | 0.6 | V | $I= +5mA^{**}$ | | OUTPUTS | D <sub>0</sub> thru D <sub>7</sub> | | | | İ | | | | High Level | 3.5 | | *v <sub>DD</sub> | l v l | $I = -5mA^{**}$ | | | Low Level | 0 | | 1.0 | v | $I = +12mA^{**}$ | | $I_{GG}$ | Supply Current | | 28 | 50 | mA | | | ΔRAM | RAM "Keep Alive" | | 20 | | μA/Bit | $V_{\mathbf{RAM}} = 4.0V$ | | | | | 30 | | uA/Bit | $V_{RAM} = 9.0V$ | NOTE 1: There is an internal pull-up of $100\mu A$ nominal ( $15\mu A$ nominal on $\overline{POR}$ ) from each of these inputs to $V_{GG}$ . $<sup>^{*}</sup>V_{\mathrm{DD}}$ may be connected to $V_{\mathrm{GG}}$ if single power supply operation is desired. <sup>\*\*</sup>At $V_{GG} \ge 8.5 VDC$ $<sup>\</sup>Delta$ Available only on S2150/S2150A. #### S2000A/S2150A #### **Preliminary Electrical Specifications** Absolute Maximum Ratings (All voltages measured with respect to VSS) | Storage Temperature | $\dots -55^{\circ}$ C to $+125^{\circ}$ C | |------------------------------------------------------------------------------------------------|----------------------------------------------| | Operating Temperature | 0°C to +70°C | | Operating Temperature (special request) | $\dots$ - $40^{\circ}$ C to + $85^{\circ}$ C | | Maximum Positive Voltage, VFD, A <sub>0</sub> -A <sub>4</sub> , D <sub>0</sub> -D <sub>7</sub> | + 33V | | All other pins | + 18V | | Maximum Negative Voltage, any pin | – 0.3V | | Maximum Output Currents | . (See Conditions below) | | Source Current, any pin | $, \dots , \dots -10 mA$ | | Total Average Power Dissipation | + 700mW | | Rate of Rise of VFD | 1.6V/msec. | | Maximum Voltage at V <sub>FD</sub> with respect to V <sub>GG</sub> | + 22V | #### S2000A/S2150A **Electrical Characteristics** — Specifications noted only for parameters which change from the S2000/2150 to the S2000A/2150A. $(V_{SS} = 0V, \ V_{GG} = 7.5 \ to \ 10.0V, \ V_{FD} = V_{GG} + 22V, \ T_A = 0 ^{\circ}C \ to \ + 70 ^{\circ}C, \ f_{SYNC} = 125kHz \ to \ 225kHz)$ | | Parameter | Min. | Typ. | Max. | Units | Conditions | |----------|----------------------------------------------------------------------------------------------|-------|------|------|---------|----------------------------------------------------------| | OUTPUTS | D <sub>0</sub> thru D <sub>7</sub> , A <sub>0</sub> thru A <sub>4</sub> High Level Low Level | - 3.5 | | 0.6 | mA<br>V | V <sub>OUT</sub> = V <sub>FD</sub> - 6V**<br>I = 250μA** | | OUTPUTS | A <sub>5</sub> thru A <sub>12</sub> , EXT,<br>SYNC, & STATUS<br>High Level | 3.5 | | | v | I = -5mA** | | | Low Level | | | 0.6 | V | $I = +5mA^{**}$ | | $I_{GG}$ | Supply Current | | 28 | 50 | mA | No Loads | NOTE 1: The output buffers for lines $A_5\,A_{12}\,are$ supplied from $V_{\rm GG},$ NOTE 2: The high voltage parts, when biased with normal V<sub>FD</sub>, are not TTL-compatible; when using external program ROM, it is necessary to interpose buffers. NOTE 3: When applying power, $V_{\rm FD}$ must rise with or after $V_{\rm GG}$ at a rate not to exceed 1.8V/msec. <sup>\*\*</sup>At $V_{GG} \ge 8.5 VDC$ #### S2200/2400 Block Diagram For applications such as pulse width measurement, interval timing and event counting, the S2200/2400 has an 8-bit binary down-counter which counts 256 distinct states. The number of states (1 to 256) is controlled by the (Modulo-) N Register. Another register, the MOD Register, controls the selection of inputs and outputs for the Programmable Counter/Timer, as well as the Display Latch output polarity and the voltage comparator's noninverting-input source. 4.12 #### S2200/2400 # Absolute Maximum Ratings (All voltages measured with respect to VSS) | Storage Temperature | – 55°C to + 125°C | |------------------------------------------------|------------------------| | Operating Temperature | 0°C to +70°C | | Operating Temperature (special request) | 40°C to + 85°C | | Maximum Positive Voltage | + 18V | | Maximum Negative Voltage | – 0.3V | | Maximum Output Currents | (See Conditions p. 12) | | IDD Supply Current (depends upon output loads) | + 75mA | | Total Maximum Power Dissipation | + 700mW | #### **Electrical Characteristics** $\{V_{SS} = 0V, \ V_{GG} = +7.5V \ to \ +10.0V; \ V_{DD} = +5V^*, \ T_A = 0^{\circ}C \ to \ +70^{\circ}C, \ f_{SYNC} = 125kHz \ to \ 225kHz \}$ | | Parameter | Min. | Typ. | Max. | Units | Conditions | |-----------|-------------------------------------|----------------------|------|----------------------|--------|------------------------------| | INPUTS | K <sub>0</sub> thru K <sub>7</sub> | | | | V | For Touch- | | | Low Level | 0 | | $K_{REF} - 0.5$ | V | Control and | | | High Level | $K_{REF} + 0.5$ | | $v_{GG}$ | V | Keyswitch | | | | | | | | Inputs | | INPUT | K <sub>REF</sub> | 0 | | $2/3~{ m V}_{ m GG}$ | V | | | INPUTS | K <sub>0</sub> thru K <sub>7</sub> | | | | ļ | For A/D | | | For A/D Conversion | 0 | | $2/3~{ m V_{GG}}$ | v | Conversion | | | Logic Low Level | | | 0.8 | V | As Logic Inputs | | | Logic High Level | 3.5 | | | V | | | NPUT | POR | | | | | | | | Low Level (POR Reset) | 0 | | 1.0 | v | 1 | | | High Level | $1/2~{ m V}_{ m GG}$ | | $V_{GG}$ | v | | | | Power Fail | | | "" | | | | | -No Interrupt | | | $V_{GG}$ | V | | | | -Interrupt | $V_{GG} + 1$ | | | V | | | NPUTS | ROMs, RUN | | | | | (Note 1) | | | Low Level | 0 | | 0.8 | v | | | | High Level | 3.5 | | $v_{GG}$ | v | | | NPUTS | D <sub>0</sub> thru D <sub>7</sub> | | | | | | | | Low Level | 0 | | 0.8 | V | | | | High Level | 4.5 | | $V_{GG}$ | V | | | OUTPUTS | A <sub>0</sub> thru A <sub>3</sub> | | | " | | | | | High Level | 3.5 | | *V <sub>DD</sub> | v | $I=-5mA^{\bullet\bullet}$ | | | Low Level | 0 | | 0.8 | v | I = +25mA** | | DUTPUTS | A <sub>4</sub> thru A <sub>12</sub> | | | | | | | | EXT, SYNC, & S | | | | | | | | High Level | 3.5 | | *V <sub>DD</sub> | V | I = -5mA** | | | Low Level | 0 | | 0.6 | V | I = +5mA** | | OUTPUTS | D <sub>0</sub> thru D <sub>7</sub> | | | | | | | | High Level | 3.5 | | $*V_{DD}$ | V | $I = -5mA^{\bullet \bullet}$ | | | Low Level | 0 | | 1.0 | V | I = +12mA** | | $I_{GG}$ | Supply Current | | 28 | 50 | mA | | | 7 | RAM "Keep Alive" | | 90 | 1 | A /D;4 | V 4 0V | | $I_{RAM}$ | Current | | 20 | | μA/Bit | $V_{RAM} = 4.0V$ | <sup>\*</sup>V $_{\rm DD}$ may be connected to V $_{\rm GG}$ if single power supply operation is desired. \*\*At V $_{\rm GG} \ge 8.5 \rm VDC$ Note 1: There is an internal pullup of $100\mu A$ nominal from each of these inputs to $V_{\rm GG}$ . #### S2200A/S2400A Preliminary Electrical Specifications Absolute Maximum Ratings (All voltages measured with respect to $V_{\rm SS}$ ) | Storage Temperature | $\dots -55^{\circ}\text{C to} + 125^{\circ}\text{C}$ | |-------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | Operating Temperature | 0°C to +70°C | | Operating Temperature (special request) | 40°C to +85°C | | Maximum Positive Voltage, V <sub>FD</sub> , A <sub>0</sub> -A <sub>4</sub> , D <sub>0</sub> -D <sub>7</sub> | + 33V | | All other pins | | | Maximum Negative Voltage | 0.3V | | Maximum Output Currents | | | Source Current, any pin | 10mA | | Total Average Power Dissipation | + 700mW | | Rate of Rise of V <sub>FD</sub> | | **Electrical Characteristics** — Specifications noted only for parameters which change from the S2200/2400 to the S2200A/2400A $(V_{SS} = 0V, \, V_{GG} = 7.5 + 10.0V, \, V_{FD} = V_{GG} + 22V, \, T_A = 0 ^{\circ}C \, \, to \, + 70 ^{\circ}C, \, f_{SYNC} = 125 kHz \, to \, 225 kHz)$ | | Parameter | Min. | Typ. | Max. | Units | Conditions | |----------|----------------------------------------------------------------------------------------------------|-------|------|------|---------|----------------------------------------------------------| | OUTPUTS | D <sub>0</sub> thru D <sub>7</sub> , A <sub>0</sub> thru A <sub>4</sub><br>High Level<br>Low Level | - 3.5 | | 0.6 | mA<br>V | V <sub>OUT</sub> = V <sub>FD</sub> - 6V**<br>1 = 250μA** | | OUTPUTS | A <sub>5</sub> thru A <sub>12</sub> , EXT,<br>SYNC, & STATUS | | | | | | | | High Level | 3.5 | | | v | $ I = -5mA^{**}$ | | | Low Level | | | 0.6 | v | $I = -5mA^{**}$ $I = +5mA^{**}$ | | $I_{GG}$ | Supply Current | | 28 | 50 | mA | No Loads | <sup>\*\*</sup>At VGG≥8.5VDC NOTE 1: The output buffers for lines $A_5\text{-}A_{12}$ are supplied from $V_{\rm GG}$ . NOTE 2: The high voltage parts, when biased with normal V<sub>FD</sub>, are not TTL-compatible; when using external program ROM, it is necessary to interpose buffers. NOTE 3: When applying power, $V_{\rm FD}$ must rise with or after $V_{\rm GG}$ at a rate not to exceed 1.6V/msec. # S9900 Family # THE AMI S9900 MICROCOMPUTER SYSTEMS FAMILY | PART NO. | DESCRIPTION | POWER SUPPLIES | ₩PUT/OUTPUT | PACKAGES | |----------------|----------------------------------------------|----------------|-------------|----------| | 59900 | 16-Bit Single Chip Microprocessor | + 12V, ±5V | TTL | 64 Pin | | S9901 | Programmable Systems Interface Circuit | + 5V | TTL | 40 Pin | | S99 <b>0</b> 2 | Asynchronous Communications Controller (ACC) | +5V | TTL | 18 Pin | | S9903 | Synchronous Communications Controller (SCC) | +5 <b>V</b> | TTI. | 20 Pin | | 59940 | 16-Bit Single Chip Microcomputer | + 5 <b>V</b> | TTL | 18 Pin | | 59980 | 16-Bit Single Chip Microcomputer | +5V | ΠL | 40 Pin | | \$9981 | 16-Bit Single Chip Microcomputer | + 5V | TTL | 40 Pin | # 16-BIT MICROPROCESSOR #### **Features** - ☐ 16-Bit Instruction Word - Full Minicomputer Instruction Set Capability including Multiply and Divide - ☐ Up to 65,536 Bytes of Memory - ☐ 3.3MHz Speed - ☐ Advanced Memory-to-Memory Architecture - ☐ Separate Memory, I/O and Interrupt-Bus Structures - ☐ 16 General Registers - ☐ 16 Prioritized Interrupts - □ Programmed and DMA I/O Capability - ☐ N-Channel Silicon-Gate Technology # General Description The S9900 microprocessor is a single-chip 16-bit central processing unit (CPU) produced using N-channel silicon-gate MOS technology. The instruction set of the S9900 includes the capabilities offered by full minicomputers. The unique memory-to-memory architecture features multiple register files, resident in memory, which allow faster response to interrupts and increased programming flexibility. The separate bus structure simplifies the system design effort. AMI provides a compatible set of MOS memory and support circuits to be used with an S9900 system. The system is fully supported by software and complete prototyping systems. #### \$9900 Electrical and Mechanical Specifications Absolute Maximum Ratings Over Operating Free-Air Temperature Range (unless otherwise noted)\* | Supply Voltage, V <sub>CC</sub> (See Note 1) | 0.3V to +20V | |----------------------------------------------|-----------------------------------| | Supply Voltage, V <sub>DD</sub> (See Note 1) | | | Supply Voltage, VSS (See Note 1) | 0.3V to +20V | | All Input Voltages (See Note 1) | | | Output Voltage (with Respect to VSS) | $\dots \dots -2V \text{ to } +7V$ | | Continuous Power Dissipation | +1.2W | | Operating Free-Air Temperature Range | 0°C to +70°C | | Storage Temperature Range | 55°C to +150°C | <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute maximum-rated conditions for extended periods may affect device reliability. #### **Recommended Operating Conditions** | Symbol | Parameter | Min. | Nom. | Max. | Unit | Conditions | |-------------------------|-----------------------------------------------------|--------------------|------|--------------------|------|------------| | VBB | Supply voltage | -5.25 | -5 | -4.75 | v | | | V <sub>CC</sub> | Supply voltage | 4.75 | 5 | 5.25 | V | | | $v_{DD}$ | Supply voltage | 11.4 | 12 | 12.6 | v | | | $v_{ss}$ | Supply voltage | | 0 | | ٧ | | | V <sub>IH</sub> | High-level input voltage (all inputs except clocks) | 2.2 | 2.4 | V <sub>CC</sub> +1 | V | | | $V_{\mathrm{IH}(\phi)}$ | High-level clock input voltage | V <sub>DD</sub> -2 | | $V_{\mathbf{DD}}$ | v | | | Vil | Low-level input voltage (all inputs except clocks) | -1 | 0.4 | 0.8 | v | · | | Villion | Low-level clock input voltage | -0.3 | 0.3 | 0.6 | V | | | TA | Operating free-air temperature | 0 | | 70 | °C | | #### Timing Requirements Over Full Range of Recommended Operating Conditions (See Figures 1 and 2) | Symbol | Parameter | Min. | Nom. | Max. | Unit | Conditions | |------------------------|-----------------------------------------------------------------------|------|-------|------|------|------------| | $\iota_{c(\phi)}$ | Clock cycle time | 0.3 | 0.333 | 0.5 | μS | - | | tr(\phi) | Clock rise time | 10 | 12 | | ns | | | $t_{f(\phi)}$ | Clock fall time | 10 | 12 | | ns | 1 | | t <sub>w(φ)</sub> | Pulse width, any clock high | 40 | 45 | 100 | ns | | | t <sub>φ1L, φ2H</sub> | Delay time, clock 1 low to clock 2 high (time between clock pulses) | 0 | 5 | Ì | ns | | | t <sub>φ2L</sub> , φ3H | Delay time, clock 2 low to clock 3 high (time between clock pulses) | 0 | 5 | 1 | ns | | | t <sub>φ3L, φ4H</sub> | Delay time, clock 3 low to clock 4 high (time between clock pulses) | 0 | 5 | | ns | | | tφ4L, φ1H | Delay time, clock 4 low to clock 1 high (time between clock pulses) | 0 | 5 | | ns | | | t <sub>φ1H</sub> , φ2H | Delay time, clock 1 high to clock 2 high (time between leading edges) | 70 | 80 | i | ns | | | t <sub>φ2H, φ3H</sub> | Delay time, clock 2 high to clock 3 high (time between leading edges) | 70 | 80 | | ns | | | t <sub>φ3H, φ4H</sub> | Delay time, clock 3 high to clock 4 high (time between leading edges) | 70 | 80 | | ns | | | t <sub>φ4H</sub> , φ1H | Delay time, clock 4 high to clock 1 high (time between leading edges) | 70 | 80 | | ns | | | $t_{su}$ | Data or control setup time before clock 1 | 30 | | | ns | | | th | Data hold time after clock 1 | 10 | | | ns | | NOTE 1: Under absolute maximum ratings values are with respect to the most negative supply, $V_{BB}$ (substrate), unless otherwise noted. Throughout the remainder of this section, voltage values are with respect to $V_{SS}$ # Electrical Characteristics Over Full Range of Recommended Operating Conditions (unless otherwise noted) | Symbol | Parameter | | Min. | Typ.† | Max. | Unit | Conditions | |-----------------------------------|----------------------------------------------------------|--------------------------------------------------------|------|-------|--------------|------|-----------------------------------------------------------------------| | | | Data Bus during DB1N | | - 50 | +100 | 1 | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | | ΙΙ | Input current | WE, MEMEN, DBIN, Address<br>bus, Data bus during HOLDA | | ±50 | , 100 | μА | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | | | | Clock* | | ± 25 | ±75 | | $V_{\rm I}$ = -0.3 to 12.6 V | | | | Any other inputs | | ±1 | .10 | } | $V_{\rm I}$ = $V_{\rm SS}$ to $V_{\rm CC}$ | | Уон | High-level out | put voltage | 2.4 | 1 | $v_{CC}$ | V | $I_{\rm O} = -0.4$ mA | | VOL | Low-level out | put voltage | | | 0.65<br>0.50 | v | I <sub>O</sub> = 32.mA<br>I <sub>O</sub> = 2mΛ | | $I_{BB}$ | Supply curren | t from V <sub>BB</sub> | | 0.1 | 1 | mΛ | | | $I_{CC}$ | Supply curren | t from V <sub>CC</sub> | | 50 | 75 | m A | | | $I_{\mathrm{DD}}$ | Supply current from VDD | | | 25 | 45 | mA | | | Ci | Input capacitance (any inputs except clock and data bus) | | | 10 | 15 | pF | V <sub>BB</sub> = -5, f = 1MHz,<br>unmeasured pins at V <sub>SS</sub> | | $\mathbf{c}_{\mathrm{i}(\phi 1)}$ | Clock-1 input capacitance | | | 100 | 150 | pF | V <sub>BB</sub> = -5, f = 1MHz,<br>unmeasured pins at V <sub>SS</sub> | | $c_{i(\phi 2)}$ | Clock · 2 input capacitance | | | 150 | 200 | pF | VBB = -5, f = 1MHz<br>unmeasured pins at VSS | | $c_{i(\phi^3)}$ | Clock-3 input | capacitance | | 100 | 150 | pF | V <sub>BB</sub> = -5, f = 1MHz,<br>unmeasured pins at V <sub>SS</sub> | | $C_{i(\phi 4)}$ | Clock 4 input capacitance | | | 100 | 150 | рF | V <sub>BB</sub> 5, f = 1MHz,<br>unmeasured pins at V <sub>SS</sub> | | $c_{DB}$ | Data bus capacitance | | | 15 | 25 | pF | $V_{BB} = -5$ , $f = 1MHz$ ,<br>unmeasured pins at $V_{SS}$ | | Co | Output capacitance (any output except data bus) | | | 10 | 15 | pF | V <sub>BB</sub> =-5, f=1MHz,<br>unmeasured pins at V <sub>SS</sub> | $<sup>\</sup>dagger {\rm All}$ typical values are at $T_A$ = $25^{\circ}{\rm C}$ and nominal voltages. # Switching Characteristics Over Full Range of Recommended Operating Conditions (See Figure 2) | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |---------------|-------------------------------------------|------|------|------|------|----------------| | tPLH or tPHL, | Propagation delay time, clocks to outputs | | 20 | 40 | ns | $C_L = 200 pF$ | <sup>\*</sup>D.C. Component of Operating Clock. NOTE: All timing and voltage levels shown on $\phi 1$ applies to $\phi 2$ , $\phi 3$ , and $\phi 4$ in the same manner. †The number of cycles over which input/output data must/will remain valid can be determined from the number of wait states required for memory access. Note that in all cases data should not change during o1. # Pin Description Table 1 defines the S9900 pin assignments and describes the function of each pin. Table 1. S9900 Pin Assignments and Functions | Signature | Pin | 1/0 | Description | |-----------------|----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 1 | | ADDRESS BUS | | A0 (MSB) | 24 | דעם | A0 through A14 comprise the address bus. This 3-state bus provides the memory-address vec- | | A1 | 23 | OUT | tor to the external-memory system when MEMEN is active and I/O-bit addresses and external- | | A2 | 22 | our . | instruction addresses to the I/O system when MEMEN is inactive. The address bus assumes the | | A3 | 21 | DUT | high-impedance state when HOLDA is active. | | A4 | 20 | OUT | | | A5 | 19 | DUT | | | A6 | 18 | OUT | | | A7 | 17 | OUT | | | A8 | 16 | OUT | | | A9 | 15 | DUT | | | A10 | 14 | OUT | | | A11 | 13 | OUT | | | A12 | 12 | DUT | | | A13 | 11 | DUT | | | A14 (LSB) | 1 10 | OUT | | | | | | DATA BUS | | DO:(MSB) | 41 | 1/0 | | | DU (MOD)<br>D1 | | 1 - | D0 through D15 comprise the bidirectional 3-state data bus. This bus transfers memory data to (when writing) and from (when reading) the external-memory system when MEMEN is | | 02 | 42 | 1/0 | | | D3 | 43<br>44 | 1/0<br> 1/0 | active. The data bus assumes the high-impedance state when HOLDA is active. | | D3<br>D4 | 44 | 1/0 | | | 05 | 46 | 1/0 | | | D6 | 47 | 1/0 | | | DB<br>D7 | 48 | 1/0 | | | 08 | 49 | 1/0 | | | D9 | | | | | D10 | 50<br>51 | 1/0 | | | | | 1/0 | | | D11 | 52 | 1/0 | | | D12<br>D13 | 53<br>54 | 1/D<br>1/0 | | | D14 | 55 | 1/0 | | | D15 (LSB) | 56 | 1/0 | | | D 10 (E00) | 30 | 170 | POWER SUPPLIES | | VBB | 1 | | Supply voltage (-5V NOM) | | V <sub>CC</sub> | 2,59 | | Supply voltage (5V NOM). Pins 2 and 59 must be connected in parallel. | | | 2,33 | | Supply voltage (3 v MON), Fins 2 and 39 must be connected in parallel. | | V <sub>DD</sub> | 26,40 | | Supply volage (12V NDM) | | Vss | 20,40 | | Ground reference. Pins 26 and 40 must be connected in parallel. | | | | | CLOCKS | | $\phi$ 1 | 8 | IN | Phase-1 clock | | φ2 | 9 | IN | Phase- 2 clock | | φ3 | 28 | IN | Phase-3 clock | | φ <b>4</b> | 25 | IN | Phase-4 clock | Table 1. \$9900 Pin Assignments and Functions (Continued) | Signature | Pin | 1/0 | Description | |--------------------------------------|----------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | BUS CONTROL | | DBIN 29 OUT | | оит | Data bus in. When active (high), DBIN indicates that the S9900 has disabled its output buffers to allow the memory to place memory-read data on the data bus during MEMEN. DBIN remains low in all other cases except when HOLDA is active. | | MEMEN | 63 | ОПТ | Memory enable. When active (low), MEMEN indicates that the address bus contains a memory address. | | WE | 61 | OUT | Write enable. When active (low), $\overline{\text{WE}}$ indicates that memory-write data is available from the S9900 to be written into memory. | | CRUCLK | 60 | OUT | CRU clock. When active (high), CRUCLK indicates that external interface logic should sample the output data on CRUOUT or should decode external instructions on A0 through A2. | | CRUIN | 31 | IN | CRU data in. CRUIN, normally driven by 3-state or open-collector devices, receives input data from external interface logic. When the processor executes a STCR or TB instruction, it samples CRUIN for the level of the CRU input bit specified by the address bus (A3 through A14). | | CRUOUT | 30 | OUT | CRU data out. Serial I/O data appears on the CRUOUT line when an LDCR, SBZ, or SBO instruction is executed. The data on CRUOUT should be sampled by external I/O interface logic when CRUCLK goes active (high). | | | • | | INTERRUPT CONTROL | | INTREQ | 32 | IN<br> <br> <br> <br> | Interrupt request. When active (low), INTREQ indicates that an external-interrupt is requested. If INTREQ is active, the processor loads the data on the interrupt-code-input lines ICO through ICO into the interrupt-code-storage register. The code is compared to the interrupt mask bits of the status register. If equal or higher priority than the enabled interrupt level (interrupt code equal or less than status register bits 12 through 15) the S9900 interrupt sequence is initiated. If the comparison fails, the processor ignores the request. INTREQ should remain active and the processor will continue to sample ICO through ICO until the program enables a sufficiently low priority to accept the request interrupt. | | ICO (MSB)<br>IC1<br>IC2<br>IC3 (LSB) | 36<br>35<br>34<br>33 | IN<br>IN<br>IN<br>IN | Interrupt codes. ICO is the MSB of the interrupt code, which is sampled when INTREQ is active. When ICO through IC3 are LLLH, the highest external-priority interrupt is being requested and when HHHH, the lowest-priority interrupt is being requested. | | | | | MEMORY CONTROL | | HOLD | 64 | IN | Hold. When active (low), HOLD indicates to the processor that an external controller (e.g., DMA device) desires to utilize the address and data buses to transfer data to or from memory. The S9900 enters the hold state following a hold signal when it has completed its present memory cycle.* The processor then places the address and data buses in the high-impedance state (along with WE, MEMEN, and DBIN) and responds with a hold-acknowledge signal (HOLDA). When HOLD is removed, the processor returns to normal operation. | <sup>\*</sup>If the cycle following the present memory cycle is also a memory cycle, it, too, is completed before the \$9900 enters the hold state. The maximum number of consecutive memory cycles is three. Table 1. \$9900 Pin Assignments and Functions (Continued) | Signature | Pin | 1/0 | Description | |-----------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HOLDA | 5 | OUT | Hold acknowledge. When active (high), HOLDA indicates that the processor is in the hold state and the address and data buses and memory control outputs (WE, MEMEN, and DBIN) are in the high impedance state. | | READY | 62 | ťΝ | Ready. When active (high), READY indicates that memory will be ready to read or write during the next clock cycle. When not-ready is indicated during a memory operation, the \$9900 enters a wait state and suspends internal operation until the memory systems indicate ready. | | WAIT | 3 | OUT | Wait. When active (high), WAIT indicates that the \$9900 has entered a wait state because of a not-ready condition from memory. | | | | | TIMING AND CONTROL | | IAQ. | 7 | OUT | Instruction acquisition. IAQ is active (high) during any memory cycle when the \$9900 is acquiring an instruction. IAQ can be used to detect illegal op codes. | | LÖAD | 4 | IN | Load. When active (low), $\overline{\text{LOAD}}$ causes the S9900 to execute a nonmaskable interrupt with memory address FFFC <sub>16</sub> containing the trap vector (WP and PC). The load sequence begins after the instruction being executed is completed. $\overline{\text{LOAD}}$ will also terminate an idle state, if $\overline{\text{LOAD}}$ is active during the time $\overline{\text{RESET}}$ is released, then the $\overline{\text{LOAD}}$ trap will occur after the $\overline{\text{RESET}}$ fuction is completed. $\overline{\text{LOAD}}$ should remain active for one instruction period. IAQ can be used to determine instruction boundaries. This signal can be used to implement cold-start ROM loaders. Additionally, front-panel routines can be implemented using CRU bits as front-panel-interface signals and software-control routines to control the panel operations. | | RESET | 6 | iN<br>i | Reset. When active (low), RESET causes the processur to be reset and inhibits WE and CRUCLK. When RESET is released, the S9900 then initiates a level-zero interrupt sequence that acquires WP and PC from locations 0000 and 0002, sets all status register bits to zero, and starts execution. RESET will also terminate an idle state. RESET must be held active for a minimum of three clock cycles. | <sup>\*</sup>If the cycle following the present memory cycle is also a memory cycle it, too, is completed before the \$9900 enters the hold state. The maximum number of consecutive memory cycles is three. #### Timing #### Memory A basic memory read and write cycle is shown in Figure 3. The read cycle is shown with no wait states and the write cycle is shown with one wait state. MEMEN goes active (low) during each memory cycle. At the same time that MEMEN is active, the memory address appears on the address bus bits A0 through A14. If the cycle is a memory-read-only cycle, DBIN will go active (high) at the same time MEMEN and A0 through A14 become valid. The memory-write signal WE will remain inactive (high) during a read cycle. If the read cycle is also an instruction acquisition cycle, IAQ will go active (high) during the cycle. The READY signal, which allows extended memory cycles, is shown high during $\phi 1$ of the second clock cycle of the read operation. This indicates to the S9900 that memory-read data will be valid during $\phi 1$ of the next clock cycle. If READY is low during $\phi 1$ , then the S9900 enters a wait state suspending internal operation until a READY is sensed during a subsequent $\phi 1$ . The memory read data is then sampled by the S9900 during the next $\phi 1$ , which completes the memory-read cycle. At the end of the read cycle, MEMEN and DBIN go inactive (high and low, respectively). The address bus may also change at this time; however, the data bus remains in the input mode for one clock cycle after the read cycle. A write cycle is similar to the read cycle with the exception that $\overline{WE}$ goes active (low) as shown and valid write data appears on the data bus at the same time the address appears. The write cycle is shown as an example of a one-wait-state memory cycle. READY is low during $\phi 1$ resulting in the WAIT signal shown. #### Hold Other interfaces may utilize the S9900 memory bus by using the hold operation (illustrated in Figure 4) of the S9900. When $\overline{\text{HOLD}}$ is active (low), the S9900 enters the hold state at the next available non-memory cycle. Considering that there can be a maximum of three consecutive memory cycles, the maximum delay between $\overline{\text{HOLD}}$ going active to HOLDA going active (high) could be $t_{c(\phi)}$ (for setup) + (6+3W) $t_{c(\phi)}$ + $t_{c(\phi)}$ (delay for HOLDA), where W is the number of wait states per memory cycle and $t_{c(\phi)}$ is the clock cycle time. When the S9900 has entered the hold state, HOLDA goes active (high) and A0 through A15, D0 through D15 DBIN, $\overline{\text{MEMEN}}$ , and $\overline{\text{WE}}$ go into a high-impedance state to allow other devices to use the memory buses. When $\overline{\text{HOLD}}$ goes inactive (high), the S9900 resumes process- ing as shown. If hold occurs during a CRU operation, the S9900 uses an extra clock cycle (after the removal of the HOLD signal) to reassert the CRU address providing the normal setup times for the CRU bit transfer that was interrupted. #### CRU CRU interface timing is shown in Figure 5. The timing for transferring two bits out and one bit in is shown. These transfers would occur during the execution of a CRU instruction. The other cycles of the instruction execution are not illustrated. To output a CRU bit, the CRU-bit address is placed on the address bus A0 through A14 and the actual bit data on CRUOUT. During the second clock cycle a CRU pulse is supplied by CRUCLK. This process is repeated until the number of bits specified by the instruction are completed. The CRU input operation is similar in that the bit address appears on A0 through A14. During the subsequent cycle the S9900 accepts the bit input data as shown. No CRUCLK pulses occur during a CRU input operation. #### Architecture The S9900 operation is shown in Figure 6 and its architecture illustrated by Figure 7. #### Registers and Memory The S9900 employs an advanced memory-to-memory architecture. Blocks of memory designated as workspace replace internal-hardware registers with program-data registers. The memory word of the S9900 is 16 bits long. Each word is also defined as 2 bytes of 8 bits. The instruction set of the S9900 allows both word and byte operands. Thus, all memory locations are on even address boundaries and byte instructions can address either the even or odd byte. The memory space is 65,536 bytes or 32,768 words. The word and byte formats are shown below. The S9900 memory map is shown in Figure 8. The first 32 words are used for interrupt trap vectors. The next contiguous block of 32 memory words is used by the extended operation (XOP) instruction for trap vectors. The last two memory words, $FFFC_{16}$ and $FFFE_{16}$ are used for the trap vector of the LOAD signal. The remaining memory is then available for programs, data, and workspace registers. If desired, any of the special areas may also be used as general memory. Three internal registers are accessible to the user. The program counter (PC) contains the address of the instruction following the current instruction being executed. This address is referenced by the processor to fetch the next instruction from memory and is then automatically incremented. The status register (ST) contains the present state of the processor. The workspace pointer (WP) contains the address of the first word in the currently active set of workspace registers. A workspace-register file occupies 16 contiguous memory words in the general memory area (see Figure 2). Each workspace register may hold data or addresses and function as operand registers, accumulators, address registers, or index registers. During instruction execution, the processor addresses any register in the workspace by adding the register number to the contents of the workspace pointer and initiating a memory request for the word. The relation- ship between the workspace pointer and its corresponding workspace is shown below. The workspace concept is particularly valuable during operations that require a context switch, which is a change from one program environment to another (as in the case of an interrupt) or to a subroutine. Such an operation, using a conventional multi-register arrangement, requires that at least part of the contents of the register file be stored and reloaded. A memory cycle is required to store or fetch each word. By exchanging the program counter, status register, and workspace pointer, the S9900 accomplishes a complete context switch with only three store cycles and three fetch cycles. After the switch the workspace pointer contains the starting address of a new 16-word workspace in memory for use in the new routine. A corresponding time saving occurs when the original context is restored. Instructions in the S9900 that result in a context switch include: - 1. Branch and Load Workspace Pointer (BLWP) - 2. Return from Subroutine (RTWP) - 3. Extended Operation (XOP). Device interrupts, RESET, and LOAD also cause a context switch by forcing the processor to trap to a service subroutine. #### Interrupts The S9900 employs 16 interrupt levels with the highest priority level 0 and lowest level 15. Level 0 is reserved for the RESET function and all other levels may be used for external devices. The external levels may also be shared by several device interrupts, depending upon system requirements. The \$9900 continuously compares the interrupt code (ICO through IC3) with the interrupt mask contained in status-register bits 12 through 15. When the level of the pending interrupt is less than or equal to the enabling mask level (higher or equal priority interrupt), the processor recognizes the interrupt and initiates a context switch following completion of the currently executing instruction. The processor fetches the new context WP and PC from the interrupt vector locations. The, the previous context WP, PC, and ST are stored in workspace registers 13, 14, and 15, respectively, of the new workspace. The S9900 then forces the interrupt mask to a value that is one less than the level of the interrupt being serviced, except for the level-zero interrupt, which loads zero into the mask. This allows only interrupts of higher priority to interrupt a service routine. The processor also inhibits interrupts until the first instruction of the service routine has been executed to preserve program linkage should a higher priority interrupt occur. All interrupt requests should remain active until recognized by the processor in the device-service routine. The individual service routines must reset the interrupt requests before the routine is complete. If a higher priority interrupt occurs, a second context switch occurs to service the higher priority interrupt. When that routine is complete, a return instruction (RTWP) restores the first service routine parameters to the processor to complete processing of the lower-priority interrupt. All interrupt subroutines should terminate with the return instruction to restore original program parameters. The interrupt-vector locations, device assignment, enabling-mask value, and the interrupt code are shown in Table 2. # Input/Output The S9900 utilizes a versatile direct command-driven I/O interface designated as the communications-register unit (CRU). The CRU provides up to 4096 directly addressable input bits and 4096 directly addressable output bits. Both input and output bits can be addressed individually or in fields of from 1 to 16 bits. The S9900 employs three dedicated I/O pins (CRUIN, CRUOUT, and CRUCLK) and 12 bits (A3 through A14) of the address bus to interface with the CRU system. The processor instructions that drive the CRU interface can set, reset, or test any bit in the CRU array or move between memory and CRU data fields. #### Single-Bit CRU Operations The S9900 performs three single-bit CRU functions: test bit (TB), set bit to one (SBO), and set bit to zero (SBZ). To identify the bit to be operated upon, the S9900 develops a CRU-bit address and places it on the address bus, A3 to A14. For the two output operations (SBO and SBZ), the processor also generates a CRUCLK pulse, indicating an output operation to the CRU device, and places bit 7 of the instruction word on the CRUOUT line to accomplish the specified operation (bit 7 is a one for SBO and a zero for SBZ). A test-bit instruction transfers the addressed CRU bit from the CRUIN input line to bit 2 of the status register (EQUAL). The S9900 develops a CRU-bit address for the single-bit operations from the CRU-base address contained in workspace register 12 and the signed displacement count contained in bits 8 through 15 of the instruction. The displacement allows two's complement addressing from base minus 128 bits through base plus 127 bits. The base address from W12 is added to the signed displacement specified in the instruction and the result is loaded onto the address bus. Figure 9 illustrates the development of a single-bit CRU address. Table 2. Interrupt Level Data | Interrupt Level | Vector Location<br>(Memory Address<br>In Hex) | Device Assignment | Interrupt Mask Values to<br>Enable Respective Interrupts<br>(ST12 through ST15) | Interrupt<br>Codes<br>FCO through IC3 | |----------------------|-----------------------------------------------|-------------------|---------------------------------------------------------------------------------|---------------------------------------| | (Highest priority) 0 | ÐO | Reset | 0 through F* | 0000 | | 1 | 04 | External device | 1 through F | 0001 | | 2 | 08 | 1 | 2 through F | 0010 | | 3 | 0C | | 3 through F | 0011 | | 4 | 10 | | 4 through F | 0100 | | 5 | 14 | | 5 through F | 0101 | | 6 | 18 | | 6 through F | 0110 | | 7 | 1C | | 7 through F | 0111 | | 8 | 20 | | 8 through F | 1000 | | 9 | 24 | | 9 through F | 1001 | | 10 | 28 | | A through F | 1010 | | 11 | 2C | | B through F | 1011 | | 12 | 30 | | C through F | 1100 | | 13 | 34 | | D through F | 1101 | | . 14 | 38 | ↓ ↓ | E and F | 1110 | | (Lowest priority) 15 | 3C | External device | Fonly | 1111 | <sup>\*</sup>Level 0 can not be disabled. #### Multiple-Bit CRU Operations The S9900 performs two multiple-bit CRU operations: store communications register (STCR) and load communications register (LDCR). Both operations perform a data transfer from the CRU-to-memory or from memory-to-CRU as illustrated in Figure 10. Although the figure illustrates a full 16-bit transfer operation, any number of bits from 1 through 16 may be involved. The LDCR instruction fetches a word from memory and right-shifts it to serially transfer it to CRU output bits. If the LDCR involves eight or fewer bits, those bits come from the right-justified field within the addressed byte of the memory word. If the LDCR involves nine or more bits, those bits come from the right-justified field within the whole memory word. When transferred to the CRU interface, each suc- cessive bit receives an address that is sequentially greater than the address for the previous bit. This addressing mechanism results in an order reversal of the bits; that is, bit 15 of the memory word (or bit 7) becomes the lowest addressed bit in the CRU and bit 0 becomes the highest addressed bit in the CRU field. An STCR instruction transfers data from the CRU to memory. If the operation involves a byte or less transfer, the transferred data will be stored right-justified in the memory byte with leading bits set to zero. If the operation involves from nine to 16 bits, the transferred data is stored right-justified in the memory word with leading bits set to zero. When the input from CRU device is complete, the first bit from the CRU is the least-significant-bit position in the memory word or byte. #### S9900 Instruction Set ## Definition Each \$9900 instruction performs one of the following operations: - ☐ Arithmetic, logical, comparison, or manipulation operations on data - Loading or storage of internal registers (program counter, workspace pointer, or status) - Data transfer between memory and external devices via the CRU - ☐ Control functions. ### Addressing Modes S9900 instructions contain a variety of available modes for addressing random-memory data (e.g., program parameters and flags), or formatted memory data (character strings, data lists, etc.). The following figures graphically describe the derivation of the effective address for each addressing mode. The applicability of addressing modes to particular instructions is described later along with the description of the operations performed by the instruction. The symbols following the names of the addressing modes [R, \*R, \*R+.@LABEL, or @TABLE (R)] are the general forms used by S9900 assemblers to select the addressing mode for register R. #### Workspace Register Addressing R Workspace Register R contains the operand. ## Workspace Register Indirect Addressing \*R Workspace Register R contains the address of the operand. # Workspace Register Indirect Auto Increment Addressing \*R + Workspace Register R contains the address of the operand. After acquiring the operand, the contents of workspace Register R are incremented. # Symbolic (Direct) Addressing @LABEL The word following the instruction contains the address of the operand. ### Indexed Addressing @TABLE (R) The word following the instruction contains the base address. Workspace Register R contains the index value. The sum of the base address and the index value results in the effective address of the operand. ### **Immediate Addressing** The word following the instruction contains: the operand. # **Program Counter Relative Addressing** The 8-bit signed displacement in the right byte (bits 8 through 15) of the instruction is multiplied by 2 and added to the updated contents of the program counter. The result is placed in the PC. # CRU Relative Addressing The 8-bit signed displacement in the right byte of the instruction is added to the CRU base address (bits 3 through 14 of the workspace Register 12). The result is the CRU address of the selected CRU bit. #### Terms and Definitions The following terms are used in describing the instructions of the S9900: | TERM | DEFINITION | |--------------------|----------------------------------------------| | В | Byte indicator (1 = byte, 0 = word) | | C | Bit count | | D | Destination address register | | DA | Destination address | | IOP | Immediate operand | | LSB(n) | Least significant (right most) bit of (n) | | MSB(n) | Most significant (left most) bit of (n) | | N | Don't care | | PC | Program counter | | Result | Result of operation performed by instruction | | $\mathbf{s}$ | Source address register | | SA | Source address | | ST | Status register | | STn | Bit n of status register | | $T_{\mathrm{D}}$ | Destination address modifier | | T <sub>S</sub> | Source address modifier | | W | Workspace register | | WRn | Workspace register n | | (n) | Contents of n | | a → b | a is transferred to b | | n | Absolute value of n | | + | Arithmetic addition | | _ | Arithmetic subtraction | | AND | Logical AND | | OR | Logical OR | | $\frac{\oplus}{n}$ | Logical exclusive OR | | <del>n</del> | Logical complement of n | # Status Register $The status\ register\ contains\ the\ interrupt\ mask\ level\ and\ information\ pertaining\ to\ the\ instruction\ operation.$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----|-----|-----|-----|-----|-----|-----|---|-----|------|------|----|------|--------|--------|------| | ST0 | ST1 | ST2 | ST3 | ST4 | ST5 | ST6 | | not | used | (=0) | | ST12 | ST13 | ST14 | ST15 | | L> | A> | = | С | 0 | P | Х | | | | | | I | nterru | pt Mas | k | | Bit | Name | Instruction | Condition to Set Bit to 1 | |---------------|-----------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ST0 | LOGICAL<br>GREATER | C, CB | If MSB(SA) = 1 and MSB(DA) = 0, or if MSB(SA) = MSB(DA) and MSB of [(DA)-(SA)] = 1 | | | THAN | CI | If $MSB(W) = 1$ and $MSB$ of $IOP = 0$ , or if $MSB(W) = MSB$ of $IOP$ and $MSB$ of $[IOP-(W)] = 1$ | | | | ABS | If $(SA) \neq 0$ | | | | All Others | If result ≠ 0 | | ST1 | ARITHMETIC<br>GREATER | C, CB | If $MSB(SA) = 0$ and $MSB(DA) = 1$ , or if $MSB(SA) = MSB(DA)$ and $MSB$ of $[(DA) \cdot (SA)] = 1$ | | | THAN | CI | If $MSB(W) = 0$ and $MSB$ of $IOP = 1$ , or if $MSB(W) = MSB$ of $IOP$ and $MSB$ of $[IOP-(W)] = 1$ | | | | ABS | If $MSB(SA) = 0$ and $(SA) \neq 0$ | | | | All Others | If MSB of result = 0 and result $\neq$ 0 | | ST2 | EQUAL | C, CB | If (SA) = (DA) $If (RI) = IOR$ | | | | Ci<br>COC | If $(W) = IOP$<br>If $(SA)$ and $(\overline{DA}) = 0$ | | | | czc | If $(SA)$ and $(DA) = 0$ | | | | ТВ | If CRUIN = 1 | | | | ABS | If (SA) = 0 | | | | All Others | If result = 0 | | ST3 | CARRY | A, AB, ABS, AI,<br>DEC, DECT,<br>INC, INCT, NEG | If CARRY OUT = 1 | | | | S, SB<br>SLA, SRA,<br>SRC, SRL | If last bit shifted out = 1 | | ST4 | OVERFLOW | A, AB AI S, SB DEC, DECT INC, INCT | If $MSB(SA) = MSB(DA)$ and $MSB$ of result $\neq MSB(DA)$<br>If $MSB(W) = MSB$ of IOP and MSB of result $\neq MSB(W)$<br>If $MSB(SA) \neq MSB(DA)$ and MSB of result $\neq MSB(DA)$<br>If $MSB(SA) = 1$ and MSB of result $= 0$<br>If $MSB(SA) = 0$ and MSB of result $= 1$ | | | | SLA<br>DIV<br>ABS, NEG | If MSB changes during shift If MSB(SA) = 0 and MSB(DA) = 1, or if MSB(SA) = MSB(DA) and MSB of [(DA)-(SA)] = 0 If (SA) = 8000 <sub>16</sub> | | ST5 | PARITY | CB, MOVB | If (SA) has odd number of 1's | | | | LDCR, STCR<br>AB, SB, SOCB, | If $1 \le C \le 8$ and (SA) has odd number of 1's | | | i | SZCB | If result has odd number of 1's | | ST6 | XOP | XOP | If XOP instruction is executed | | ST12-<br>ST15 | INTERRUPT<br>MASK | LIMI<br>RTWP | If corresponding bit of IOP is 1 If corresponding bit of WR15 is 1 | #### Instructions Dual Operand Instructions with Multiple Addressing Modes for Source and Destination Operand 0 2 1 3 5 6 10 11 12 13 14 15 $T_{\mathrm{D}}$ General format: OP CODE D s $T_S$ If B=1 the operands are bytes and the operand addresses are byte addresses. If B=0 the operands are words and the operand addresses are word addresses. The addressing mode for each operand is determined by the T field of that operand. | T <sub>S</sub> or T <sub>D</sub> | S or D | Addressing Mode | Notes | |----------------------------------|-------------------|--------------------------------------------|-------| | 00 | 0, 1, 15 | Workspace register | 1 | | 01 | 0, 1, 15 | Workspace register indirect | | | 10 | 0 | Symbolic | 4 | | 10 | $1, 2, \dots, 15$ | Indexed | 2,4 | | 11 | 0, 1, 15 | Workspace register indirect auto-increment | 3 | #### Notes: - 1. When a workspace register is the operand of a byte instruction (bit 3 = 1), the left byte (bits 0 through 7) is the operand and the right byte (bits 8 through 15) is unchanged. - 2. Workspace register 0 may not be used for indexing. - 3. The workspace register is incremented by 1 for byte instructions (bit 3 = 1) and is incremented by 2 for word instructions (bit 3 = 0). - 4. When $T_S = T_D = 10$ , two words are required in addition to the instruction word. The first word is the source operand base address and the second word is the destination operand base address. | MNEMONIC | OP CODE<br>0 1 2 | | B<br>3 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|------------------|---|--------|--------------------------------|----------------------------|----------------------------|------------------------------------------------------| | A | 1 0 | 1 | 0 | Add | Yes | 0-4 | (SA)+(DA)→(DA) | | AB | 1 0 | 1 | 1 | Add bytes | Yes | 0-5 | $(SA)+(DA)\rightarrow(DA)$ | | С | 1 0 | 0 | 0 | Compare | No | 0-2 | Compare (SA) to (DA) and set appropriate status bits | | СВ | 1 0 | 0 | 1 | Compare bytes | No | 0-2,5 | Compare (SA) to (DA) and set appropriate status bits | | S | 0 1 | 1 | 0 | Subtract | Yes | 0-4 | $(DA) - (SA) \rightarrow (DA)$ | | SB | 0 1 | 1 | 1 | Subtract bytes | Yes | 0-5 | (DA) - (SA) *(DA) | | SOC | 1 1 | 1 | 0 | Set ones corresponding | Yes | 0-2 | (DA) OR (SA)→(DA) | | SOCB | 1 1 | 1 | 1 | Set ones corresponding bytes | Yes | 0-2,5 | (DA) OR (SA)→(DA) | | SZC | 0 1 | 0 | 0 | Set zeroes corresponding | Yes | 0-2 | (DA) AND (SA)→(DA) | | SZCB | 0 1 | 0 | 1 | Set zeroes corresponding bytes | Yes | 0-2,5 | (DA) AND (SA)→(DA) | | MOV | 1 1 | 0 | 0 | Move | Yes | 0-2 | (SA)→(DA) | | MOVB | 1 1 | 0 | 1 | Move bytes | Yes | 0-2,5 | $(SA) \rightarrow (DA)$ | Dual Operand Instructions with Multiple Addressing Modes for the Source Operand and Workspace Register Addressing for the Destination O 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 General format: OP CODE D T<sub>S</sub> S The addressing mode for the source operand is determined by the $T_{\rm S}$ field. | $T_{\rm S}$ | s | ADDRESSING MODE | NOTES | |-------------|----------|--------------------------------------------|-------| | 00 | 0, 1, 15 | Workspace register | | | 01 | 0, 1, 15 | Workspace register indirect | | | 10 | 0 | Symbolic | | | 10 | 1, 2, 15 | Indexed | 1 | | 11 | 0, 1, 15 | Workspace register indirect auto increment | 2 | NOTES: 1. Workspace register 0 may not be used for indexing. 2. The workspace register is incremented by 2. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|------------------------|--------------------------------|----------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | COC | 001000 | Compare ones corresponding | No | 2 | Test (D) to determine if 1's are in each bit position where 1's are in (SA). If so, set ST2. | | CZC | 001001 | Compare zeros<br>corresponding | No | 2 | Test (D) to determined if 0's are in each bit position where 1's are in (SA). If so, set ST2. | | XOR | 001010 | Exclusive OR | Yes | 0-2 | (D)⊕(SA)→(D) | | МРҮ | 001110 | Multiply | No | | Multiply unsigned (D) by unsigned (SA) and place unsigned 32 bit product in D (most significant) and D+1 (least significant). If WR15 is D, the next word in memory after WR15 will be used for the least significant half of the product. | | DIV | 001111 | Divide | No | 4 | If unsigned (SA) is less than or equal to unsigned (D), perform no operation and set ST4. Otherwise, divide unsigned (D) and (D+1) by unsigned (SA). Quotient $\rightarrow$ (D), remainder $\rightarrow$ (D+1). If D = 15, the next word in memory after WR15 will be used for the remainder. | ## Extended Operation (XOP) Instruction General format: | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | _15 | |---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|-----| | Ĺ | 0 | 0 | 1 | 0 | 1 | 1 | | | D | | r | 's | | s | | | The T<sub>S</sub> and S fields provide multiple mode addressing capability for the source operand. When the XOP is executed, ST6 is set and the following transfers occur: $(40_{16} + 4D) \rightarrow (WP)$ $(42_{16} + 4D) \rightarrow (PC)$ SA - (new WR11) (old WP) → (new WR13) (old PC) - (new WR14) $(old ST) \rightarrow (new WR15)$ The S9900 does not test interrupt requests (INTREQ) upon completion of the XOP instruction. # **Single Operand Instructions** O 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 General format: OP CODE T<sub>S</sub> S The $T_S$ and S fields provide multiple mode addressing capability for the source operand. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 8 9 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|--------------------------------|--------------------------------------|----------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | В | 0000010001 | Branch | No | _ | SA→(PC) | | BL | 0000011010 | Branch and link | No | _ | $(PC) \rightarrow (WR11); SA \rightarrow (PC)$ | | BLWP | 0000010000 | Branch and load<br>workspace pointer | No | - | (SA)→(WP); (SA+2)→(PC);<br>(old WP)→(new WR13);<br>(old PC)→(new WR14);<br>(old ST)→(new WR15);<br>the interrupt input (INTREQ)<br>is not tested upon completion<br>of the BLWP instruction. | | CLR | 0000010011 | Clear operand | No | | 0→(SA) | | SETO | 0000011100 | Set to ones | No | _ | FFFF <sub>16</sub> →(SA) | | INV | 0000010101 | Invert | Yes | 0.2 | (SA)→(SA) | | NEG | 0000010100 | Negate | Yes | 0-4 | -(\$A)→(\$A) | | ABS | 0000011101 | Absolute value* | No | 0-4 | i(SA) i→(SA) | | SWPB | 0 0 0 0 0 1 1 0 1 1 | Swap bytes | No | _ | (SA), bits 9 thru 7→(SA), bits 8 thru 15; (SA), bits 8 thru 15 → (SA), bits 0 thru 7. | | INC | 0000010110 | Increment | Yes | 0-4 | (SA)+1→(SA) | | INCT | 0000010111 | Increment by two | Yes | 0-4 | (SA)÷2→(SA) | | DEC | 0 0 0 0 0 1 1 0 0 0 | Decrement | Yes | 0-4 | (SA)—1→(SA) | | DECT | 0000011001 | Decrement by two | Yes | 0-4 | (SA)-2→(SA) | | X† | 0000010010 | Execute | Νo | _ | Execute the instruction at SA. | <sup>\*</sup>Operand is compared to zero for status bit. tlf additional memory words for the execute instruction are required to define the operands of the instruction located at SA, these words will be accessed from PC and the PC will be updated accordingly. The instruction acquisition signal (IAQ) will not be true when the S9900 accesses the instruction at SA, Status bits are affected in the normal manner for the instruction executed. # **CRU Multiple-Bit Instructions** General format: OP C | _0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |----|---|-----|-----|---|---|---|---|---|---|----|----|----|----|----|----| | | C | P C | ODE | | | | ( | C | | Т | `s | | | S | | The C field specifies the number of bits to be transferred. If C=0, 16 bits will be transferred. The CRU base register (WR12, bits 3 through 14) defines the starting CRU bit address. The bits are transferred serially and the CRU address is incremented with each bit transfer, although the contents of WR12 is not affected. $T_8$ and S provide multiple mode addressing capability for the source operand. If 8 or fewer bits are transferred (C=1 through 8), the source address is a byte address. If 9 or more bits are transferred (C=0,9 through 15), the source address is a word address. If the source is addressed in teh workspace register indirect auto increment mode, the workspace register is incremented by 1 if C=1 through 8, and is incremented by 2 otherwise. | MMEMONIC | | ( | )P ( | :OD | E | | MEANING | RESULT<br>COMPARED | STATUS<br>BITS | DESCRIPTION | |----------|---|---|------|-----|---|---|--------------------------------|--------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | MEANING | TO 0 | AFFECTED | DESCRIPTION | | LDCR | 0 | 0 | 1 | 1 | 0 | 0 | Load communication<br>register | Yes | 0-2,5† | Beginning with LSB of (SA),<br>transfer the specified number<br>of bits from (SA) to the CRU. | | STCR | 0 | 0 | 1 | 1 | 0 | 1 | Store communication register | Yes | 0-2,5† | Beginning with LSB of (SA),<br>transfer the specified number of<br>bits from the CRU to (SA). Load<br>unfilled bit positions with 0. | tST5 is affected only if $1 \le C \le 8$ . # **CRU Single-Bit Instructions** General format: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | _9_ | _10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|-----|-----|---|---|---|---|-----|-----|-------|------|-----|-----|----| | | | O | P C | ODE | | | | | S | | ED DI | SPLA | CEM | ENT | | #### CRU relative addressing is used to address the selected CRU bit. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 | MEANING | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|----------------------------|-----------------|----------------------------|-------------------------------------------| | SBO | 00011101 | Set bit to one | _ | Set the selected CRU output bit to 1. | | SBZ | 00011110 | Set bit to zero | _ | Set the selected CRU output bit to 0. | | тв | 00011111 | Test bit | 2 | If the selected CRU input bit=1, set ST2. | # Jump Instructions General format: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|-----|-----|---|---|---|---|---|----|------|------|-----|----|----| | | | C | P C | ODE | | | | | | D | ISPL | ACEM | ENT | | | Jump instructions cause the PC to be loaded with the value selected by PC relative addressing if the bits of ST are at specified values. Otherwise, no operation occurs and the next instruction is executed since PC points to the next instruction. The displacement field is a word count to be added to PC. Thus, the jump instruction has a range of -128 to 127 words from memory-word address following the jump instruction. No ST bits are affected by jump instruction. | MNEMONIC | | | O | P C | OD | E | _ | | MEANING | ST CONDITION TO LOAD PC | |-------------|---|---|---|-----|----|---|---|---|--------------------|-------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | MEANING | SI CONDITION TO LOAD PC | | JEQ | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Jump equal | ST2 = 1 | | JGT | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | Jump greater than | ST1 = 1 | | JH | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | Jump high | ST0 = 1 and $ST2 = 0$ | | JHE | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | Jump high or equal | ST0 = 1 or ST2 = 1 | | JL | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | Jump low | ST0 = 0 and $ST2 = 0$ | | JLE | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Jump low or equal | ST0 = 0 or ST2 = 1 | | $_{ m JLT}$ | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | Jump less than | ST1 = 0 and $ST2 = 0$ | | JMP | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Jump unconditional | unconditional | | JNC | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Jump no carry | ST3 = 0 | | JNE | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Jump not equal | ST2 = 0 | | JNO | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Jump no overflow | ST4 = 0 | | JOC | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Jump on carry | ST3 = 1 | | JOP | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | Jump odd parity | ST5 = 1 | # **Shift Instructions** General format: | _0 | 1 | 2 | 3 | 4 | 5 | 6 | 7_ | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |----|---|---|-----|-----|---|---|----|---|---|----|----|----|----|----|----| | | | C | P C | ODE | | | | | | С | | | | W | | If C = 0, bits 12 through 15 of WR0 contain the shift count. If C = 0 and bits 12 through 15 of WR0 = 0, the shift count is 16. | MNEMONIC | | | Ç | Р ( | 20 | DI | E | | | MEANING | RESULT<br>COMPARED | STATUS<br>BITS | DESCRIPTION | |-----------|---|---|---|-----|----|----|---|---|---|------------------------|--------------------|----------------|-----------------------------------------------------------------------| | MINEMONIC | 0 | 1 | 2 | 3 | | 4 | 5 | 6 | 7 | MEANING | TO 0 | AFFECTED | DESCRIPTION | | SLA | 0 | 0 | 0 | 0 | | 1 | 0 | 1 | 0 | Shift left arithmetic | Yes | 0-4 | Shift (W) left. Fill vacated bit positions with 0. | | SRA | 0 | 0 | 0 | 0 | 2 | 1 | 0 | 0 | 0 | Shift right arithmetic | Yes | 0-3 | Shift (W) right. Fill vacated bit positions with original MSB of (W). | | SRC | 0 | 0 | 0 | 0 | : | 1 | 0 | 1 | 1 | Shift right circular | Yes | 0-3 | Shift (W) right. Shift previous LSB into MSB. | | SRL | 0 | 0 | 0 | 0 | : | 1 | 0 | 0 | 1 | Shift right logical | Yes | 0-3 | Shift (W) right. Fill vacated bit positions with 0's. | # Immediate Register Instructions General format: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|---|----|----|----|---|---|---|----|----|----|----|----|----| | | | | | OP | CO | DE | | | | | Ŋ | | 1 | w | | | | | | | | | | | Ю | P | | | | | | | | MNEMONIC | OF CODE<br>0 1 2 3 4 5 6 7 8 9 10 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|-----------------------------------|-------------------|----------------------------|----------------------------|----------------------------------------------------| | AI | 00000010001 | Add immediate | Yes | 0-4 | (W)+IOP→(W) | | ANDI | 00000010010 | AND immediate | Yes | 0-2 | (W) AND IOP→(W) | | Cl | 00000010100 | Compare immediate | Yes | 0-2 | Compare (W) to IOP and set appropriate status bits | | LI | 00000010000 | Load immediate | Yes | 0-2 | IOP >(W) | | ORI | 00000010011 | OR immediate | Yes | 0-2 | (W) OR IOP→(W) | # Internal Register Load Immediate Instructions General format: | _ 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----|---|---|---|----|----|----|---|----|---|----|----|----|----|----|----| | | | | | OP | CO | DE | | | | | | | N | | | | | | | | | | | | ΙQ | P | | | | | | | | NATE WOMEO | | | | | OP | CC | DI | E | | | | MEANING | DESCRIPTION | |------------|---|---|---|---|----|----|----|---|---|---|----|----------------------------------|----------------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | MEANING | DBSGRR 11014 | | LWPI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Load workspace pointer immediate | IOP→(WP), no ST bits affected | | LIMI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Load interrupt mask | IOP, bits 12 thru 15→ST12<br>thru ST15 | # **Internal Register Store Instructions** General format: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|---|---|---|----|----|----|---|---|---|----|----|----|----|----|----| | | | | | OF | co | DE | | | | | N | | • | W | | # No ST bits are affected. | MNEMONIC | | OP CODE | | | | | | | | | | MEANING | DESCRIPTION | | | |----------|---|---------|---|---|---|---|---|---|---|----|----|-------------------------|-------------|--|--| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | MEANING | DESCRIPTION | | | | STST | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Store status register | (ST)→(W) | | | | STWP | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | ,0 | 1 | Store workspace pointer | (WP)→(W) | | | # Return Workspace Pointer (RTWP) Instruction General format: | | | | | | | | | | | | 11 | 12 | 13 | 14 | 15 | |---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | | N | | | The RTWP instruction causes the following transfers to occur: $(WR15) \rightarrow (ST)$ $(WR14) \rightarrow (PC)$ $(WR13) \rightarrow (WP)$ # **External Instructions** General format: | 0 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----|---|---|----|----|---|---|---|---|----|----|----|----|----|----| | | | | OP | co | | | | | | | | N | | | External instructions cause the three most-significant address lines (A0 through A2) to be set to the below described levels and the CRUCLK line to be pulsed, allowing external control functions to be initiated. | MNEMONIC | OP CODE 0 1 2 3 4 5 6 7 8 9 10 | | MEANING | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | | ADDRESS<br>BUS<br>A0 A1 A2 | | | | | | | | |----------|--------------------------------|-----|---------|----------------------------|-------------|---|----------------------------|---|--------------|-------------|-------------------------------------------------------------------------------|---|---|---| | IDLE | 000 | 0 | 0 1 | ) 1 | 1 | 0 | 1 | 0 | <b>Idle</b> | <del></del> | Suspend S9900 instruction execution until an interrupt, LOAD, or RESET occurs | L | H | L | | RSET | 000 | 0 ( | 0 ( | 1 | 1 | 0 | 1 | 1 | Reset | 12-15 | 0→ST12 through ST15 | L | Н | H | | CKOF | 000 | 0 ( | 0 ( | ) 1 | 1 | 1 | 1 | 0 | User defined | | _ | Н | Н | L | | CKON | 0.00 | 0 ( | 0 ( | 1 | 1 | 1 | 0 | 1 | User defined | | _ | н | L | H | | LREX | 000 | 0 ( | 0 ( | 1 | 1 | 1 | 1 | 1 | User defined | , | _ | H | H | Н | # \$9900 Instruction Execution Times Instruction execution times for the S9900 are a function of: - 1) Clock cycle time, t<sub>c(o)</sub> - Addressing mode used where operands have multiple addressing mode capability - 3) Number of wait states required per memory ac- Table 3 lists the number of clock cycles and memory accesses required to execute each S9900 instruction. For instructions with multiple addressing modes for either or both operands, the table lists the number of clock cycles and memory accesses with all operands addressed in the workspace-register mode. To determine the additional number of clock cycles and memory accesses required for modified addressing, add the Table 3. Instruction Execution Times | ABS (MSB = D)<br>(MSB = 1) | 14<br>14<br>14<br>12 | M<br>4 | SOURCE | DEST | | CYCLES<br>C | ACCESS<br>M | SOURCE | CATION†<br>DEST | |-----------------------------|----------------------|--------|----------|------|-------------------------------|-------------|-------------|--------|-----------------| | AB (MSB = 0) (MSB = 1) | 14 | | I A I | Α | LWPI | 10 | 2 | | _ | | ABS (MSB = 0)<br>(MSB = 1) | | 4 | B | B | MOV | 14 | 4 | A | Α | | (MSB = 1) | , , | 2 | l a l | _ | MOVB | 14 | 4 | ß | B | | 1 | 14 | 4 | Ä | _ | MPY | 52 | 5 | Ä | | | AI I | 14 | 4 | '' | _ | NEG | 12 | 3 | Â | _ | | AND! | 14 | 4 | _ | _ | ÖRÏ | 14 | 4 | | _ | | B | 8 | | l a l | | RSET | 12 | l i | _ | _ | | ēL l | 12 | 2 3 | A I | _ | RTWP | 14 | 4 | _ | _ | | BLWP | 26 | 6 | A | _ | s | 14 | 4 | A | Α | | c l | 14 | 3 | L A I | Α | SB | 14 | 4 | B 1 | В | | CB | 4 | 3 | В | В | SBO | 12 | 2 | _ : | i <u>-</u> | | Ċi . | 14 | 3 | _ | _ | SBZ | 12 | 2 | | _ | | CKDF | 12 | 1 | _ | _ | SETO | 10 | 3 | A | _ | | CKON | 12 | 1 | - | _ | Shift (C≠0) | 12+20 | 3 | | _ | | CLR | 10 | 3 | l a l | _ | (C=0, Bits 12-15 | , ,, ,, | • | | | | coc | 14 | 3 | l a l | _ | of WRO = 0) | 52 | 4 | | _ | | czc | 14 | 3 | A | _ | (C=0, Bits 12-15 | | | | | | DEC | 10 | 3 | A | _ | of WRP=N≠0) | 20+2N | 4 | _ | _ | | DECT | 10 | 3 | l A l | | SOC | 14 | 4 | A | A | | DIV (ST4 is set) | 16 | 3 | l a l | | SDCB | 14 | 4 | В | В | | DIV (ST4 is reset)* | 92 - 124 | 6 | l a l | _ | STCH (C=0) | 60 | 4 | Ā | _ | | IDLE | 12 | 1 1 | | _ | (1 ≤ C ≤ 7) | 42 | 4 | В | _ | | INC | 10 | 3 | l a l | | (C=8) | 44 | 4 | В | _ | | INCT | 10 | 3 | A | _ | (9≤ € ≤15) | 58 | 4 | Ā | _ | | INV | 10 | 3 | l a l | _ | STST | 8 | 2 | _ | _ | | Jump (PC is | | _ | | | STWP | 8 | 2 | _ | _ | | changed) | 10 | 1 | _ | _ | SWPB | 10 | 3 | A | _ | | (PC is not | | | l | | SZC | 14 | 4 | A | Α | | changed) | 8 | 1 | - | _ | SZCB | 14 | 4 | В | В | | LOCR (C = 0) | 52 | 3 | l a l | _ | TB | 12 | 2 | _ | _ | | (1≤C≤8) | 20+2C | 3 | 8 | _ | X** | 8 | 2 | A | _ | | (9≤C≤15) | 20+2C | 3 | Ā | _ | XOP | 36 | 8 | À | _ | | Li | 12 | 3 | _ | | XOR | 14 | 4 | Α | _ | | LIMI | 16 | 2 | _ | | | | | | | | LREX | 12 | Ī | ! - ! | _ | | | | | | | BESET function | 26 | 5 | <u> </u> | | Undefined ap codes | | | | | | LOAD function | 22 | 5 | _ | _ | 0000-01FF, 0320- | 6 | 1 | _ | _ | | Interrupt context<br>switch | 22 | 5 | | _ | 033F, 0C00-0FFF,<br>0780-07FF | J | ' | _ | _ | <sup>\*</sup>Execution time is dependent upon the partial quotient after each clock cycle during execution. <sup>\*\*</sup>Execution time is added to the execution time of the instruction located at the source address minus 4 clock cycles and 1 memory access time. †The letters A and B refer to the respective tables that follow. Table A Address Modification | ADDRESSING MODE | CYCLES<br>CYCLES<br>C | MEMORY<br>Accesses<br>M | |-----------------------------------------------------------------------|-----------------------|-------------------------| | WR (T <sub>S</sub> or T <sub>D</sub> = 00) | 0 | 0 | | WR indirect ( $T_S$ or $T_D = 01$ ) | 4 | 1 | | WR indirect auto-increment<br>{T <sub>S</sub> or T <sub>0</sub> = 11} | 8 | 2 | | Symbolic (T <sub>S</sub> or T <sub>D</sub> = 10,<br>S or D = 0) | В | 1 | | Indexed ( $T_S$ or $T_D = 10$ ,<br>S or $D \neq 0$ ) | 8 | 2 | Table B Address Modification | ADDRESSING MODE | CLOCK<br>CYCLES<br>C | MEMORY<br>Accesses<br>M | |-----------------------------------------------------|----------------------|-------------------------| | WR (T <sub>S</sub> or T <sub>O</sub> =00) | 0 | 0 | | WR indirect ( $T_S$ or $T_D = 01$ ) | 4 | 1 | | WR indirect auto-increment (Ts or Tp = 11) | 6 | 2 | | Symbolic ( $T_S$ or $T_D = 10$ , $S$ or $D = 0$ ) | 8 | 1 | | Indexed ( $T_S$ or $T_D = 10$ , $S$ or $D \neq 0$ ) | 8 | 2 | appropriate values from the referenced tables. The total instruction-execution time for an instruction is: $$T = t_{c(\phi)}(C + W \cdot M)$$ where: T = total instruction execution time; $t_{e(\phi)} = clock$ cycle time; e number of clock cycles for instruction execution plus address modification; W = number of required wait states per memory access for instruction execution plus address modification — no wait states used unless accessing slow memory; M = number of memory accesses. As an example, the instruction MOVB is used in a system with $t_{c(\phi)}=0.333~\mu s$ and no wait states are required to access memory. Both operands are addressed in the workspace register mode: $T=t_{c(a)}\left(C+W\cdot M\right)=0.333\left(14+0.4\right)\,\mu s=4.662\mu s.$ If two wait states per memory access were required, the execution time is: $$T = 0.333 (14 + 2.4) \mu s = 7.326 \mu s$$ . If the source operand was addressed in the symbolic mode and two wait states were required: $$\begin{array}{lll} T &=& t_{c(\phi)} \left( C &+& W \cdot M \right) \\ C &=& 14 &+& 8 &=& 22 \\ M &=& 4 &+& 1 &=& 5 \\ T &=& 0.333 \left( 22 &+& 2 \cdot 5 \right) \mu s &=& 10.656 \mu s. \end{array}$$ #### System Design Examples Figure 13 illustrates a typical minimum S9900 system. Eight bits of input and output interface are implemented. The memory system contains 1024x16 ROM and 1024x16 RAM memory blocks. The total package count for this system is 13 packages. A maximum S9900 microprocessor system is illustrated in Figure 14. ROM and RAM are both shown for a total of 65,536 bytes of memory. The I/O interface supports 4096-output bits and 4096-input bits. Fifteen external interrupts are implemented in the interrupt interface. The clock generator and control section contains memory decode logic, synchronization logic, and the clock electronics. Bus buffers, required for this maximally configured system, are indicated on the system buses. # Instruction Summary | MNEMONIC | OP CODE | FORMAT | RESULT<br>COMPARED<br>TO ZERO | STATUS<br>AFFECTED | INSTRUCTIONS | |----------|---------|--------|-------------------------------|--------------------|----------------------------------------| | A | A000 | 1 | Υ | 0-4 | ADD(WORD) | | AB | 8000 | 1 | Y | 0-5 | ADD(BYTE) | | ABS | 0740 | 6 | Y | 0-4 | ABSOLUTE VALUE | | AI | 0220 | 8 | Y | 0-4 | ADD IMMEDIATE | | ANDI | 0240 | 8 | Υ | 0-2 | AND IMMED∤ATE | | В | 0440 | 6 | N | | BRANCH | | BL | 0880 | 6 | N | _ | BRANCH AND LINE (W11) | | BLWP | 0400 | 6 | N | | BRANCH LOAD WORKSPACE POINTER | | C | 8000 | 1 | N | 0-2 | COMPARE (WORD) | | CB | 9000 | 1 | N | 0-2,5 | COMPARE (BYTE) | | C1 | 0280 | 8 | N | 0-2 | COMPARE IMMEDIATE | | CKOF | 0300 | 7 | N_ | | EXTERNAL CONTROL | | CKON | 03A0 | 7 | N | ' | EXTERNAL CONTROL | | CLR | 0400 | 6 | N | _ | CLEAR OPERAND | | COC | 2000 | 3 | N | 2 | COMPARE ONES CORRESPONDING | | CZC | 2400 | 3 | N | 2 | COMPARE ZEROES CORRESPONDING | | DEC | 0600 | , 6 | Y | 0-4 | DECREMENT (BY ONE) | | DECT | 0640 | 6 | Y | 0-4 | DECREMENT (BY TWO) | | DIV | 3000 | 9 | N | 4 | DIVIDE | | IDLE | 0340 | 7 | N | | COMPUTER IDLE | | INC | 0580 | 6 | Y | 0-4 | INCREMENT (BY ONE) | | INCT | 0500 | 6 | Υ | 0-4 | (NCREMENT (BY TWO) | | INV | 0540 | 6 | Y | 0-2 | INVERT (ONES COMPLEMENT) | | JEQ | 1300 | 2 | N | | JUMP EQUAL (ST2=1) | | JGT | 1500 | 2 | N | _ | JUMP GREATER THAN (ST1=1) | | JH | 1800 | 2 | N N | _ | JUMP HIGH (ST0=1 AND ST2=0) | | JHE | 1400 | 2 | N | | JUMP HIGH OR EQUAL (STO OR ST2=1) | | JL | 1A00 | 2 | N | | JUMP LOW (STO AND ST2=0) | | JLE | 1200 | 2 | N | _ | JUMP LOW OR EQUAL (STO=0 OR ST2=1) | | JLT | 1100 | 2 | N | - | JUMP LESS THAN (ST1 AND ST2=0) | | JMP | 1000 | 2 | N | - | JUMP UNCONDITIONAL | | INC | 1700 | 2 | N | <u> </u> | JUMP NO CARRY (ST3=0) | | INE | 1600 | 2 | N | - | JUMP NOT EQUAL (ST2=0) | | INO | 1900 | 2 | N | - | JUMP NO OVERFLOW (ST4=0) | | 100 | 1800 | 2 | N | _ ] | JUMP ON CARRY (ST3=1) | | JOP | 1000 | 2 | N N | _ | JUMP ODD PARITY (ST5=1) | | LDCR | 3000 | 4 | Y | 0-2,5 | LOAD CRU | | Lt | 0200 | 8 | N | 0-2 | LOAD IMMEDIATE | | LIMI | 0300 | 8 | N | 12-15 | LOAD IMMEDIATE TO INTERRUPT MASK | | LREX | 03E0 | 7 | N | 12-15 | EXTERNAL CONTROL | | LWPI | 02E0 | 8 | N | - | LOAD IMMEDIATE TO WORKSPACE<br>POINTER | | MDV | C000 | 1 | Y | 0-2 | MOVE (WORD) | | MOVB | D000 | 1 | Y | 0-2,5 | MOVE (BYTE) | | MPY | 3800 | 9 | N | _ | MULTIPLY | Instruction Summary (Continued) | MNEMONIC | OP CODE | FORMAT | RESULT<br>COMPARED<br>TO ZERO | STATUS<br>AFFECTED | INSTRUCTIONS | |----------|---------|--------|-------------------------------|--------------------|---------------------------------| | NEG | 0500 | 6 | Υ | 0-4 | NEGATE (TWO'S COMPLEMENT) | | 0RI | 0260 | 8 | Y | 0-2 | ORIMMEDIATE | | RSET | 8360 | 7 | N | 12-15 | EXTERNAL CONTROL | | RTWP | 0380 | 7 | N | 0-6, 12-15 | RETURN WORKSPACE POINTER | | S | 6000 | 1 | Y | 0-4 | SUBTRACT (WORD) | | SB | 7000 | 1 | Υ | 0-5 | SUBTRACT (BYTE) | | SB0 | 1000 | 2 | N. | _ | SET CRU BIT TO ONE | | SBZ | 1E00 | 2 | N | _ | SET CRU BIT TO ZERO | | SETO | 0700 | 6 | N | | SET ONES | | SLA | 0A00 | . 5 | Y | 0.4 | SHIFT LEFT (ZERO FILL) | | SOC | E000 | 1 | Y | 0-2 | SET ONES CORRESPONDING (WORD) | | SOCB | F000 | 1 | Y | 0-2,5 | SET ONES CORRESPONDING (BYTE) | | SRA | 0800 | 5 | Υ | 0-3 | SHIFT RIGHT (MSB EXTENDED) | | SRC | 0800 | 5 | Υ | 0-3 | SHIFT RIGHT CIRCULAR | | SRL | 0900 | 5 | Υ | 0-3 | SHIFT RIGHT (LEADING ZERO FILL) | | STCR | 3400 | 4 | Υ | 0-2,5 | STORE FROM CRU | | STST | 02Ç0 | 8 | N | _ | STORE STATUS REGISTER | | STWP | 02A0 | 8 | N | _ | STORE WORKSPACE POINTER | | SWPB | 06C0 | 6 | N | ! - | SWAP BYTES | | SZC | 4000 | 1 | Y | 0-2 | SET ZERDES CORRESPONDING (WORD) | | SZCB | 5000 | 1 | Y | 0-2,5 | SET ZEROES CORRESPONDING (BYTE) | | TB | 1F00 | 2 | N | 2 | TEST CRU BIT | | Х | 0480 | 6 | N | _ | EXECUTE | | XOP | 2000 | 9 | N | 6 | EXTENDED OPERATION | | XOR | 2800 | 3 | Υ | 0-2 | EXCLUSIVE OR | ILLEGAL OP CODES 0000-01FF, 0320-033F, 0780-07FF, 0C00-0FFF # Programmable Systems Interface Circuit ### **Features** - N-Channel Silicon-Gate Process - 9900 Series CRU Peripheral - Performs Interrupt and I/O Interface Functions - 6 Dedicated Interrupt Input Lines - 7 Dedicated I/O Ports - 9 Ports Programmable as Interrupts or I/O - Easily Stacked for Interrupt and I/O Expansion - Interval and Event Timer - Single 5V Supply # **General Description** The S9901 Programmable Systems Interface is a multifunctioned component designed to provide low cost interrupts and I/O ports in a 9900/9980 microprocessor system. It is fabricated with N-channel silicon-gate technology and is completely TTL compatible on all inputs including the power supply (+5V) and single-phase clock. Figure 1 is a block diagram of the S9901. The Programmable Systems Interface provides a 9900/9980 system with interrupt control, I/O ports, and a real-time clock as shown in Figure 2. # **S9901 Electrical Specifications** Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otherwise Noted)\* | Supply Voltages, V <sub>CC</sub> and V <sub>SS</sub> 0.3V to +10V | |-------------------------------------------------------------------| | All Input and Output Voltages | | Continuous Power Dissipation | | Operating Free-Air Temperature Range | | Storage Temperature Range65°C to +150°C | <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute maximum rated conditions for extended period may affect device reliability. #### Recommended Operating Conditions | Parameter | Min. | Nom. | Max. | Unit | |------------------------------------------|------|------|------|------| | Supply Voltage, V <sub>CC</sub> | 4.75 | ō | 5.25 | V | | Supply Voltage, V <sub>SS</sub> | | 0 | | v | | High-Level Input Voltage, VIH | | 2 | | V | | Low-Level Input Voltage, V <sub>IL</sub> | | 0.8 | Ì | v | | Operating Free-Air Temperature, TA | 0 | | 70 | °C | Electrical Characteristics Over Full Range of Recommended Operating Conditions (Unless Otherwise Noted) | Symbol | Parameter | Min. | Typ. | Max. | Unit | Conditions | |--------------------------------------|---------------------------------------------|------|------|------|---------|----------------------------------------------------------| | I | Input Current (Any Input) | | ±10 | | $\mu A$ | $V_I = 0V$ to $V_{CC}$ | | <b>T</b> 7 | High I and Ontant Walters | | 2.4 | | V | $I_{\mathrm{OH}}$ = 100 $\mu$ A | | $v_{OH}$ | High Level Output Voltage | | 2 | | μА | $I_{OH} = -400 \mu A$ | | $v_{\scriptscriptstyle \mathrm{OL}}$ | Low Level Output Voltage | | 0.4 | | v | $I_{\rm OL}$ = $3.2 {\rm mA}$ | | $I_{CC}$ | Supply Current from V <sub>CC</sub> | | 100 | | mA | | | $I_{SS}$ | Supply Current from V <sub>SS</sub> | | 200 | | mA | | | I <sub>CC(av)</sub> | Average Supply Current from V <sub>CC</sub> | | 60 | | mA | $t_{c(\phi)} = 333 \text{ns}, T_A = 25^{\circ} \text{C}$ | | Ci | Capacitance, Any Input | | 10 | | pF | f = 1MHz, | | Co | Capacitance, Any Output | | 20 | | pF | All Other Pins at 0V | # Timing Requirements Over Full Range of Operating Conditions | Symbol | Parameter | Min. | Nom. | Max. | Unit | |------------------------------------|---------------------------------------------------|------|------|------|------| | $t_{c(\phi)}$ | Clock Cycle Time | | 333 | | ns | | t <sub>r(φ)</sub> | Clock Rise Time | | 10 | | ns | | t <sub>f(\phi)</sub> | Clock Fall Time | | 10 | | ns | | t <sub>w(<math>\phi</math>L)</sub> | Clock Pulse Low Width | | 55 | | ns | | $t_{w(\phi H)}$ | Clock Pulse High Width | | 240 | 1 | ns | | t <sub>su</sub> | Setup Time for S0-S1, CE, or CRUOUT before CRUCLK | | 200 | | ns | | t <sub>su</sub> | Setup Time, Input Before Valid CRUIN | | 200 | | ns | | t <sub>su</sub> | Setup Time, Interrupt Before $\phi$ Low | | 40 | | ns | | tw(CRUCLK) | CRU Clock Pulse Width | | 100 | | ns | | t <sub>h</sub> | Address Hold Time | | 80 | | ns | # Switching Characteristics Over Full Range of Recommended Operating Conditions | Symbol | Parameter | Min. | Тур. | Max. | Unit | Test Conditions | |----------|---------------------------------------------------------------------------------|------|------|------|------|----------------------------------------| | $t_{PD}$ | Propagation Delay, \$\overline{\phi}\$ Low to Valid INTREQ, I_{CO} \cdot I_{C3} | | 80 | | ns | C <sub>L</sub> = 100pF,<br>2 TTL Loads | | $t_{PD}$ | Propagation Delay, S0-S4 or $\overline{\text{CE}}$ to Valid CRUIN | | 400 | | ns | $C_{ m L}$ = 100pF | # Pin Definitions Table 1 defines the S9901 pin assignments and describes the function of each pin. Table 1. S9901 Pin Assignments and Functions | Signature | Pin | I/O | Description | |-------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | INTREQ | 11 | OUT | INTERRUPT Request. When active (low) INTREQ indicates that an enabled interrupt has been received. INTREQ will stay active until all enabled interrupt inputs are removed. | | ICO (MSB)<br>IC1<br>IC2<br>IC3 (LSB) | 15<br>14<br>13<br>12 | OUT<br>OUT<br>OUT<br>OUT | Interrupt Code lines. ICO-IC3 output the binary code corresponding to the highest priority enabled interrupt. If no enabled interrupts are active ICO-IC3 = $(1,1,1,1)$ . | | <u>CE</u> | 5 | IN | Chip Enable. When active (low) data may be transferred through the CRU interface to the CPU. $\overline{\text{CE}}$ has no effect on the interrupt control section. | | S0<br>S1<br>S2<br>S3<br>S4 | 39<br>36<br>35<br>25<br>24 | IN<br>IN<br>IN<br>IN<br>IN | Address select lines. The data bit being accessed by the CRU interface is specified by the $5\cdot$ bit code appearing on S0-S4. | | CRUIN | 4 | OUT | CRU data in (to CPU). Data specified by S0-S4 is transmitted to the CPU by CRUIN. When $\overline{\text{CE}}$ is not active CRUIN is in a high-impedance state. | | CRUOÚT | 2 | IN | CRU data out (from CPU). When $\overline{\text{CE}}$ is active, data present on the CRUOUT input will be sampled during CRUCLK and written into the command bit specified by S0·S4. | | CRUCLK | 3 | IN | CRU Clock (from CPU). CRUCLK specifies that valid data is present on the CRUOUT line. | | RST1 | 1 | IN | Power Up Reset. When active (low) RST1 resets all interrupt masks to "0", disables the clock, and programs all I/O ports to inputs. RST1 has a Schmitt-Trigger input to allow implementation with an RC circuit as shown in Figure 6. | | $v_{cc}$ | 40 | | Supply Voltage. +5V nominal. | | $V_{SS}$ | 16 | | Ground Reference | | φ | 10 | | System clock ( $\overline{\phi}$ 3 in S9900 system, $\overline{ ext{CKOUT}}$ in S9980 system). | | NT1<br>INT2<br>INT3<br>INT4<br>INT5<br>INT6 | 17<br>18<br>9<br>8<br>7<br>6 | IN<br>IN<br>IN<br>IN<br>IN | Group 1, interrupt inputs. When active. (Low) the signal is ANDed with its corresponding mask bit and if enabled sent to the interrupt control section. INT1 has highest priority. | | INT7/P15<br>INT8/P14<br>INT9/P13<br>INT10/P12<br>INT11/P11<br>INT12/P10<br>INT13/P9<br>INT14/P8<br>INT15/P7 | 34<br>33<br>32<br>31<br>30<br>29<br>28<br>27<br>23 | I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O | Group 2, Programmable interrupt (active low) or I/O pins (true logic). Each pin is individually programmable as an interrupt, an input port, or an output port. | | P0<br>P1<br>P2<br>P3<br>P4<br>P5<br>P6 | 38<br>37<br>26<br>22<br>21<br>20<br>19 | I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O | Group 3, I/O ports (true logic). Each pin is individually programmable as an input port or an output port. | ### Functional Description #### CPU Interface The S9901 interfaces to the CPU through the Communications Register Unit (CRU) and the interrupt control lines as shown in Figure 1. The CRU interface consists of 5 address select lines (S0-S4), chip enable $(\overline{CE})$ , and 3 CRU lines (CRUIN, CRUOUT, CRUCLK). When CE becomes active (low), the 5 select lines point to the CRU bit being accessed (see Table 2). In the case of a write, the datum is strobed off the CROUT line by the CRUCLK signal. For a read, the datum is sent to the CPU on the CRUIN line. The interrupt control lines consist of an interrupt request line (INTREQ) and 4 code lines (ICO-IC3). The interrupt section of the S9901 prioritizes and encodes the highest priority active interrupt into the proper code to present to the CPU, and outputs this code on the 1C0-1C3 code lines along with an active INTREQ. Several S9901's can be used with the CPU by connecting all CRU and address lines in parallel and providing a unique chip select to each device. #### System Interface The system interface consists of 22 pins divided into 3 groups. The 6 pins in Group 1 (INT1-INT6) are normally dedicated to interrupt inputs (active low), but may also be used as input ports (true data in). Group 2 (INT7/P15-INT15/P7) consists of 9 pins which can be individually programmed as interrupt inputs (active low), input worts (true data in), or output ports (true data out). The remaining 7 pins which comprise Group 3 (P0-P6) are dedicated as individually programmable I/O ports (true data). #### Interrupt Control A block diagram of the interrupt control section is shown in Figure 4. The interrupt inputs (6 dedicated, 9 programmable) are sampled by $\bar{\phi}$ (active low) and are ANDED with their respective mask bits. If an interrupt input is active (low) and enabled (MASK=1), the signal is passed through to the priority encoder where the highest priority signal is encoded into a 4-bit binary code as shown in Table 3. The code along with the interrupt request is then output via the CPU interface on the leading edge of the next $\bar{\phi}$ to ensure proper synchronization to the processor. The output signals will remain valid until the corresponding interrupt input is removed, the interrupt is disabled (MASK=0), or a higher priority enabled interrupt becomes active. When the highest priority enabled interrupt is removed, the code corresponding to the next highest priority enabled interrupt is output. If no enabled interrupt is active, all CPU interface lines (INTREQ, ICO-1C3) are held high. RST1 (power-up-reset) will force the output code to (0,0,0,0) with INTREQ held high and will reset all mask bits low (interrupts disabled). Individual interrupts can be subsequently enabled (disabled) by programming the appropriate command bits. Unused interrupt inputs may be used as datum inputs by disabling the interrupt (MASK=0). #### Input/Output A block diagram of the I/O section is shown in Figure 5. Up to 16 individually controlled I/O ports are available (7 dedicated, 9 programmable). $\overline{RST}1$ or $\overline{RST}2$ (a command bit) will program all ports to the input mode. Writing a datum to any port will program that port to the output mode and latch out the datum. The port will then remain in the output mode until either $\overline{RST}1$ or RST2 is executed. Data present on the Group 2 pins can be read by either the Read Interrupt Commands or the Read Input Commands, Group 2 pins being used as input ports should have their respective Interrupt Mask values reset (low) to prevent false interrupts from occurring. In applications where Group 1 pins are not required as interrupt inputs, they may be used as input ports and read using the Read Input commands. As with Group 2 ports, any pins being used as input ports should have their respective Interrupt Masks disabled. Table 2. CRU Bit Assignments | CRU Bit | so | S1 | S2 | S3 | S4 | CRU Read Data | CRU Write Data | |------------|----|----|----|----|-----|----------------|-----------------| | 0 | 0 | 0 | 0 | o | 0 | CONTROL BIT(1) | CONTROL BIT(1) | | 1 | 0 | 0 | 0 | 0 | 1 | INT1/CLK1(2) | Mask 1/CLK1(3) | | 2 | 0 | 0 | 0 | 1 | 0 | INT2/CLK2 | Mask 2/CLK2 | | 3 | 0 | 0 | 0 | 1 | 1 | ĪNT3/CLK3 | Mask 3/CLK3 | | 4 | 0 | 0 | 1 | 0 | 0 | ĪNT4/CLK4 | Mask 4/CLK4 | | 5 | 0 | 0 | 1 | 0 | 1 | ĪNT5/CLK5 | Mask 5/CLK5 | | 6 | 0 | 0 | 1 | 1 | 0 | INT6/CLK6 | Mask 6/CLK6 | | 7 | 0 | 0 | 1 | 1 | 1 | INT7/CLK7 | Mask 7/CLK7 | | 8 | 0 | 1 | 0 | 0 | 0 | INT8/CLK8 | Mask 8/CLK8 | | 9 | 0 | 1 | 0 | 0 | 1 | INT9/CLK9 | Mask 9/CLK9 | | 10 | 0 | 1 | 0 | 1 | 0 | INT10/CLK10 | Mask 10/CLK10 | | 11 | 0 | 1 | 0 | 1 | 1 | INT11/CLK11 | Mask 11/CLK11 | | 12 | 0 | 1 | 1 | 0 | 0 | INT12/CLK12 | Mask 12/CLK12 | | 13 | 0 | 1 | 1 | 0 | 1 | INT13/CLK13 | Mask 13/CLK13 | | 14 | 0 | 1 | 1 | 1 | 0 | INT14/CLK14 | Mask 14/CLK14 | | <b>1</b> 5 | 0 | 1 | 1 | 1 | 1 | INT15/INTREQ | Mask 15/RST2(4) | | 16 | 1 | 0 | 0 | 0 | 0 | PO INPUT(5) | P0 Output(6) | | 17 | 1 | 0 | 0 | 0 | 1 | P1 Input | P1 Output | | 18 | 1 | 0 | 0 | 1 | 0 | P2 Input | P2 Output | | 19 | 1 | 0 | 0 | 1 | 1 | P3 Input | P3 Output | | 20 | 1 | 0 | 1 | 0 | 0 | P4 Input | P4 Output | | 21 | 1 | 0 | 1 | 0 | 1 | P5 Input | P5 Output | | 22 | 1 | 0 | 1 | 1 | 0 | P6 Input | P6 Output | | <b>2</b> 3 | 1 | 0 | 1 | 1 | 1 | P7 Input | P7 Output | | 24 | 1 | 1 | 0 | 0 | 0 - | P8 Input | P8 Output | | 25 | 1 | 1 | 0 | 0 | 1 | P9 Input | P9 Output | | 26 | 1 | 1 | 0 | 1 | 0 | P10 Input | P10 Output | | 27 | 1 | 1 | 0 | 1 | 1 | P11 Input | P11 Output | | 28 | 1 | 1 | 1 | 0 | 0 | P12 Input | P12 Output | | 29 | 1 | 1 | 1 | 0 | 1 | P13 Input | P13 Output | | 30 | 1 | 1 | 1 | 1 | 0 | P14 Input | P14 Output | | 31 | 1 | 1 | 1 | 1 | 1 | P15 Input | P15 Output | NOTES: (1) 0 - Interrupt Mode 1 = Clock Mode (2) Data present on INT input pin (or clock value) will be read regardless of mask value. <sup>(3)</sup> While in the Interrupt Mode (Control Bit = 0) writing a "1" into mask will enable interrupt; a "0" will disable. <sup>(4)</sup> Writing a zero to bit 15 while in the clock mode (Control Bit = 1) executes a software reset of the I/O pins. <sup>(5)</sup> Data present on the pin will be read. Output data can be read without affecting the data. <sup>(6)</sup> Writing data to the port will program the port to the output mode and output the data. Table 3 Interrupt Code Generation | Interrupt/State | Priority | IC0 | IC1 | IC2 | IC3 | INTREQ | |---------------------------|-------------|-----|-----|-----|-----|--------| | INT1 | 1 (HIGHEST) | 0 | 0 | 0 | 1 | 0 | | $\overline{\text{INT}}$ 2 | 2 | 0 | 0 | 1 | 0 | 0 | | INT3/CLOCK | 3 | 0 | 0 | 1 | 1 | 0 | | ĪNT4 | 4 | 0 | 1 | 0 | 0 | 0 | | INT5 | 5 | 0 | 1 | 0 | 1 | 0 | | <del>INT</del> 6 | 6 | 0 | 1 | 1 | 0 | 0 | | ĪNT7 | 7 | 0 | 1 | 1 | 1 | . 0 | | INT8 | 8 | 1 . | 0 | 0 | 0 | 0 | | ĪNT9 | 9 | 1 | 0 | 0 | 1 | 0 | | ĪNT10 | 10 | 1 | 0 | 1 | 0 | 0 | | ĪNT11 | 11 | 1 | 0 | 1 | 1 | 0 | | INT12 | 12 | 1 | 1 | 0 | 0 | 0 | | INT13 | 13 | 1 | 1 | 0 | 1 | 0 | | INT14 | 14 | 1 | 1 | 1 | 0 | 0 | | ĪNT15 | 15 (LOWEST) | 1 | 1 | 1 | 1 | 0 | | NO INTERRRUPT | - | 1 | 1 | 1 | 1 | 1 | #### Programmable Real Time Clock A block diagram of the programmable real time clock section is shown in Figure 6. The clock consists of a 14-bit counter that decrements at a rate of $F(\phi)/64$ (at 3MHz this results in a maximum interval of 349ms with a resolution of $21.3\mu s$ ) and can be used as either an interval timer or as an event timer. The clock is accessed by writing a one into the control bit (address 0) to force CRU bits 1-15 to clock mode. (See Table 1.) Writing a nonzero value into the clock register then enables the clock and sets its frequency. During system set up this entire operation can be accomplished with one additional I/O instruction (LCDR) as shown in Table 4. The clock functions as an interval timer by decrementing to zero, issuing an intervupt, and restarting at the programmed start value. When the clock interrupt is active, the clock mask (mask bit 3) must be written into (with either a "1" or a "0") to clear the interrupt. If a value other than that initially programmed is required, a new 14-bit clock start value is similarly programmed by executing a CRU write operation to the same locations. During programming the decrementer is restarted with the current start value after each start value bit is written. A timer restart can be easily implemented by writing a single bit to any of the clock bits. The clock is disabled by RSTI (power-up-clear) or by writing a zero value into the clock register. Enabling the clock programs the third priority interrupt (INT3) as the clock interrupt and disables generation of interrupts from the INT3 input pin. When accessing the clock all interrupts should be disabled to ensure that system integrity is maintained. The clock can also function as an event timer since whenever the device is switched to the clock mode, by writing a one to the control bit, the current value of the clock is stored in the clock read register. Reading this value, and thus the elapsed event time, is accomplished by executing a 14-bit CRU read operation (addresses 1-14). The software example (Table 3) shows a read of the event timer. The current status of the machine can always be obtained by reading the control (address zero) bit. A "0" indicates the machine is in an interrupt mode. Bits 1 through 15 would normally be the interrupt input lines in this mode, but if any are not needed for interrupts they may also be read with a CRU input command and interpreted as normal data inputs. A "1" read on the control bit indicates that the 9901 is in the clock mode. Reading bits 1 through 14 completes the event timer operation as described above. Reading bit 15 indicates whether the interrupt request line is active. A software reset RST2 can be performed by writing a "1" to the control bit followed by writing a "1" to bit 15, which forces all I/O ports to the input mode. Table 4 Software Examples | Assumptions | Examples | <del></del> | | |------------------------------------------------|----------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <ul><li>System us</li><li>Total of 6</li></ul> | es clock at ma<br>interrupts are<br>used as output | | <ul> <li>8 bits are used as input port</li> <li>RST1 (power up reset) has already been applied</li> </ul> | | System<br>Setup for<br>Interrupt | LI<br>LDCR<br>LDCR | R12,PSIBAS<br>@X,0<br>@Y,7 | Setup CRU Base Address to point 9901<br>Program Clock with maximum interval<br>Re-enter interrupt mode and enable top 6 interrupts | | System<br>Setup for<br>Output<br>Ports | LI<br>LDCR | R12,PSIBAS+ 16<br>R1,8 | Move CRU Base to point I/O port Move most significant byte of R1 to output port | | Read<br>Programmed<br>Inputs | LI<br>STCR | R12,PSIBAS+ 24<br>R2,8 | Move CRU Base to point to input ports Move input port to most significant byte of R2 | | | (X) —— | <b>►</b> FFFF | | | | (Y)—— | ►7FXX | | | | | Don't care | 8 | | | BLWP<br>• | CLKVCT | Save Interrupt Mask | | CLKPC | LIMI<br>LI<br>SB0<br>STCR<br>SBZ<br>RTWP | 0<br>R12,PSIBAS+ 1<br>-1<br>R4,14<br>-1 | Disable INTERRUPTS Set up CRU Base Set 9901 into Clock Mode, Latch Clock Value Store Read Register Latch Value into R4 Reenter Interrupt Mode and Restarting Clock Restore Interrupt Mask | | CLKVCT | DATA | CLKWP, CLKPC | | | | | | | # System Operation During power up $\overline{RST1}$ must be activated (low) for a minimum of 2 clock cycles to force the S9901 into a known state. $\overline{RST1}$ will disable all interrupts, disable the clock, program all I/O ports to the mode, and force ICO-IC3 to (0,0,0,0) with $\overline{INTREQ}$ held high. System software must then enable the proper interrupts, program the clock (if used), and configure the I/O ports as required (see Table 4 for an example). After initial power up, the S9901 will be accessed only as needed to service the clock, enable (disable) interrupts, or read (write) data to the I/O ports. The I/O ports can be reconfigured by use of the $\overline{RST}2$ command bit. Figure 7 illustrates the use of an S9901 with an S9900. The S9904 is used to generate RST to reset the 9900 and the 9901 (connected to $\overline{RST}$ 1). Figure 8 shows an S9980 system using the S9901. The reset function, load interrupt, and 4 maskable interrupts allowed in a 9980 are encoded as shown in Table 5. Connecting the system as shown ensures that the proper reset will be applied to the 9980. Table 5 9980 Interrupt Level Data | Interrupt<br>Code<br>(ICO-IC2) | Function | Vector Location<br>(Memory Address<br>In Hex) | Device Assignment | Interrupt Mask Values To Enable (ST12 through ST15) | |--------------------------------|----------|-----------------------------------------------|-------------------|-----------------------------------------------------| | 1 1 0 | Level 4 | 0 0 1 0 | External Device | 4 Through F | | 101 | Level 3 | 000C | External Device | 3 Through F | | 1 0 0 | Level 2 | 0008 | External Device | 2 Through F | | 0 1 1 | Level 1 | 0004 | External Device | 1 Through F | | 0 0 1 | Reset | 0000 | Reset Stimulus | Don't Care | | 010 | Load | 3 F F C | Load Stimulus | Don't Care | | 0 0 0 | Reset | 0000 | Reset Stimulus | Don't Care | | 1 1 1 | No-Op | - | _ | Don't Care | | | ı | | | 1 | # Asynchronous Communications Controller (ACC) #### **Features** - 5- to 8-Bit Character Length - 1, 1 1/2, or 2 Stop Bits - Even, Odd, or No Parity - Fully Programmable Data Rate Generation - Interval Timer with Resolution from 64 to 16,320 µs - Fully TI'L Compatible, Including Single Power Supply. #### General Description The S9902 Asynchronous Communication Controller (ACC) is a peripheral device for the S9900 family of microprocessors. The ACC provides an interface between the microprocessor and a serial asynchronous communication channel, performing the timing and data serialization and deserialization, thus facilitating the control of the asynchronous channel by the microprocessor. #### **\$9902 Electrical Specifications** #### Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otherwise Noted)\* | Supply Voltage, V <sub>CC</sub> 0.3V to +10V | |----------------------------------------------| | All inputs and Output Voltages | | Continuous Power Dissipation | | Operating Free-Air Temperature Range | | Storage Temperature Range65°C to +150°C | <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to Absolute Maximum Rated conditions for extended periods may affect device reliability. #### **Recommended Operating Conditions** | Parameter | Min. | Nom. | Max. | Unit | |------------------------------------------------|------|------|--------------|------| | Supply Voltage, V <sub>CC</sub> | 4.75 | 5 | 5.25 | v | | Supply Voltage, V <sub>SS</sub> | | 0 | | V | | High-Level Input Voltage, VIII | 2.2 | 2.4 | $v_{\rm CC}$ | V | | Low-Level Input Voltage, V <sub>IL</sub> | | 0.4 | 0.8 | V | | Operating Free-Air Temperature, T <sub>A</sub> | 0 | | 70 | °C | #### Electrical Characteristics Over Full Range of Recommended Operating Conditions (Unless Otherwise Noted) | Symbol | Parameter | Min. | Typ. | Max. | Unit | Conditions | |---------------------|---------------------------------------------|------|------|------|------|----------------------------------------------------------| | $I_{\mathbf{I}}$ | Input Current (Any Input) | | | ±10 | μA | $V_1 = 0V$ to $V_{\rm CC}$ | | 57 - | High Lovel Output Velters | 2.2 | 3.0 | | ν | $I_{OH} = -100 \mu A$ | | V <sub>OH</sub> | High-Level Output Voltage | 2.0 | 2.5 | | Į v | I <sub>OH</sub> = -400μA | | VoL | Low-Level Output Voltage | | 0.4 | 0.85 | V | $I_{\rm OL}$ = $3.2 {\rm mA}$ | | I <sub>CC(AV)</sub> | Average Supply Current from V <sub>CC</sub> | | 2.5 | 100 | mΛ | $t_{c(\phi)} = 250 \text{ns}, T_A = 25^{\circ} \text{C}$ | | $C_{\rm i}$ | Capacitance, Any Input | | 10 | | pF | f = 1 MHz, | | $\mathbf{C_o}$ | Capacitance, Any Output | | 20 | | l pr | All other pins at 0V | #### Timing Requirements Over Full Range of Recommended Operating Conditions | Symbol | Parameter | Min. | Тур. | Max. | Unit | |--------------------------------------------|---------------------------------------------------|------|------|------|------| | $t_{c(\phi)}$ | Clock Cycle Time | 300 | 333 | 2000 | ns | | $\overline{\mathbf{t}_{\mathrm{r}(\phi)}}$ | Clock Rise Time | | 10 | 12 | ns | | $t_{f(\phi)}$ | Clock Fall Time | | 10 | 12 | ns | | $t_{\mathrm{H}(\phi)}$ | Clock Pulse Width (High Level) | | 225 | 240 | ns | | $\mathbf{t}_{\mathbf{L}(\varphi)}$ | Clock Pulse Width (Low Level) | | 45 | 55 | ns | | t <sub>su(ad)</sub> | Setup Time for Address and CRUOUT Before CRUCLK | | 220 | | ns | | t <sub>su(CE)</sub> | Setup Time for CE Before CRUCLK | | 190 | | ns | | t <sub>HD</sub> | Hold Time for Address, CE and CRUOUT After CRUCLK | | 90 | | ns | | twee | CRUCLK Pulse Width | | 120 | | ns | Switching Characteristics Over Full Range of Recommended Operating Conditions | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |----------------------|-------------------------------------------|------|------|------|------|----------------| | T <sub>PCI(cd)</sub> | Propagation Delay, Address-to-Valid CRUIN | | | 400 | ns | $C_L = 100 pF$ | | T <sub>PCI(CE)</sub> | Propagation Delay, CE-to-Valid CRUIN | | | 400 | ns | $C_L = 100 pF$ | | $\mathbf{t_H}$ | CRUIN Hold Time After Address | | | 20 | ns | | #### S9902 Pin Description Table 1 defines the S9902 pin assignments and describes the function of each pin as shown in Figure 2. Table 1 | Signature | Pin | I/O | Description | | |-------------------------------------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | INT | 1 | 0 | Interrupt — when active (low), the $\overline{\text{INT}}$ output indicates that at least one of the interrupt conditions has occured. | | | XOUT | 2 | O | Transmitter serial data output line — XOUT remains inactive (high) when $$9902$ is not transmitting. | | | RIN | 3 | I | Receiver serial data input line — RCV — must be held in the inactive (hig state when not receiving data. A transition from high to low will active the receiver circuitry. | | | CRUIN | 4 | 0 | Serial data output pin from \$9902 to CRUIN input pin of the CPU. | | | RTS | 5 | 0 | Request-to-send output from S9902 to modem. This output is enabled by the CPU and remains active (low) during transmission from the S9902. | | | CTS | 6 | I | Clear-to-send input from modem to S9902. When active (low), it end the transmitter section of S9902. | | | DSR | 7 | I | Data set ready input from modem to S9902. This input generates an interrupt when going On or Off. | | | CRUOUT | 8 | I | Serial data input line to S9902 from CRUOUT line of the CPU. | | | $v_{ss}$ | 9 | I | Ground reference voltage. | | | S4 (LSB) | 10 | I | | | | S3 | 11 | I | | | | S2 | 12 | I | | | | SI<br>SO | 13<br>14 | I | Address bus S0-S4 are the lines that are addressed by the CPU to select a particular S9902 function. | | | | I | _ | 1 • | | | CRUCLK | 15 | I | CRU Clock. When active (high), S9902 from CRUOUT line of the CPU. | | | $\overline{\phi}$ | 16 | I | TTL Clock. | | | CE | 17 | I | Chip enable — when CE is inactive (high), the S9902 address decoding is inhibited which prevents execution of any S9902 command function. CRUIN remains at high-impedance when $\overline{\text{CE}}$ is inactive (high). | | | $\mathbf{v}_{\mathbf{c}\mathbf{c}}$ | 18 | 1 | Supply voltage (+5V nominal). | | #### Device Interface The relationship of the ACC to other components in the system is shown in Figures 4 and 5. The ACC is connected to the asychronous channel through level shifters which translate the TTL inputs and outputs to the appropriate levels (e.g., RS-232C, TTY current loop, etc.). The microprocessor transfers data to and from the ACC via the Communication Register Unit (CRU). #### CPU Interface The ACC interfaces to the CPU through the Communication Register Unit (CRU). The CRU interface consists of five address-select lines (SO-S4), chip enable ( $\overline{\text{CE}}$ ), and three CRU control lines (CRUIN, CRUOUT, and CRUCLK). When $\overline{\text{CE}}$ becomes active (low), the five select lines address the CRU bit being accessed. When data is being transferred to the ACC from the CPU, CRUOUT contains the valid datum which is strobed by CRUCLK. When ACC data is being read, CRUIN is the datum output by the ACC. INTERRUPT CODE SSERIAL SYN CHRONOUS SMIFTERS S9802 ACC ADDRESS ADDRESS #### Asynchronous Communication Channel Interface The interface to the asynchronous communication channel consists of an output control line ( $\overline{RTS}$ ), two input status lines ( $\overline{DSR}$ and $\overline{CTS}$ ), and serial transmit (XOUT) and receive (RIN) data lines. The request-to-send line ( $\overline{RTS}$ ) is active (low) whenever the transmitter is activated. However, before data transmission begins, the clear-to-send ( $\overline{CTS}$ ) input must be active. The data set ready ( $\overline{DSR}$ ) input does not affect the receiver or transmitter. When $\overline{DSR}$ or $\overline{CTS}$ changes level, an interrupt is generated. #### Interrupt Output The interrupt output $(\overline{\text{INT}})$ is active (low) when any of the following conditions occurs and the corresponding interrupt has been enabled by the CPU: - (1) DSR or CTS changes levels (DSCH = 1); - (2) a character has been received and stored in the Receiver Buffer Register (RBRL = 1); - (3) the Transmit Buffer Register is empty (XBRE = 1); or - (4) the selected time interval has elapsed (TIMELP = 1). The logical relationship of the interrupt output is shown below. #### Clock Input The clock input to the ACC $(\bar{\phi})$ is normally provided by the $\bar{\phi} \bar{3}$ output of the clock generator (9900 systems) or the S9980 (9980 systems). This clock input is used to generate the internal device clock, which provides the time base for the transmitter, receiver, and interval timer of the ACC. #### Device Operation #### Control and Data Output Data and control information is transferred to the ACC using $\overline{\text{CE}}$ , S0-S4, CRUOUT, and CRUCLK. The diagrams below show the connection of the ACC to the S9900 and S9980 CPUs. The high-order CPU address lines are used to decode the $\overline{\text{CE}}$ signal when the device is being selected. The low-order address lines are connected to the five address-select lines (S0-S4). Table 2 describes the output bit address assignments for the ACC. Table 2 S9902 ACC Output Bit Address Assignments | | Ac | dress | 2 | | Address 10 | Name | Description | |----|-----------|------------|----|-----------|------------|--------|--------------------------------------------------------------------------------------------| | SO | <b>S1</b> | <b>\$2</b> | S3 | <b>S4</b> | Address10 | Name | Description | | 1 | 1 | 1 | 1 | 1 | 31 | RESET | Reset device. | | | | | | | 30-22 | | Not used. | | 1 | 0 | 1 | 0 | 1 | 21 | DSCENB | Data Set Status Change Interrupt Enable. | | 1 | 0 | 1 | 0 | 0 | 20 | TIMENB | Timer Interrupt Enable | | 1 | 0 | 0 | 1 | 1 | 19 | XBIENB | Transmitter Interrupt Enable | | 1 | 0 | 0 | 1 | 0 | 18 | RIENB | Receiver Interrupt Enable | | 1 | 0 | 0 | 0 | 1 | 17 | BRKON | Break On | | 1 | 0 | 0 | 0 | 0 | 16 | RTSON | Request to Send On | | 0 | 1 | 1 | 1 | 1 | 15 | TSTMD | Test Mode | | 0 | 1 | 1 | 1 | 0 | 14 | LDCTRL | Load Control Register | | 0 | 1 | 1 | 0 | 1 | 13 | LDIR | Load Interval Register | | 0 | 1 | 1 | 0 | 0 | 12 | LRDR | Load Receiver Data Rate Register | | 0 | 1 | 0 | 1 | 1 | 11 | LXDR | Load Transmit Data Rate Register | | | | | | | 10-0 | | Control, Interval, Receive Data Rate, Transmit Data<br>Rate, and Transmit Buffer Registers | Bit 31 (RESET) — Writing a one or zero to Bit 31 causes the device to be reset, disabling all interrupts, initializing the transmitter and receiver, setting $\overline{\text{RTS}}$ inactive (high), setting all register load control flags (LDCTRL, LDIR, LRDR, and LXDR) to a logic one level, and resetting the BREAK flag. No other input or output operations should be performed for $11\overline{\phi}$ clock cycles after issuing the RESET command. Bit 30-Bit 22 — Not used. Bit 21 (DSCENB) — Data Set Change Interrupt Enable. Writing a one to Bit 21 causes the INT output to be active (low) whenever DSCH (Data Set Status Change) is a logic one. Writing a zero to Bit 21 causes DSCH interrupts to be disabled. Writing either a one or zero to Bit 21 causes DSCH to be reset. Bit 20 (TIMENB) — Timer Interrupt Enable. Writing a one to Bit 20 causes the INT output to be active whenever TIMELP (Timer Elapsed) is a logic one. Writing a zero to Bit 20 causes TIMELP interrupts to be disabled. Writing either a one or zero to Bit 20 causes TIMELP and TIMERR (Timer Error) to be reset. Bit 19 (XBIENB) — Transmit Buffer Interrupt Enable. Writing a one to Bit 19 causes the INT output to be active whenever XBRE (Transmit Buffer Register Empty) is a logic one. Writing a zero to Bit 19 causes XBRE interrupts to be disabled. The state of XBRE is not affected by writing to Bit 19. Bit 18 (RIENB) — Receiver Interrupt Enable. Writing a one to Bit 18 causes the INT output to be active whenever RBRL (Receiver Buffer Register Loaded) is a logic one. Writing a zero to Bit 18 disables RBRL interrupts. Writing either a one or zero to Bit 18 causes RBRL to be reset. Bit 17 (BRKON) — Break On. Writing a one to Bit 17 causes the XOUT (Transmitter Serial Data Output) to go to a logic zero whenever the transmitter is active and the Transmit Buffer Register (XBR) and the Transmit Shift Register (XSR) are empty. While BRKON is set, loading of characters into the XBR is inhibited. Writing a zero to Bit 17 causes BRKON to be reset and the transmitter to resume normal operation. Bit 16 (RTSON) — Request-to-Send On. Writing a one to Bit 16 causes the RTS output to be active (low). Writing a zero to Bit 16 causes RTS to go to a logic one after the XSR and XBR are empty, and BRKON is reset. Thus, the RTS output does not become inactive (high) until after character transmission has been completed. Bit 15 (TSTMD) — Test Mode. Writing a one to Bit 15 causes RTS to be internally connected to CTS, XOUT to be internally connected to RIN, DSR to be internally held low, and the Interval Timer to operate at 32 times its normal rate. Writing a zero to Bit 15 re-enables normal device operation. Bits 14-11— Register Load Control Flags. Output Bits 14-11 control which of the five registers will be loaded by writing to Bits 10-0. The flags are prioritized as shown in Table 3. Table 3 S9902 ACC Register Load Selection | | Register Load C<br>Statu | Register Enabled | | | | |--------|--------------------------|------------------|------|-----------------------------|--| | LDCTRL | LDIR | LRDR | LXDR | | | | 1 | X | X | X | Control Register | | | 0 | 1 | x | х | Interval Register | | | 0 | 0 | 1 | x | Receive Data Rate Register | | | 0 | 0 | x | 1 | Transmit Data Rate Register | | | 0 | 0 | 0 | l o | Transmit Buffer Register | | Bit 14 (LDCTRL) — Load Control Register. Writing a one to Bit 14 causes LDCTRL to be set to a logic one. When LDCTRL = 1, any data written to bits 0-7 are directed to the Control Register. Note that LDCTRL is also set to a logic one when a one or zero is written to Bit 31 (RESET). Writing a zero to Bit 14 causes LDCTRL to be reset to a logic zero, disabling loading of the Control Register. LDCTRL is also automatically reset to a logic zero when a datum is written to Bit 7 of the Control Register which normally occurs as the last bit written when loading the Control Register with a LDCR instruction. Bit 13 (LDIR) — Load Interval Register. Writing a one to Bit 13 causes LDIR to be set to a logic one. When LDIR = 1 and LDCTRL = 0, any data written to Bits 0-7 are directed to the interval Register. Note that LDIR is also set to a logic one when a datum is written to Bit 31 (RESET); however, Interval Register loading is not enabled until LDCTRL is set to a logic zero. Writing a zero to Bit 13 causes LDIR to be reset to logic zero, disabling loading of the Internal Register. LDIR is also automatically reset to logic zero when a datum is written to Bit 7 of the Interval Register, which normally occurs as the last bit written when loading the Interval Register with a LDCR instruction. Bit 12 (LRDR) — Load Receive Data Rate Register. Writing a one to Bit 12 causes LRDR to be set to a logic one. When LRDR = 1, LDIR = 0, and LDCTRL = 0, any data written to Bits 0-10 are directed to the Receive Data Rate Register. Note that LRDR is also set to a logic one when a datum is written to Bit 31 (RESET); however, Receive Data Rate Register loading is not enabled until LDCTRL and LDIR have been set to a logic zero. Writing a zero to Bit 12 causes LRDR to be reset to a logic zero, disabling loading of the Receive Data Rate Register. LRDR is also automatically reset to logic zero when a datum is written to Bit 10 of the Receive Data Rate Register, which normally occurs as the last bit written when loading the Receive Data Rate Register with a LDCR instruction. Bit 11 (LXDR) - Load Transmit Data Rate Register. Writing a one to Bit 11 causes LXDR to be set to a logic one. When LXDR = 1, LDIR = 0, and LDCTRL = 0, any data written to Bits 0-10 are directed to the Transmit Data Rate Register. Note that loading of both the Receive and Transmit Data Rate Registers is enabled when LDCTRL = 0, LDIR = 0, LRDR = 1, and LXDR = 1; thus these two registers may be loaded simultaneously when data are received and transmitted at the same rate, LXDR is also set to a logic one when a datum is written to Bit 31 (RESET); however, Transmit Data Rate Register loading is not enabled until LDCTRL and LDIR have been reset to logic zero. Writing a zero to Bit 11 causes LXDR to be reset to logic zero, disabling loading of the Transmit Data Rate Register. Since Bit 11 is the next bit addressed after loading the Transmit Data Rate Register, the register may be loaded and the LXDR flag reset with a single LDCR instruction where 12 bits (Bits 0-11) are written, with a zero written to Bit 11. #### Control Register The Control Register is loaded to select character length, device clock operation, parity, and the number of stop bits for the transmitter. Table 4 shows the bit address assignments for the Control Register. Table 4 Control Register Bit Address Assignments | Addı | ress10 | | Name | | Descrip | tion | | |------|--------|---|-------|-------------------|-----------------------|-----------|------| | | 7 | | SBS1 | 1 . | 04 Dir 6 | 11 | | | | 6 | | SBS2 | 1 | Stop Bit S | select | | | | 5 | | PENB | Pa | rity Enable | | | | | 4 | | PODD | Odd Parity Select | | | | | | 3 | ( | CLK4M | $\phi$ | φ Input Divide Select | | | | | 2 | | _ | No | ot Used | | | | | 1 | | RCL1 | 1 | <b>(1)</b> | r | 14 | | | 0 | | RCL0 | <u> </u> | —— Unaracter | Length Se | lect | | | 6 | 5 | _ | 3 | 2 | | | 7 6 5 4 3 2 1 0 SBS1 SBS2 PENB PODD CLK4M NOT USED RCL1 RCL0 MSB LSB Bits 7 and 6 (SBS1 and SBS2) — Stop Bit Selection. The number of stop bits to be appended to each transmitter character is selected by Bits 7 and 6 of the Control Register as shown below. The receiver only tests for a single stop bit, regardless of the status of Bits 7 and 6. | SBS1<br>Bit 7 | SBS2<br>Bit 6 | Number of Transmitted<br>Stop Bits | |---------------|---------------|------------------------------------| | 0 | 0 | 1½ | | 0 | 1 | 2 | | 1 | 0 | 1 | | 1 | 1 | 1 | Stop Bit Selection Bits 5 and 4 PENB and PODD) -- Parity Selection. The type of parity to be generated for transmission and detected for reception is selected by Bits 5 and 4 of the Control Register as shown below. When parity is enabled (PENB = 1), the parity bit is transmitted and received in addition to the number of bits selected for the character length. Odd parity is such that the total number of ones in the character and parity bit, exclusive of stop bit(s), will be odd. For even parity, the total number of ones will be even. | PENB<br>Bit 5 | PODD<br>Bit 4 | PARITY | |---------------|---------------|--------| | 0 | 0 | None | | 0 | 1 | None | | 1 | 0 | Even | | 1 | 1 | Odd | Parity Selection Bit 3 (CLK4M) — $\overline{\phi}$ Input Divide Select. The $\overline{\phi}$ input to the S9902 ACC is used to generate internal dynamic logic clocking and to establish the time base for the Interval Timer, Transmitter, and Receiver. The $\overline{\phi}$ input is internally divided by either 3 or 4 to generate the two-phase internal clocks required for MOS logic, and to establish the basic internal operating frequency (fint) and internal clock period (tint). When Bit 3 of the Control Register is set to a logic one (CLK4M = 1), $\overline{\phi}$ is internally divided by 4, and when CLK4M = 0, $\overline{\phi}$ is divided by 3. For example, when $f\overline{\phi}=3$ MHz, as in a standard 3 MHz S9900 system, and CLK4M = 0, $\overline{\phi}$ is internally divided by 3 to generate an internal clock period tint of 1 $\mu$ s. The figure below shows the operation of the internal clock divider circuitry. The internal clock frequency should be no greater than 1. 1 MHz; thus, when $f\overline{\phi}>3.3$ MHz, CLK4M should be set to a logic one. Bits 1 and 0 (RCL1 and RCL0) — Character Length Select. The number of data bits in each transmitted and received character is determined by Bits 1 and 0 of the Control Register as shown below. | RCL1<br>Bit 1 | RCL0<br>Bit 0 | Character<br>Length | |---------------|---------------|---------------------| | 0 | 0 | 5 Bits | | 0 | 1 | 6 Bits | | 1 | 0 | 7 Bits | | 1 | 1 | 8 Bits | Character Length Selection #### Interval Register The Interval Register is enabled for loading whenever LDCTRL = 0 and LDIR = 1. The Interval Register is used for selecting the rate at which interrupts are generated by the Interval Timer of the ACC. The figure below shows the bit address assignments for the Interval Register when enabled for loading. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | TMR7 | TMR6 | TMR5 | TMR4 | TMR3 | TMR2 | TMR1 | TMR0 | | MSB | | - | | | | | LSB | Interval Register Bit Address Assignments The figure below illustrates the establishment of the interval for the Interval Timer. As an example, if the Interval Register is loaded with a value of $80_{16}$ ( $128_{10}$ ) the interval at which Timer Interrupts are generated is $t_{\rm ITVL} = t_{\rm int} \cdot 64 \circ M = (1\mu s) (\cdot 64) (\cdot 128) = 8.192$ ms. when $t_{\rm int} = 1\mu s$ . Time Internal Selection #### Receive Data Rate Register The Receive Data Rate Register is enabled for loading whenever LDCTRL = 0, LDIR = 0, and LRDR = 1. The Receive Data Rate Register is used for selecting the bit rate at which data is received. The diagram shows the bit address assignments for the Receive Data Rate Register when enabled for loading. Receive Data Rate Register Bit Address Assignments The following diagram describes the manner in which the receive data rate is established. Basically, two programmable counters are used to determine the interval for one-half the bit period of receive data. The first counter either divides the internal system clock frequency ( $f_{int}$ ) by either 8 (RDV8 = 1) or 1 (RDV8 = 0). The second counter has ten stages and may be programmed to divide its input signal by any value from 1 (RDR9-RDR0 = 0000000001) to 1023 (RDR8-RDR0 = 11111111111). The frequency of the output of the second counter ( $f_{RHBT}$ ) is double the receive-data rate. Register is loaded with a value of 11000111000, RDV8 = 1, and RDR9-RDR0 = 1000111000 = 238<sub>16</sub> = 568 10. Thus, for $f_{int}$ = 1 MHz, the receive-data rate = 1 X 10<sup>6</sup> ÷ 8 ÷ 568 ÷ 2 = 110.04 bits per second. Receive Data Rate Selection Quantitatively, the receive-data rate $f_{RCV}$ may be described by the following algebraic expression: $$f_{RCV} = \frac{f_{RHBT}}{2} = \frac{f_{int}}{2mn} = \frac{f_{int}}{(2) (8^{RDV8}) (RDR9-RDR0)}$$ #### Transmit Data Rate Register The Transmit Data Rate Register is enabled for loading whenever LDCTRL = 0, LDIR = 0, and LXDR = 1. The Transmit Data Rate Register is used for selecting the data rate for the transmitter. The figure below shows the bit address assignments for the Transmit Data Rate Register. | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------|------|------|------| | XDV8 | XDR9 | XDR8 | XDR7 | XDR6 | XDR5 | XDR4 | XDR3 | XDR2 | XDR1 | XDR0 | | MSB | | | | | | | | | | LSB | Selection of transmit data rate is accomplished with the Transmit Data Rate Register in the same way that the receive data rate is selected when the Receive Data Rate Register. The algebraic expression for the Transmit Data Rate $f_{\rm XMT}$ is: $$f_{XMT} = \frac{f_{XHBT}}{2} = \frac{f_{int}}{(2) (8^{XDV8}) (XDR9-XDR0)}$$ For example, if the Transmit Data Rate Register is loaded with a value of 00110100001, XDV8 = 0, and XDR9-XDR0 = $1A1_{16}$ = 417, the transmit data rate = $1 \times 10^6 \div 2 \div 1 \div 417$ = 1199.04 bits per second. #### Transmit Buffer Register The Transmit Buffer Register is enabled for loading when LDCTRL = 0, LDIR = 0, LRDR = 0, and BRKON = 0. The Transmit Buffer Register is used for storage of the next character to be transmitted. When the transmitter is active, the contents of the Transmit Buffer Register are transferred to the Transmit Shift Register each time the previous character has been completely transmitted. The bit address assignments for the Transmit Buffer Register are shown below: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | XBR7 | XBR6 | XBR5 | XBR4 | XBR3 | XBR2 | XBR1 | XBR0 | | MSB | | | | | | | LSB | All 8 bits should be transferred into the register, regardless of the selected character length. The extraneous high-order bits will be ignored for transmission purposes; however, loading of bit 7 is internally detected to cause the Transmit Buffer Register Empty (XBRE) status flag to be reset. #### Status and Data Input Status and data information is read from the ACC using $\overline{\text{CE}}$ , S0·S4, and CRUIN. The following figure illustrates the relationship of the signals used to access data from the ACC. Table 6 describes the input bit address assignments for the ACC. Table 5. CRU Output Bit Address Assignments Table 6. \$9902 ACC Input Bit Address Assignments | | Address9 | | | | Addison None | Description | | | |----|---------------|---|-----------|------|--------------|-------------|--------------------------------------------------|--| | S0 | 0 S1 S2 S3 S4 | | Address10 | Name | | | | | | 1 | 1 | 1 | 1 | 1 | 31 | INT | Interrupt | | | 1 | 1 | 1 | 1 | 0 | 30 | FLAG | Register Load Control Flag Set | | | 1 | 1 | 1 | 0 | 1 | 29 | DSCH | Data Set Status Change | | | 1 | 1 | 1 | 0 | 0 | . 28 | CTS | Clear to Send | | | 1 | 1 | Ø | 1 | 1 | 27 | DSR | Data Set Ready | | | 1 | 1 | 0 | 1 | 0 | 26 | RTS | Request to Send | | | 1 | 1 | 0 | 0 | 1 | 25 | TIMELP | Timer Elapsed | | | 1 | 1 | 0 | 0 | 0 | 24 | TIMERR | Timer Error | | | 1 | 0 | 1 | ] 1 | 1 | 23 | XSRE | Transmit Shift Register Empty | | | 1 | 0 | 1 | 1 | 0 | 22 | XBRE | Transmit Buffer Register Empty | | | 1 | 0 | 1 | 0 | 1 | 21 | RBRL | Receive Buffer Register Loaded | | | 1 | 0 | 1 | 0 | 0 | 20 | DSCINT | Data Set Status Charge Interrupt (DSCH · DSCENB) | | | 1 | 0 | 0 | 1 | 1 | 19 | TIMINT | Timer Interrupt (TIMELP · TIMENB) | | | 1 | 0 | 0 | 1 | 0 | 18 | _ | Not used (always = 0) | | | 1 | 0 | 0 | 0 | 1 | 17 | XBINT | Transmitter Interrupt (XBRE · XBIENB) | | | 1 | 0 | 0 | 0 | 0 | 16 | RBINT | Receiver Interrupt (RBRL · RIENB) | | | 0 | 1 | 1 | 1 | 1 | 15 | RIN | Receive Input | | | 0 | 1 | 1 | 1 | 0 | 14 | RSBD | Receive Start Bit Detect | | | 0 | 1 | 1 | 0 | 1 | 13 | RFBD | Receive Full Bit Detect | | | 0 | 1 | 1 | 0 | 0 | 12 | RFER | Receive Framing Error | | | 0 | 1 | 0 | 1 | 1 | 11 | ROVER | Receive Overrun Error | | | 0 | 1 | 0 | 1 | 0 | 10 | RPER | Receive Parity Error | | | 0 | 1 | 0 | 0 | 1 | 9 | RCVERR | Receive Error | | | 0 | 1 | 0 | 0 | 0 | 8 | – | Not used (always = 0) | | | | ] | | | | 7-0 | RBR7-RBR0 | Receive Buffer Register (Received Data) | | | Bit 31 (INT) — | INT = DSCINT + TIMINT + XBINT + RBINT. The interrupt output $(\overline{INT})$ is active when this status signal is a logic 1. | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 30 (FLAG) — | FLAG = LDCTRL + LDIR + LRDR + LXDR + BRKON. When any of the register load control flags or BRKON is set, $FLAG = 1$ . | | Bit 29 (DSCH) — | Data Set Status Change Enable. DSCH is set when the $\overline{DSR}$ or $\overline{CTS}$ input changes state. To ensure recognition of the state change, $\overline{DSR}$ or $\overline{CTS}$ must remain stable in its new state for a minimum of two internal clock cycles. DSCH is reset by an output to bit 21 (DSCENB). | | Bit 28 (CTS) — | Clear to Send. The CTS signal indicates the inverted status of the CTS device input. | | Bit 27 (DSR) — | Data Set Ready. The DSR signal indicates the inverted status of the $\overline{\text{DSR}}$ device input. | | Bit 26 (RTS) — | Request to Send. The RTS signal indicates the inverted status of the $\overline{\text{RTS}}$ device output. | | Bit 25 (TIMELP) — | Timer Elapsed. TIMELP is set each time the Interval Timer decrements to 0. TIMELP is reset by an output to bit $20$ (TIMENB). | - Bit 24 (TIMERR) Timer Error. TIMERR is set whenever the Interval timer decrements to 0 and TIMELP is already set, indicating that the occurrence of TIMELP was not recognized and cleared by the CPU before subsequent intervals elapsed. TIMERR is reset by an output to bit 20 (TIMENB). - Bit 23 (XSRE) Transmit Shift Register Empty. When XSRE = 1, no data is currently being transmitted and the XOUT output is at logic 1 unless BRKON is set. When XSRE = 0, transmission of data is in progress. - Bit 22 (XBRE) Transmit Buffer Register Empty. When XBRE = 1, the transmit buffer register does not contain the next character to be transmitted. XBRE is set each time the contents of the transmit buffer register are transferred to the transmit shift register, XBRE is reset by an output to bit 7 of the transmit buffer register (XBR7), indicating that a character has been loaded. - Bit 21 (RBRL) Receive Buffer Register Loaded, RBRL is set when a complete character has been assembled in the receive shift register and the character is transferred to the receive buffer register. RBRL is reset by an output to bit 18 (RIENB). - Bit 20 (DSCINT) Data Sct Status Change Interrupt. DSCINT = DSCH (input bit 29) · DSCENB (output bit 21). DSCINT indicates the presence of an enabled interrupt caused by the changing of state of DSR or CTS. - Bit 19 (TIMINT) Timer Interrupt. TIMINT = TIMELP (input bit 25) TIMENB (output bit 20). TIMINT indicates the presence of an enabled interrupt caused by the interval timer. - Bit 17 (XBINT) Transmitter Interrupt. XBINT = XBRE (input bit 22) · XBIENB (output bit 19). XBINT indicates the presence of an enabled interrupt caused by the transmitter. - Bit 16 (RBINT) Receiver Interrupt. RBINT = RBRL (input bit 21) · RIENB (output bit 18). RBINT indicates the presence of an enabled interrupt caused by the receiver. - Bit 15 (RIN) Receive Input. RIN indicates the status of the RIN input to the device. - Bit 14 (RSBD) Receive Start Bit Detect. RSBD is set one-half bit time after the 1-to-0 transition of RIN indicating the start bit of a character. If RIN is not still 0 at this point in time, RSBD is reset. Otherwise, RSBD remains true until the complete character has been received. This bit is normally used for testing purposes. - Bit 13 (RFBD) Receive Full Bit Detect. RFBD is set one bit time after RSBD is set to indicate the sample point for the first data bit of the received character. RSBD is reset when the character has been completely received. This bit is normally used for testing purposes. - Bit 12 (RFER) Receive Framing Error. RFER is set when a character is received in which the stop bit, which should be a logic 1, is a logic 0. RFER should only be read when RBRL (input bit 21) is a 1, RFER is reset when a character with the correct stop bit is received. - Bit 11 (ROVER) Receive Overrun Error, ROVER is set when a new character is received before the RBRL flag (input bit 21) is reset, indicating that the CPU failed to read the previous character and reset RBRL before the present character is completely received. ROVER is reset when a character is received and RBRL is 0 when the character is transferred to the receive buffer register. - Bit 10 (RPER) Receive Parity Error. RPER is set when a character is received in which the parity is incorrect. RPER is reset when a character with correct parity is received. - Bit 9 (RCVERR) Receive Error. RCVERR = RFER + ROVER + RPER. RCVERR indicates the presence of an error in the most recently received character. - Bit 7-Bit 0 (RBR7-RBR0) Receive Buffer Register. The receive buffer register contains the most recently received character. For character lengths of fewer than 8 bits the character is right justified, with unused most significant bit(s) all zero(es). The presence of valid data in the receive buffer register is indicated when RBRL is a logic 1. #### **Transmitter Operation** #### Transmitter Initialization The operation of the transmitter is described in the following flowchart. The transmitter is initialized by issuing the RESET command (output to bit 31), which causes the internal signals XSRE and XBRE to be set, and BRKON to be reset. Device outputs $\overline{\text{RTS}}$ and XOUT arc set, placing the transmitter in its idle state. When RTSON is set by the CPU, the $\overline{\text{RTS}}$ output becomes active and the transmitter becomes active when $\overline{\text{CTS}}$ goes low. #### Data Transmission If the Transmit Buffer Register contains a character, transmission begins. The contents of the Transmit Buffer Register are transferred to the Transmit Shift Register, causing XSRE to be reset and XBRE to be set. The first bit transmitted (start bit) is always a logic 0. Subsequently, the character is shifted out, LSB first. Only the number of bits specified by RCL1 and RCLO (character length select) of the Control Register are shifted. If parity is enabled, the correct parity bit is next transmitted. Finally the stop bit(s) selected by SBS1 and SBS0 of the Control Register are transmitted. Stop bits are always logic one. XSRE is set to indicate that no transmission is in progress, and the transmitter again tests XBRE to determine if the CPU has yet loaded the next character. The waveform for a transmitted character is shown below. #### **BREAK Transmission** The BREAK message is transmitted only if XBRE=1, CTS = 9, and BRKON = 1. After transmission of the BREAK message begins, loading of the Transmit Buffer Register is inhibited and XOUT is reset. When BRKON is reset by the CPU, XOUT is set and normal operation continues. It is important to note that characters loaded into the Transmit Buffer Register are transmitted prior to the BREAK message regardless of whether the character has been loaded into the Transmit Shift Register before BRKON is set. Any character to be transmitted subsequent to transmission of the BREAK message may not be loaded into the Transmit Buffer Regiser until after BRKON is reset. #### Transmission Termination Whenever XSRE = 1 and BRKON = 0, the transmitter is idle, with XOUT set to one. If RTSON is reset at this time, the $\overline{RTS}$ device output will go inactive, disabling further data transmission until RTSON is again set. $\overline{RTS}$ will not go inactive, however, until any characters loaded into the Transmit Buffer Register prior to resetting RTSON are transmitted and BRKON = 0. #### **Receiver Operation** #### Receiver Initialization Operation of the S9902 receiver is described in the following flowchart. The receiver is initialized any time the CPU issues the RESET command. The RBRL flag is reset to indicate that no character is currently in the Receive Buffer Register, and the RSBD and RFBD flags are reset. The receiver remains in the inactive state until a 1 to 0 transition is detected on the RIN device input. #### Start Bit Detection The receiver delays one-half bit time and again samples RIN to ensure that a valid start bit has been detected. If RIN = 0 after the half-bit delay, RSBD is set and data reception begins. If RIN = 1 no data reception occurs. #### Data Reception In addition to verifying the valid start bit, the half-bit delay after the 1-to-0 transition also establishes the sample point for all subsequent data bits in this character. Theoretically, the sample point is in the center of each bit cell, thus maximizing the limits of acceptable distortion of data cells. After the first full bit delay, the least significant data bit is received and RFBD is set. The receiver continues to delay one-bit intervals and sample RIN until the selected number of bits is received. If parity is enabled, one additional bit is read for parity. After an additional bit delay, the received character is transferred to the Receive Buffer Register, RBRL is set, ROVER and RPER are loaded with appropriate values, and RIN is tested for a valid stop bit. If RIN = 1, the stop bit is valid. RFER, RSBD, and RFBD are reset and the receiver waits for the next start bit to begin reception of the next character. If RIN = 0 when the stop bit is sampled, RFER is set to indicate the occurrence of a framing error. RSBD and RFBD are reset but sampling for the start bit of the next character does not begin until RIN = 1. CHARACTER RECEPTION TIMING #### Interval Timer Operation A flowchart of the operation of the Interval Timer is shown below. Execution of the RESET command by the CPU causes TIMELP and TIMERR to be reset and LDIR to be set. Resetting LDIR causes the contents of the Interval Register to be loaded into the Interval Timer, thus beginning the selected time interval. The timer is decremented every 64 internal clock cycles (every 2 internal clock cycles when in Test Mode) until it reaches zero, at which time the Interval Timer is reloaded by the Interval Register and TIMELP is set. If TIMELP was already set, TIMERR is set to indicate that TIMELP was not cleared by the CPU before the next time period elapsed. Each time LDIR is reset the contents of the Interval Register are loaded into the Interval Timer, thus restarting the time. #### **Device Application** This section describes the software interface between the CPU and the S9902 ACC and discusses some of the design considerations in the use of this device in asynchronous communications applications. #### Device Initialization The ACC is initialized by the CPU issuing the RESET command, followed by loading the Control, Interval, Receive Data Rate, and Trasmit Data Rate registers. Assume that the value to be loaded into the CRU Base Register (register 12) in order to point to bit 0 is $0040_{16}$ . In this application, characters will have 7 bits of data plus even parity and one stop bit. The $\phi$ input to the ACC is a 3MHz signal. The ACC will divide this signal frequency by 3 to generate an internal clock frequency of 1MHz. An interrupt will be generated by the Interval Timer every 1.6 milliseconds when timer interrupts are enabled. The transmitter will operate at a data rate of 300 bits per second and the receiver will operate at 1200 bits per second. Had it been desired that both the transmitter and receiver operate at 300 bits per second, the "LDCR @RDR,11" instruction would have been deleted, and the "LDCR @XDR,12" instruction would have caused both data rate registers to be loaded and LRDR and LXDR to have been reset. #### Initialization Program The initialization program for the configuration previously described is as shown below. The RESET command disables all interrupts, initializes all controllers, sets the four register load control flags (LDCTRL, LDIR, LRDR, and LXDR). Loading the last bits of each of the registers causes the load control flag to be automatically reset. | | LI | R12, > 40 | INITIALIZE CRU BASE | |-------|------|-----------|-------------------------------| | | SBO | 31 | RESET COMMAND | | | LDCR | @CNTRL, 8 | LOAD CONTROL AND RESET LDCTRL | | | LDCR | @INTVL, 8 | LOAD INTERVAL AND RESET LDIR | | | LDCR | @RDR, 11 | LOAD RDR AND RESET LRDR | | | LDCR | @XDR, 12 | LOAD XDR AND RESET LXDR | | | • | | | | | • | | | | | • | | | | CNTRL | BYTE | >A2 | | | INTVL | BYTE | 1600/64 | | | RDR | DATA | >1A1 | | | XDR | DATA | >4DO | | | | | | | The RESET command initializes all subcontrollers, disables interrupts, and sets LDCTRL, LDIR, LRDR, and LXDR, enabling loading of the control register. #### Control Register The options described previously are selected by loading the value shown below. #### Interval Register The interval register is to be set up to generate an interrupt every 1.6 milliseconds. The value loaded into the interval register specifies the number of 64 microsecond increments in the total interval. 25 X 64 MICROSECONDS = 1.6 MILLISECONDS #### Receive Data Rate Register The data rate for the receiver is to be 1200 bits per second. The value to be loaded into the Receive Data Rate Register is as shown: 10<sup>6</sup> ÷ 1 ÷ 417 ÷ 2 × 1199,04 BITS PER SECOND #### Transmit Data Rate Register The data rate for the transmitter is to be 300 bits per second. The value to be loaded into the Transmit Data Rate Register is: 1 X 106 ÷ 8 ÷ 208 ÷ 2 = 300.48 BITS PER SECOND #### Data Transmission The subroutine shown below demonstrates a simple loop for the transmitting of a block of data. | | LĬ<br>LĬ<br>LĬ | R0, LISTAD<br>R1, COUNT<br>R12, CRUBAS | INITIALIZE LIST POINTER<br>INITIALIZE BLOCK COUNT<br>INITIALIZE CRU BASE | |-------|----------------|----------------------------------------|--------------------------------------------------------------------------| | | SBO | 16 | TURN OFF TRANSMITTER | | XMTLP | TB | 22 | WAIT FOR XBRE = $1$ | | | JNE | XMTLP | | | | LDCR | *R0+,8 | LOAD CHARACTER INCREMENT POINTER RESET XBRE | | | DEC | R1 | DECREMENT COUNT | | | JNE | XMTLP | LOOP IF NOT COMPLETE | | | SBZ | 16 | TURN OFF TRANSMITTER | After initializing the list pointer, block count, and CRU base address. RTSON is set to cause the transmitter and the RTS output to become active. Data transmission does not begin, however, until the CTS input becomes active. After the final character is loaded into the transmit buffer register, RTSON is reset. The transmitter and the RTS output do not become inactive until the final character has been completely transmitted. #### Data Reception The software shown below will cause a block of data to be received and stored in memory. | CARRET | BYTE | >OD | | |--------|------|------------|---------------------------------------------| | RCVBLK | LI | R2, RCVLST | INITIALIZE LIST COUNT | | | Lī | R3, MXRCNT | INITIALIZE MAX COUNT | | | LI | R4, CARRET | SET UP END OF BLOCK CHARACTER | | RCVLP | TB | 21 | WAIT FOR RBRL = 1 | | | JNE | RCVLP | | | | STCR | *R2,8 | STORE CHARACTER | | | SBZ | 18 | RESET RBRL | | | DEC | R3 | DECREMENT COUNT | | | JEQ | RCVEND | END IF COUNT = $0$ | | | CB | *R2+, R4 | COMPARE TO EOB CHARACTER, INCREMENT POINTER | | | JNE | RCVLP | LOOP IF NOT COMPLETE | | RCVEND | RT | | END OF SUBROUTINE | #### Register Loading After Initialization The control, interval, and data rate registers may be reloaded after initialization. For example, it may be desirable to change the interval of the timer. Assume, for sample, that the interval is to be changed to 10.24 milliseconds. The instruction sequence is as follows: | | SB0<br>LDCR | 13<br>@INTVL2,8 | SET LOAD CONTROL FLAG<br>LOAD REGISTER, RESET FLAG | |--------|-------------|-----------------|----------------------------------------------------| | | • | | | | | • | | | | | • | | | | INTVL2 | BYTE | 10240/64 | | Caution should be exercised when transmitter interrupts are enabled to ensure that the transmitter interrupt does not occur while the load control flag is set. For example, if the transmitter interrupts between execution of the "SBO 13" and the next instruction, the transmit buffer is not enabled for loading when the transmitter interrupt service routine is entered because the LDIR flag is set. This situation may be avoided by the following sequence: | | BLWP | @INTVCHG | CALL SUBROUTINE | |------------------|-------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------| | ITV CPC | LI MI<br>MOV<br>SBO<br>LDCR<br>RTWP | 0<br>@24(R13), RIZ<br>13<br>@INTVL2,8 | MASK ALL INTERRUPTS<br>LOAD CRU BASE ADDRESS<br>SET FLAG<br>LOAD REGISTER AND RESET FLAG<br>RESTORE MASK AND RETURN | | ITVCHG<br>INTVL2 | DATA<br>BYTE | ACCWP, ITVCPC<br>10240/64 | | In this case all interrupts are masked, ensuring that all interrupts are disabled while the load control flag is set. **Mechanical Data** # SYNCHRONOUS COMMUNICATIONS CONTROLLER #### Features - Versatile CRU interface to synchronous and asynchronous serial devices for the S99XX series of microprocessors - □ DC to 250 KBPS data rate, half- or fullduplex - Dynamic character length selection - ☐ Line protocols include BI-SYNC, SDLC, and HDLC, as well as others - Programmable-polynominal CRC generation and detection - Interface to unclocked or NRZI data with 32x clocks - ☐ Two programmable sync registers - $\square$ Interval timer [64 $\mu$ s to 16.32ms] on chip - ☐ Automatic zero insert and delete for SDLC and HDLC - Single +5V supply, 20-pin DIP, all inputs and outputs TTL compatible - □ N-channel Silicon-Gate technology #### General Description The S9903 is a versatile device which provides the system designer with a wide range of capabilities in synchronous and asynchronous communications control. The S9903 operates in a multi-mode configuration that allows a broad range in the degree of active participation required in the control of high-speed serial communications. Most synchronous data-link control protocols can be supported through software control of sync and fill characters, timing, CRC generation and detection, etc. Established protocols such as BI-SYNC, SDLC, and HDLC are implemented directly in hardware, with others implemented through various combinations of hardware and software. Universal applicability is further assured through the capability for dynamic character length selection from 5-to 9-bit data words plus parity. Definition and operation of all communications control is under software control and as such make upgrading to another protocol simply a matter of changing software with no hardware changes required. ## **MICROPROCESSOR** #### **Features** □ 16-Bit Instruction Word □ Minicomputer Instruction Set Including Multiply and Divide □ 2048 Bytes of ROM on Chip □ 16 General Purpose Registers □ 4 Prioritized Interrupts □ On Chip Timer/Event Counter □ 32 Bits General Purpose I/O □ 256 Bits I/O Expansion □ Multiprocessor System Interface □ Single 5 Volt Power Supply □ Power Down Capability for Low Stand-by Power □ N-Channel Silicon Gate MOS #### **General Description** The S9940 is a single-chip, 16-bit microcomputer containing a CPU, memory (RAM and ROM), and extensive I/O. The instruction set of the S9940 is a subset of the S9900 instruction set and includes capabilities offered by minicomputers. The unique memory-to-memory architecture features multiple register files, resident in the RAM, which allow faster response to interrupts, and increased programming flexibility. The memory consists of 128 bytes of RAM and 2048 bytes of ROM. The S9940 implements four levels of interrupts, including an internal decrementer which can be programmed as a timer or an event counter. All members of the S9900 family of peripheral circuits are compatible with the S9940. ### 16-BIT MICROPROCESSOR #### **Features** - ☐ 16-Bit Instruction Word - ☐ Full Minicomputer Instruction Set Capability Including Multiply and Divide - □ Up to 16,384 Bytes of Memory - ☐ 8-Bit Memory Data Bus - ☐ Advanced Memory-to-Memory Architecture - ☐ Separate Memory, I/O, and Interrupt-Bus Structures - 16 General Registers - □ 4 Prioritized Interrupts - ☐ Programmed and DMA I/O Capability - ☐ On-Chip 4-Phase Clock Generator - ☐ 40-Pin Package - □ N-Channel Silicon-Gate Technology The S9980A and the S9981 although very similar, have several differences which are: The S9980A requires a V<sub>BB</sub> supply (pin 21) while the S9981 has an internal charge pump to generate V<sub>BB</sub> from V<sub>CC</sub> and V<sub>DD</sub>. - The S9981 has an optional on-chip crystal oscillator in addition to the external clock mode of the S9980A. - The pin-outs are not compatible for D0-D7, INT0-INT2, and φ3. #### Description The S9980A/S9981 is a software-compatible member of AMI's 9900 family of microprocessors. Designed to minimize the system cost for smaller systems, the S9980A/S9981 is a single-chip 16-bit central processing unit (CPU) which has an 8-bit data bus, on-chip clock, and is packaged in a 40-pin package (see Figure 1). The instruction set of the S9980A/S9981 includes the capabilities offered by full minicomputers and is exactly the same as the 9900's. The unique memory-to-memory architecture features multiple register files, resident in memory, which allow faster response to interrupts and increased programming flexibility. The separate bus structure simplifies the system design effort. # **Telecommunications** ### **TELECOMMUNICATIONS** | PART NO. | DESCRIPTION | PROCESS | POWER SUPPLIES | INPUT/OUTPUT | PACKAGES | |-----------|-----------------------------|----------|-----------------|--------------|----------| | \$1883 | Universal Asynchronous | P- 1 | -12V, ±5V | <u>ΠL</u> ' | 4D Pin | | | Receiver/Transmitter (UART) | | | | | | S2350 | Universal Synchronous | N-SiGate | + 5V | TTL | 40 Pin | | | Receiver/Transmitter (USRT) | | | | | | \$2559A/B | Digital Tone Generator | CMOS | +3.5V to +13V | TTL/CMOS | 16 Pin | | S2559C/D | Oigital Tone Generator | CMOS | + 2.75 to + 10V | TTL/CMOS | 16 Pin | | S2560A/B | Key Pulser | CMOS | + 12V | | 18 Pin | | S2561 | Tone Ringer | CMOS | + 13.5V | | 18 Pin | | \$2562 | Repertory Dialer | CMOS | | | 40 Pin | # DIGITAL TONE GENERATOR #### Features - □ Wide Operating Supply Voltage Range: 3.5 to 13 Volts (A, B) 2.75 to 10 Volts (C, D) - □ Low Power CMOS Circuitry Allows Device Power to be Derived Directly from the Telephone Lines or from Small Batteries, e.g., 9V. □ Uses TV Crystal Standard (3.58MHz to Derive - all Frequencies thus Providing Very High Accuracy and Stability - ☐ MUTE and Transmitter Drivers On Chip ☐ Interfaces Directly to a Standard Telephone Push-Button or Calculator Type X-Y Keyboard - ☐ The Total Harmonic Distortion is Below Industry Specification - ☐ On Chip Generation of a Reference Voltage to Assure Amplitude Stability of the Dual Tones Over the Operating Voltage and Temperature Range - Dual Tone as well as Single Tone Capability - Four Options Available: - A: 3.5 to 13V Mode Select - B: 3.5 to 13V Chip Disable C: 2.75 to 10V Mode Select - D: 2.75 to 10V Chip Disable #### General Description The S2559 Digital Tone Generator is specifically designed to implement a dual tone telephone dialing system. The device can interface directly to a standard pushbutton telephone keyboard or calculator type X-Y keyboard and operates directly from the telephone lines. All necessary dual-tone frequencies are derived from the widely used TV crystal standard providing very high accuracy and stability. The required sinusoidal wave.form for the individual tones is digitally synthesized on the chip. The waveform so generated has very low total harmonic distortion. A voltage reference is generated on the chip which is stable over the operating voltage and temperature range and regulates the signal levels of the dual tones to meet the recommended telephone industry specifications. These features permit the S2559 to be incorporated with a slight modification of the standard 500 type telephone basic circuitry to form a pushbutton dualtone telephone. Other applications of the device include radio and mobile telephones, remote control, Point-of-Sale, and Credit Card Verification Terminals and process control. Pin Configuration ### **Absolute Maximum Ratings** | DC Supply Voltage (VDD = VSS) \$2559 A, B+13.57 | V | |-------------------------------------------------|---| | DC Supply Voltage (VDD - VSS) S2559 C, D | V | | Operating Temperature | C | | Storage Temperature55°C to +125°C | C | | Power Dissipation at 25°C | V | | Input Voltage | 6 | **S2559A & B Electrical Characteristics** (Specifications apply over the operating temperature range of -25°C to +70°C unless otherwise noted. Absolute values of measured parameters are specified.) | Symbol | Parameter/Condi | tions | | (V <sub>DD</sub> -V <sub>SS</sub> )<br>Volts | Min. | Тур. | Max. | Units | |-------------------|--------------------------------------------------------------------|-----------------------------------|-------------------------|----------------------------------------------|-----------|--------------------------------------------------|--------------|----------| | | Supply Voltage | | | | - <b></b> | | <u> </u> | | | $v_{\mathrm{DD}}$ | Tone Out Mode w | vith One Va | lid Key Depressed | | 3.5 | | 13.0 | V | | VDD | Non Tone Out Mode (No Keys Depressed) | | | | 2.5 | | 13.0 | V | | | Supply Current | | | | | | | | | Ι <sub>Ώ</sub> | Standby (No Keys Selected, Tone, MUTE and XMIT Outputs Unloaded) | | | 13.0 | | | 130 | μА | | IOD | Operating (One Key Selected, Tone, MUTE and XMIT Outputs Unloaded) | | | 5.0 | | | 18 | mA | | | Tone Output <sup>1</sup> | | | | 1 | | | | | VOR | | Row Tone RL = 600Ω | | 5.0 | 490 | | 660 | mVrms | | YOR | Single Tone | Row Tone RL = 320Ω | | 12.0 | 440 | | 600 | mVrms | | Voc | Mode, Output<br>Voltage | Column Tone RL = $600\Omega$ | | 5.0 | 650 | | 880 | mVrms | | .00 | | Column Tone R <sub>L</sub> = 320Ω | | 12.0 | 590 | | 790 | mVrm: | | dBCR | Ratio of Column | to Row To | ne | 3.5-13.0 | 1.75 | 2.85 | 3.7 | dB | | % DIS | | | * | 3.5-13.0 | | | 10 | % | | | XMIT, MUTE Or | itputs | • | · · · · · · · · · · · · · · · · · · · | | | | | | | | | I <sub>OH</sub> = 15mA | 3.5 | 1.5 | | | V | | VOH | | | I <sub>OH</sub> = 50mA | 10.0 | 8.0 | | | v | | $v_{OL}$ | MUTE Output Ve | | | 3.5 | | | 0.4 | V | | , OL | No Key Depressed, No Load | | | 13.0 | | | 1.0 | V | | VOH | One Key Depressed, No Load | | | 3.5 | 2.6 | | | V | | VOH | | | | 13.0 | 10.0 | | | v | | lOT | MUTE Output Sink<br>Current | | VOL = 0.5V | 3.0 | 0.2 | | | m A | | | | | 10,5 | 10.0 | 0.5 | | | m A | | Iou | MUTE Output Source<br>Current | | V <sub>OH</sub> = 2V | 3.0 | 0.5 | | | mA | | IOH | | | $V_{OH} = 9V$ | 10.0 | 0.5 | | | m A | | | Oscillator | | | | • | • | • | • | | IOH | O | | Sink VII. = 0.5V | 3.5 | 0.34 | | | mA | | | Output Current | | Source VIH = 3.0V | 3.5 | 0.23 | | <del> </del> | m A | | tsu | Startup Time | | | 3.5 | <u> </u> | | 6.0 | mS | | | Input Currents | · · · | | 1 | • | 1 | <u> </u> | <u> </u> | | IIH | Row, Column Inputs,<br>Pull-up (Source) Current | | V <sub>IH</sub> = 3.0V | 3.5 | 1 | 1 | 0.45 | m A | | | | | V <sub>IH</sub> = 12.5V | 13.0 | | <del> </del> | 1.48 | m A | | IIL | Pull-down (Sink) Current | | V <sub>IL</sub> = 2.1V | 3.5 | | <b> </b> | 0.1 | mA | | | | | V <sub>IL</sub> = 9.1V | 13.0 | | <u> </u> | 0.6 | mΛ | <sup>\*</sup>Distortion measured in accordance with the specification described in Ref. 1 as the "ratio of the total power of all extraneous frequencies in the voiceband above 500Hz accompanying the signal to the total power of the frequency pair." 1 Amplitude specification limits apply at room temperature (+25°C) only. **S2559C & D Electrical Characteristics** (Specifications apply over the operating temperature range of $-25^{\circ}$ C to $+70^{\circ}$ C unless otherwise noted. Absolute values of the measured parameters are specified.) | Symbol | Parameter/Conditions | | (VDD-VSS)<br>Volts | Min. | Тур. | Max. | Units | |-------------|--------------------------------------------|------------------------------------|--------------------|------|------|----------------------------------------------|--------------| | | Supply Voltage | | | | | | | | VDD | Tone Out Mode with Valid | Key Depressed | | 2.75 | | 10.0 | V | | עםי | Non Tone Out Mode (No Key Depressed) | | | 2.25 | | 10.0 | V | | | Supply Current | | | | · | | | | | Standby (No Key Selected, | 3.0 | | 0.3 | 30 | μA | | | Terrer | and MUTE Outputs Unload | 10.0 | | 1.0 | 100 | $\mu A$ | | | $_{ m IDD}$ | Operating (One Key Selecte | 3.0 | | 1.0 | 2.0 | mA | | | | and MUTE Outputs Unload | 10.0 | | 8.0 | 16.0 | m A | | | | Tone Output <sup>1</sup> | | | | • | • | • | | Vor | Row | Row Tone, RL = $390\Omega$ | | 424 | 546 | 667 | m Vrms | | VOR | Single Tone Row | Row Tone, R <sub>L</sub> = 240Ω | | 376 | 501 | 626 | mVrms | | Voc | Mode Output<br>Voltage Column | Column Tone, RL = $390\Omega$ | | 573 | 731 | 889 | m Vrms | | Voc | Column | Column Tone, R <sub>L</sub> = 240Ω | | 504 | 672 | 840 | mVrms | | dBCR | Ratio of Column to Row To | ne | 3.0-10.0 | 1.75 | 2.54 | 3.75 | dB | | % DIS | Distortion (Any Dual Tone)* | | 3.0-10.0 | | | 10 | % | | | XMIT, MUTE Outputs | | | | | | | | 17 | XMIT, Output Voltage, High | (I <sub>OH</sub> = 15mA) | 3.0 | 1.5 | 1.8 | | V | | VOH | (No Key Depressed) (Pin 2) | $(I_{OH} = 50 \text{mA})$ | 10.0 | 8.5 | 8.8 | | v | | IOF | XMIT, Output Source Leak<br>VOF = 0V | age Current, | 10.0 | | - | 100 | μΑ | | Vor | MUTE (Pin 10) Output Vol | 2.75 | | 0 | 0.5 | v | | | $v_{OL}$ | (No Key Depressed), No Lo | 10.0 | | 0 | 0.5 | V | | | Vor | MUTE, Output Voltage, Hig | h. | 2.75 | 2.25 | 2.75 | | V | | VOH | One Key Depressed), No Load | | 10.0 | 9.5 | 10.0 | | V | | $I_{OL}$ | ]<br> MUTE, Output Sink Curren | $V_{OL} = 0.5V$ | 3.0 | 0.53 | 1.3 | | m.A | | -01. | MC119, Oueput blink Gullen | | 10.0 | 2.0 | 5.3 | | mA | | IOH | MUTE, Output Source | $V_{OII} = 2.5V$ | 3.0 | 0.17 | 0.41 | | mA | | ·On | Current | $V_{OH} = 9.5V$ | 10.0 | 0.57 | 1.5 | <u>. </u> | m A | | | Oscillator Input/Output | | | | | | | | IOL | Output Sink Current | $V_{OL} = 0.5V$ | 3.0 | 0.21 | 0.52 | | mΛ | | | One Key Selected | $V_{OL} = 0.5V$ | 10,0 | 0.80 | 2.1 | | m A | | lOH | Output Source Current | $V_{OH} = 2.5V$ | 3.0 | 0.13 | 0.31 | | m A | | | One Key Selected | $V_{OH} = 9.5V$ | 10.0 | 0.42 | 1.1 | | m A | | | Input Current | | | | | | | | IIL | Leakage Sink Current,<br>One Key Selected | V <sub>IL</sub> = 10.0V | 10.0 | | | 1.0 | μΑ | | ΉΗ | Leakage Source Current<br>One Key Selected | V <sub>IH</sub> = 0.0V | 10.0 | | | 1.0 | μA | | IIL | Sink Current | $V_{\rm HL} = 0.5 V$ | 3.0 | 47 | 93 | <u> </u> | $\mu\Lambda$ | | | No Key Selected VII. = ( | | 10.0 | 65 | 130 | | μA | | tSTART | Oscillator Startup Time | | 2.75 | | 0.4 | 1.2 | mS | | | Comments over out with | | 10.0 | | 0.25 | 0.75 | mS | | CI/O | Input/Output Capacitance | | 3.0 | | 12 | 16 | pF | | | | 10.0 | | 10 | 14 | pF | | <sup>&</sup>lt;sup>1</sup> Amplitude specification limits apply at room temperature (+25°C) only. S2559C & D Electrical Specifications (continued) | Symbol | Parameter/Conditi | (Vpp-Vss)<br>Volts | Min. | Тур. | Max. | Units | | |-------------------|--------------------------------|------------------------------------------------------|------|------|------|-------|----| | | Input Currents | · | | | | | | | ИГ | Row &<br>Column Inputs | Sink Current,<br>VIL = 3.0V (Pull-down) | 3.0 | 6.5 | 16 | | μΑ | | | | Sink Current,<br>V <sub>1L</sub> = 10.0V (Pull-down) | 10.0 | 9.2 | 24 | | μА | | I <sub>IH</sub> | | Source Current,<br>VIH = 2.5V (Pull-up) | 3.0 | 85 | 210 | - | μА | | | | Source Current,<br>V <sub>IH</sub> = 9.5V (Pull-up) | 10.0 | 280 | 740 | | μΑ | | I <sub>IH</sub> | Mode Select<br>Input (S2559C) | Source Current,<br>VIH = 0.0V (Pull-up) | 3,0 | 1.4 | 3.3 | | μА | | | | Source Current,<br>VIH = 0.0V (Pull-up) | 10.0 | 18 | 46 | | μА | | I <sub>IL</sub> , | Chip Disable<br>Input (S2559D) | Sink Current,<br>V <sub>IL</sub> = 3.0V (Pull-down) | 3.0 | 3.9 | 9.5 | | μΑ | | | | Sink Current,<br>VIL = 10.0V (Pull-down) | 10.0 | 55 | 143 | | μА | <sup>\*</sup>Distortion measured in accordance with the specification described in Ref. 1 as the "ratio of the total power of all extraneous frequencies in the voiceband above 500Hz accompanying the signal to the total power of the frequency pair." Table 1. Comparisons of Specified vs Actual Tone Frequencies Table 2. XMIT and MUTE Output Functional Relationship Generated by \$2559 | ACTIVE INPUT | OUTPUT FRE<br>Specified | QUENCY Hz<br>ACTUAL | % ERROR<br>SEE NOTE | OUTPUT | 'DIGIT' KEY<br>RELEASED | 'DIGIT' KEY<br>Depressed | COMMENT | | |--------------|-------------------------|---------------------|---------------------|--------|-------------------------|--------------------------|-----------------------------|--| | R1 | 697 | 699.1 | +0.30 | V144- | N. C | 115-1-1-1-1-1-1 | | | | R2 | 770 | 766.2 | -0.49 | XMIT | Vop | High Impedance | Can source at least 50mA at | | | R3 | 852 | 847.4 | -0.54 | | | | 10V with 1.5V | | | R4 | 941 | 948.0 | +0.74 | | | | max. drop | | | <b>C</b> 1 | 1,209 | 1,215.9 | +0.57 | | | | i | | | C2 | 1,336 | 1,331.7 | -0.32 | MUTE | VSS | Vap | Can source or | | | C3 | 1,477 | 1,471.9 | -G.35 | | • | | sink current | | | C4 | 1,633 | 1,645.0 | +0.73 | | | | | | NOTE: % Error does not include ascillator drift. #### Circuit Description The S2559 is designed so that it can be interfaced easily to the dual tone signaling telephone system and that it will more than adequately meet the recommended telephone industry specifications regarding the dual tone signaling scheme. #### Design Objectives The specifications that are important to the design of the Digital Tone Generator are summarized below: The dual tone signal consists of linear addition of two voice frequency signals. One of the two signals is selected from a group of frequencies called the "low group" and the other is selected from a group of frequencies called the "high group." The low group consists of four frequencies 697, 770, 852 and 941 Hz. The high group consists of four frequencies 1209, 1336, 1477 and 1633Hz. A keyboard arranged in a row, column format (4 rows x 3 or 4 columns) is used for number entry. When a push button corresponding to a digit (0 thru 9) is pushed, one appropriate row (R1 thru R4) and one appropriate column (C1 thru C4) is selected. The active row input selects one of the low group frequencies and the active column input selects one of the high group frequencies. In standard dual tone telephone systems, the highest high group frequency of 1633Hz (Col. 4) is not used. The frequency tolerance must be $\pm 1.0\%$ . However, the S2559 provides a better than .75% accuracy. The total harmonic and intermodulation distortion of the dual tone must be less than 10% as seen at the telephone terminals. (Ref. 1.) The high group to low group signal amplitude ratio should be 2.0 ±2dB and the absolute amplitude of the low group and high group tones must be within the allowed range. (Ref. 1.) These requirements apply when the telephone is used over a short loop or long loop and over the operating temperature range. The design of the S2559 takes into account these considerations. #### Oscillator The device contains an oscillator circuit with the necessary parasitic capacitances on chip so that it is only necessary to connect a $10 \mathrm{M}\Omega$ feedback resistor and the standard 3.58MHz TV crystal across the Osci and Osco terminals to implement the oscillator function. The oscillator functions whenever a row input is activated. The reference frequency is divided by 2 and then drives two sets of programmable dividers, the high group and the low group. #### **Keyboard Interface** The S2559 employs a calculator type scanning circuitry to determine key closures. When no key is depressed, active pull-down resistors are "on" on the row inputs and active pull-up resistors are "on" on the column inputs. When a key is pushed a high level is seen on one of the row inputs, the oscillator starts and the keyboard scan logic turns on. The active pull-up or pull-down resistors are selectively switched on and off as the keyboard scan logic determines the row and the column inputs that are selected. The advantage of the scanning technique is that a keyboard arrangement of SPST switches are shown in Figure 2 without the need for a common line, can be used. Conventional telephone push button keyboards as shown in Figure 1 or X-Y keyboards with common can also be used. The common line of these keyboards can be left unconnected or wired "high." #### Logic Interface The S2559 can interface with CMOS logic outputs directly. The S2559 requires active "high" logic levels. Since the active pull-up resistors present in the S2559 are fairly low value ( $500\Omega$ typ), diodes can be used as shown in Figure 3 to eliminate excessive sink current flowing into the logic outputs in their "low" state. #### Tone Generation When a valid key closure is detected, the keyboard logic programs the high and low group dividers with appropriate divider ratios so that the output of these dividers cycle at 16 times the desired high group and low group frequencies. The outputs of the programmable dividers drive two 8-stage Johnson counters. The symmetry of the clock input to the two divide by 16 Johnson counters allows 32 equal time segments to be generated within each output cycle. The 32 segments are used to digitally synthesize a stairstep waveform to approximate the sinewave function (See Figure 4.) This is done by connecting a weighted resistor ladder network between the outputs of the Johnson counter, VDD and VREF. VREF closely tracks VDD over the operating voltage and temperature range and therefore the peak to peak amplitude VP (VDD - VREF) of the stairstep function is fairly constant. VREF is so chosen that Vp falls within the allowed range of the high group and low group tones. 0,1 $(V_{\rm ref})$ TIME SEGMENTS The individual tones generated by the sinewave synthesizer are then linearly added and drive a bipolar NPN transistor connected as emitter follower to allow proper impedance transformation, at the same time preserving signal level. #### **Dual Tone Mode** When one row and one column is selected dual tone output consisting of an appropriate low group and high group tone is generated. If two digit keys, that are not either in the same row or in the same column, are depressed, the dual tone mode is disabled and no output is provided. #### Single Tone Mode Single tones either in the low group or the high group can be generated as follows. A low group tone can be generated by activating the appropriate row input or by depressing two digit keys in the appropriate row. A high group tone can be generated by depressing two digit keys in the appropriate column, i.e., selecting the appropriate column input and two row inputs in that column. #### Mode Select S2559A and S2559C have a Mode Select (MDSL) input (Pin 15). When MDSL is left floating (unconnected) or connected to VDD, both the dual tone and single tone modes are available. If MDSL is connected to VSS, the single tone mode is disabled and no output tone is produced if an attempt for single tone is made. The S2559B and S2559D do not have the Mode Select option. #### Chip Disable The S2559B and S2559D have a Chip Disable input at Pin 15 instead of the Mode Select input. The chip disable for the S2559B and S2559D is active "high." When the chip disable is active, the tone output goes to VSS, the row, column inputs go into a high impedance state, the oscillator is inhibited and the MUTE and XMIT outputs go into active states. The effect is the device essentially disconnects from the keyboard. This allows one keyboard to be shared among several devices. #### Crystal Specification A standard television color burst crystal is specified to have much tighter tolerance than necessary for tone generation application. By relaxing the tolerance specification the cost of the crystal can be reduced. The recommended crystal specification is as follows: Frequency: 3.579545MHz ±0.02% $R_S \le 100\Omega$ , $L_M = 96MHY$ $C_M = 0.02pF$ $C_h = 5pF$ #### MUTE, XMIT Outputs The S2559 A, B, C, D have a CMOS buffer for the MUTE output and a bipolar NPN transistor for the XMIT output. With no keys depressed, the MUTE output is "low" and the XMIT output is in the active state so that substantial current can be sourced to a load. When a key is depressed, the MUTE output goes high, while the XMIT output goes into a high impedance state. When Chip Disable is "high" the MUTE output is forced "low" and the XMIT output is in active state regardless of the state of the keyboard inputs. #### Amplitude/Distortion Measurements Amplitude and distortion are two important parameters in all applications of the Digital Tone Generator. Amplitude depends upon the operating supply voltage as well as the load resistance connected on the Tone Output pin. The on-chip reference circuit is fully operational when the supply voltage equals or exceeds 5 volts and as a consequence the tone amplitude is regulated in the supply voltage range above 5 volts. The load resistor, value also controls the amplitude. If R<sub>I</sub>, is low the reflected impedance into the base of the output transistor is low and the tone output amplitude is lower. For RI greater than $5 \mathrm{K}\Omega$ the reflected impedance is sufficiently large and highest amplitude is produced. Individual tone amplitudes can be measured by applying the dual tone signal to a wave analyzer (H-P type 3581A) and amplitudes at the selected frequencies can be noted. This measurment also permits verification of the preemphasis between the individual frequency tones. Distortion is defined as "the ratio of the total power of all extraneous frequencies in the voiceband above 500Hz accompanying the signal to the power of the frequency pair." This ratio must be less than 10% or when expressed in dB must be lower than -20dB. (Ref. 1.) Voiceband is conventionally the frequency band of 300Hz to 3400Hz. Mathematically distortion can be expressed as: Dist. = $$\frac{\sqrt{(V_1)^2 + (V_2)^2 + \dots + (V_n)^2}}{\sqrt{(V_L)^2 + (V_H)^2}}$$ where $(V_1)$ ... $(V_n)$ are extraneous frequency (i.e., intermodulation and harmonic) components in the 500Hz to 3400Hz band and $V_L$ and $V_H$ are the individual frequency components of the DTMF signal. The expression can be expressed in dB as: $${\rm DIST}_{dB} = 20 \log \frac{\sqrt{(V_1)^2 + (V_2)^2 + \dots (V_n)^2}}{\sqrt{(V_L)^2 + (V_H)^2}}$$ $$= 10 \left\{ \log \left[ (V_1)^{2+} \dots (V_n)^2 \right] - \log \left[ (V_L)^{2+} (V_H)^2 \right] \right\} \dots (1)$$ An accurate way of measuring distortion is to plot a spectrum of the signal by using a spectrum analyzer (H-P type 3580A) and an X-Y plotter (H-P type 7046A). Individual extraneous and signal frequency components are then noted and distortion is calculated by using the expression (1) above. Figure 6 shows a spectrum plot of a typical signal obtained from a S2559D device operating from a fixed supply of 4Vdc and $R_L = 10 \mathrm{k}\Omega$ in the test circuit of Figure 5. Mathematical analysis of the spectrum shows distortion to be -30dB (3.2%). For quick estimate of distortion, a rule of thumb as outlined below can be used. "As a first approximation distortion in dB equals the difference between the amplitude (dB) of the extraneous component that has the highest amplitude and the amplitude (dB) of the low frequency signal." This rule of thumb would give an estimate of -28dB as distortion for the spectrum plot of Figure 6 which is close to the computed result of -30dB. In a telephone application amplitude and distortion are affected by several factors that are interdependent. For detailed discussion of the telephone application and other applications of the 2559 Tone Generator, refer to the applications note "Applications of Digital Tone Generator." Ref. 1: Bell System Communications Technical Reference, PUB 47001, "Electrical Characteristics of Bell System Network Facilities at the Interface with Voiceband Ancillary and Data Equipment," August 1976. ## **KEY PULSER** #### **Features** - ☐ Low Voltage CMOS Process for Direct Operation From Telephone Lines - ☐ Inexpensive R-C Oscillator Design Provides Better than ±5% Accuracy Over Temperature and Unit to Unit Variations - ☐ Dialing Rate Can Be Varied By Changing the Dial Rate Oscillator Frequency - ☐ Dial Rate Select Input Allows Changing of the Dialing Rate by a 2:1 Factor Without the Need of Changing Oscillator Components - ☐ Two Selections of Mark/Space Ratios (33-1/3/66-2/3 or 40/60) - □ Twenty Digit Memory for Input Buffering and for Redial With Access Pause Capability - ☐ Mute and Dial Pulse Drivers on Chip - ☐ Accepts Standard Telephone DPCT Keypad Arranged in a 2 of 7 Format; Also Capable of Logic Interface - □ Ignores Multi Key Entries #### General Description The S2560 Key Pulser is a CMOS integrated circuit that converts pushbutton inputs to a series of pulses suitable for telephone dialing. It is intended as a replacement for the mechanical telephone dial and can operate directly from the telephone lines with minimum interface. Storage is provided for 20 digits, therefore, the last dialed number is available for redial until a new number is entered. #### Unique Features of S2560A (18 Pin Package) IDP scaled to the dialing rate such as to produce smaller IDP at higher dialing rates. Additionally, the IDP can be changed by a 2:1 factor at a given dialing rate by means of the IDP select input. #### Unique Features of \$2560B (24 Pin Package) Separate IDP oscillator for selecting an IDP independent of the dialing rate. Provision for changing of the IDP by a 2:1 factor without the need of changing external components. Alternating pacifier tone output simulates dual tone effects coincident with each keyboard number entry. Data subject to change at any time without notice. These sheets transmitted for information only. #### **Absolute Maximum Ratings** | Supply Voltage | +5.5V | |------------------------------------------|-------------------------------------------| | Operating Temperature Range | - 40°C to +85°C | | Storage Temperature Range | 40°C to +125°C | | Voltage at Any Pin | $V_{SS} - 0.3V \text{ to } V_{DD} + 0.3V$ | | Lead Temperature (Soldering, 10 Seconds) | 300°C | Electrical Characteristics Specifications apply over the operating temperature range and $1.5V \le V_{DD}$ to $V_{SS} \le 3.5V$ unless otherwise specified. Absolute values of the measured parameters are specified. | Symbol | Parameter | V <sub>DD</sub> -V <sub>SS</sub><br>(Volts) | Min. | Max. | Units | Conditions | |-----------------------------------|--------------------------------------------|---------------------------------------------|---------------------------|------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Output Current Levels | | | | | | | IOLDP | DP Output Low (Sink) Current | 3,5 | 125 | | μA | V <sub>OUT</sub> = 0.4V | | IOHDP | DP Output High (Source) Current | 1.5<br>8.5 | 20<br>125 | | μ <b>Α</b><br>μΑ | V <sub>OUT</sub> = 1V<br>V <sub>OUT</sub> = 2.5V | | IOLM | MUTE Output Low (Sink) Current | 3.5 | 125 | | μА | V <sub>OUT</sub> = 0.4V | | ІОНМ | MUTE Output High<br>(Source) Current | 1.5<br>3.5 | 20<br>125 | | μ <b>Α</b><br>μ <b>Α</b> | V <sub>OUT</sub> = 1V<br>V <sub>OUT</sub> = 2.5V | | IOLT | Tone Output Low (Sink)<br>Current | 1.5 | 20 | | μA | V <sub>OUT</sub> = 0.4V | | IOHT | Tone Output High (Source)<br>Current | 1,5 | 20 | | μА | V <sub>OUT</sub> = 1V | | IDD | Quiescent Current | 3.5 | | 1 | μA | "On Hook" HS = VDD | | IIL, IIH | Input Current Any<br>Pin (Keyboard Inputs) | 3.5 | 1 | 10 | μA | V <sub>IN</sub> = Open or V <sub>DD</sub> | | I <sub>IL</sub> . I <sub>IH</sub> | Input Current Any<br>Other Pin | 3.5 | | 100 | nA | V <sub>IN</sub> = V <sub>SS</sub> or V <sub>DD</sub> | | IDD | Operating Current | 3.5<br>3.5 | | 60 | μ <b>Α</b> | DP, MUTE open, HS=VSS ("Off Hook") Keyboard processing and dial pulsing space fo = 2400Hz DP, MUTE sourcing 20μA, other conditions as above | | fo | Oscillator Frequency | 1,5 | | 10 | kHz | | | Δfo/fo | Frequency Deviation | 1.5 to<br>2.5<br>2.5 to<br>3.5 | -5<br>-5 | +5 | %<br>% | Fixed R-C oscillator components $50 \mathrm{k}\Omega < \mathrm{R}_D < 750 \mathrm{k}\Omega$ ; $100 \mathrm{pF} < \mathrm{C}_D * < 3000 \mathrm{pF}$ ; $1 \mathrm{M}\Omega < \mathrm{R}_E < 5 \mathrm{M}\Omega$ *330 \text{pF} most desirable value for CD. Indicated and over the operating temperature range and unit to unit variations | | | Input Voltage Levels | | | | | | | V <sub>IH</sub> | Logical "1" | | V <sub>DD</sub><br>- 0.25 | $v_{DD}$ | v | | | VIL | Logical "0" | | Vss | V <sub>SS</sub> + 0.25 | v | | | Cin | Input Capacitance<br>Any Pin | | | 7.5 | рF | | The device power supply should always be turned on before the input signal sources, and the input signals should be turned off before the power supply is turned off ( $V_{SS} \le V_{I} \le V_{DD}$ as a maximum limit). This rule will prevent over-dissipation and possible damage of the input protection diods when the device power supply is grounded. #### **Functional Description** The key pulser is available in two package configurations: 18 pin and 24 pin. The pin function designations for the two packages are outlined in Table 1. #### 18 Pin Configuration This package is specifically designed for the most common telephone application where the rotary dial is to be replaced by a keypad to dial pulse conversion system. Figure 5 shows a typical telephone interface scheme. OFF Hook Operation: The device is continuously powered through a $27\mathrm{k}\Omega$ resistor during OFF hook operation. The $\overline{\mathrm{DP}}$ output is normally high and sources base drive to transistor $Q_1$ to turn ON transistor $Q_2$ . Transistor $Q_2$ replaces the mechanical dial contact used in the rotary dial phones. Dial pulsing begins when the user enters a number through the keyboard. The $\overline{\mathrm{DP}}$ output goes low shutting the base drive to $Q_1$ $\overline{\mathrm{OFF}}$ causing $Q_2$ to open during the pulse break. The $\overline{\mathrm{MUTE}}$ output also goes low during dial pulsing allowing muting of the receiver through transistors $Q_3$ and $Q_4$ . The relationship of dial pulse and mute outputs are shown in Figure 4. ON Hook Operation: The device is continuously powered through a $10M\Omega$ resistor during the ON hook operation. This resistor allows enough current from the tip and ring lines to the device to allow the internal memory to hold and thereby providing storage of the last number dialed. The dialing rate is derived by dividing down the dial rate oscillator frequency. Table 2 shows the relationship of the dialing rate with the oscillator frequency and the dial rate select input. Different dialing rates can be derived by simply changing the external resistor value. The dial rate select input allows changing of the dialing rate by a factor of 2 without the necessity of changing the external component values. Thus, with the oscillator adjusted to 2400Hz, dialing rates of 10 or 20 pps can be achieved. Dialing rates of 7 and 14 pps similarly can be achieved by changing the oscillator frequency to 1680Hz. The Inter-Digit Pause (IDP) time is also derived from the oscillator frequency and can be changed by a factor of 2 by the IDP select input. With IDP select pin wired to $V_{\rm SS}$ , an IDP of 800ms is obtained for dial rates of 10 and 20 pps. IDP can be reduced to 400ms by wiring the IDP select pin to $V_{\rm DD}$ . At dialing rates of 7 and 14 pps, IDP's of 1143ms and 572ms can be similarly obtained. If the IDP select pin is connected to the dial rate select pin, the IDP is scaled to the dial rate such that at 10 pps an IDP of 800ms is obtained and at 20 pps an IDP of 400ms is obtained. The user can enter a number up to 20 digits long from a standard 3 x 4 double contact keypad (Figure 1) or a matrix keyboard arranged out of 12 SPST switches to produce a 2 of 7 format (Figure 2). It is also possible to use a logic interface as shown in Figure 3 for number entry. Antibounce protection circuitry is provided on chip (min. 13ms) to prevent false entry. Any key depressions during the on-hook condition are ignored and the oscillator is inhibited. This insures that the current drain in the on-hook condition is used to retain the memory. #### Normal Dialing The user enters the desired numbers through the keyboard after going off hook. Dial pulsing starts as soon as the first digit is entered. The entered digits are stored sequentially in the internal memory. Since the device is designed in a FIFO arrangement, digits can be entered at a rate considerably faster than the output rate. Digits can be entered approximately once every 50ms while the dialing rate may vary from 7 to 20 pps. The number entered is retained in the memory for future redial. Pauses may be entered when required in the dial sequence by pressing the "#" key, which provides access pauses for future redial. Any number of access pauses may be entered as long as the total entries do not exceed twenty. #### **Auto Dialing** The last number dialed is retained in the memory and therefore can be redialed out by going off hook and pressing the "#" key. Dial pulsing will start when the key is depressed and finish after the entire number is dialed out unless an access pause is detected. In such a case, the dial pulsing will stop and will resume again only after the user pushes the "#" key. #### 24 Pin Configuration All the functions previously described for the 18 pin package configuration can be performed in this configuration. Additionally, the following features are incorporated: A separate IDP oscillator is provided. This allows generation of an IDP time independent of the #### 24 Pin Configuration (Continued) dialing rate. The 1DP select input allows generation of two IDP's with a 2:1 ratio without the need of changing oscillator components. Thus, for an oscillator frequency of 2400Hz, an IDP of 400ms is obtained with IDP select pin wired to $V_{\rm DD}$ and an IDP of 800ms is obtained with the IDP select pin connected to $V_{\rm SS}$ . Table 2 shows the relationship between the IDP and the IDP oscillator frequency. Typical resistance and capacitor values are also provided. The IDP oscillator input can be driven by the dial rate oscillator output if scaling of IDP to dialing rate is desired. 2. A pacifier tone output is provided. As entries from the keyboard are made, the pacifier tone output alternates between two frequencies for successive digits. This provides simulation of the dual tone signaling in the user's earpiece. The tone frequency is derived from the dial rate oscillator and therefore depends on the dialing rate selected. The pacifier tone output alternates between a pair of audio frequencies. 3. A test input is provided to allow testing of the dial rate and IDP oscillators. With the test pin connected to V<sub>SS</sub>, the dial rate and IDP oscillators can be gated on. This facilitates calibration of the required frequencies. In the normal operation, the test input must be connected to V<sub>DD</sub>. Table 1. Pin/Function Descriptions #### 18 Pin Configuration | Pin | Number | Function | |-------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Keyboard<br>(R <sub>1</sub> , R <sub>2</sub> , R <sub>3</sub> , R <sub>4</sub> , C <sub>1</sub> , C <sub>2</sub> , C <sub>3</sub> ) | 7 | These are 4 row and 3 column inputs from the keyboard contacts. These inputs are open when the keyboard is inactive. When a key is pushed, an appropriate row and column input must go to VDD. A logic interface is also possible as shown in Figure 3. Active pull up and pull down networks are present on these inputs when the device begins keyboard scan. The keyboard scan begins when a key is pressed and starts the oscillator. Debouncing is provided to avoid false entry (typ. 20ms). | | Inter-Digit Pause Select (IPS) | 1 | One programmable line is available that allows selection of the pause duration that exists between dialed digits. It is programmed according to the truth table shown in Table 3. Note that preceding the first dialed pulse is an inter-digit time equal to the selected IDP. Two pauses either 400ms or 800ms are available for dialing rates of 10 and 20 pps. IDP's corresponding to other dialing rates can be determined from Tables 2 and 3. | | Dial Rate Select (DRS) | 1 | A programmable line allows selection of two different output rates such as 7 or 14 pps, 10 or 20 pps, etc. See Tables 2 and 3. | | Mark/Space (MS) | 1 | This input allows selection of the mark/space ratio, as per Table 3. | | Mute Out (MUTE) | 1 | A pulse is available that can provide a drive to turn on<br>an external transistor to mute the receiver during the<br>dial pulsing. | Table 1. (Continued) | Pîn | Number | Function | |--------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Dial Pulse Out (DP) | 1 | Output drive is provided to turn on a transistor at the dial pulse rate. The normal output will be "low" during "space" and "high" otherwise. | | Dial Rate Oscillator | 3 | These pins are provided to connect external resistors $R_D$ , $R_E$ and capacitor $C_D$ to form an R-C oscillator that generates the time base for the Key Pulser. The output dialing rate and IDP are derived from this time base. | | Hook Switch (HS) | 1 | This input detects the state of the hook switch contact; "off hook" corresponds to $V_{SS}$ condition. | | Power $(V_{\Omega D}, V_{SS})$ | 18 | These are the power supply inputs. The device is designed to operate from $1.5\mathrm{V}$ to $3.5\mathrm{V}$ . | #### 24 Pin Configuration Pacifier Tone Out (Tone) In addition to the 18 pins listed above, the following pins are provided: 1 | | | quencies as defined in Table 3 when keypad buttons are depressed. | |--------------------------------------------------------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IDP Oscillator (R <sub>I</sub> , R <sub>J</sub> , C <sub>I</sub> ) | 3 | These pins are for connecting external resistors $R_{\rm I}$ , $R_{\rm J}$ and capacitor $C_{\rm I}$ to form an R-C oscillator that determines the duration of the inter-digit pause. This oscillator functions independently of the dial rate oscillator and thus permits the dialing rates and IDP to be independent of each other. | | Test | 1 | This input when connected to $V_{\rm SS}$ turns the dial rate and IDP oscillators on to allow easy calibration of the frequencies desired. In normal operation it must be connected to $V_{\rm DD}$ . | Square wave output that alternates between two fre- Figure 2. SPST Matrix Keyboard Arranged in the 2 of 7 Row, Column Format Figure 3. Logic Interface For the \$2560 G1 through G7 any CMOS type logic gates 877292 Table 2. Table for Selecting Oscillator Component Values for Desired Dialing Rates and Inter-Digit Pauses | Dial Rate | Osc. Freq. | RD (RI) | $R_{E}(R_{J}) = C_{D}(C_{I})$ | | Dial Ra | ate (pps) | IDP (ms) | | |-------------------------------------------------|------------|---------|-------------------------------|------|-----------------------|-----------------------|-----------------------------------------------|--------------------------------------------| | Desired | (Hz) | (kΩ) | (kΩ) | (pF) | DRS=V <sub>SS</sub> | DRS=V <sub>DD</sub> | IPS=V <sub>SS</sub> | IPS=V <sub>DD</sub> | | 5.5/11 | 1320 | | | | 5,5 | 11 | 1454 | 727 | | 6/12 | 1440 | ] | | | 6 | 12 | 1334 | 667 | | 6.5/13 | 1560 | ] | | | 6.5 | 13 | 1230 | 615 | | 7/14 | 1680 | | | | | 14 | 1142 | 571 | | 7.5/15 | 1800 | 1 | | | | 15 | 1066 | 533 | | 8/16 | 1920 | ] | D. D. ( | | 8 | 16 | 1000 | 500 | | 8.5/17 | 2040 | 10 | Be Determ | mea | 8.5 | 17 | 942 | 471 | | 9/18 | 2160 | 1 | | | 9 | 18 | 888 | 444 | | 9.5/19 | 2280 | 1 | | | 9.5 | 19 | 842 | 421 | | 10/20 | 2400 | 1 | | | 10 | 20 | 800 | 400 | | (f <sub>d</sub> /240)/<br>(f <sub>d</sub> /120) | ťd | | | | (f <sub>d</sub> /240) | (f <sub>d</sub> /120) | $\left(\frac{1920}{f_1^*} \times 10^3\right)$ | $\left(\frac{960}{f_i} \times 10^3\right)$ | #### Notes: - In the 18 pin package configuration, IDP is dependent on the dialing rate selected. For example, for a dialing rate of 10 pps, an IDP of either 800ms or 400ms can be selected. For a dialing rate of 14 pps, an IDP of either 1142ms or 571ms can be selected. - 2. In the 24 pin package configuration, the dialing rate and IDP can be independently selected of each other. The general formula outlined in the table may be used to figure out any IDP and dialing rate independent of each other where f<sub>d</sub> = dial rate oscillator frequency in Hz as determined by components R<sub>D</sub>, R<sub>E</sub> and C<sub>D</sub> and f<sub>i</sub> = IDP oscillator frequency in Hz as determined by components R<sub>I</sub>, R<sub>J</sub> and C<sub>I</sub>. Table 3. | Function | Pin Designation | Input Logic Level | Selection | |-----------------------------|-----------------|----------------------------------------------------|----------------------------| | Dial Pulse Rate Selection | DRS | $egin{array}{c} V_{ m SS} \ V_{ m DD} \end{array}$ | (f/240) pps<br>(f/120) pps | | Inter-Digit Pause Selection | IPS | V <sub>DD</sub> | 960 s | | | | $ m v_{ss}$ | 1920 s | | Mark/Space Ratio | M/S | $egin{array}{c} V_{ m SS} \ V_{ m DD} \end{array}$ | 33-1/3/66-2/3<br>40/60 | | On Hook/Off Hook | ĦS | V <sub>DD</sub><br>V <sub>SS</sub> | On Hook<br>Off Hook | Note: f is the oscillator frequency and is determined as shown in Figure 5. ## **TONE RINGER** #### Features - □ CMOS Process for Low Power Operation□ Operates Directly from Telephone Lines - with Simple Interface - ☐ Also Capable of Logic Interface for Non-Telephone Applications - Provides a Tone Signal that Shifts Between Two Predetermined Frequencies at Approximately 16Hz to Closely Simulate the Effects of the Telephone Bell - ☐ Push-Pull Output Stage Allows Direct Drive, Eliminating Capacitive Coupling and Provides Increased Power Output - □ 50mW Output Drive Capability at 10V Operating Voltage - Auto Mode Allows Amplitude Sequencing such that the Tone Amplitude Increases in Each of the First Three Rings and Thereafter Continues at the Maximum Level - ☐ Single Frequency Tone Capability #### General Description The S2561 Tone Ringer is a CMOS integrated circuit that is intended as a replacement for the mechanical telephone bell. It can be powered directly from the telephone lines with minimum interface and can drive a speaker to produce sound effects closely simulating the telephone bell. Data subject to change at any time without notice. These sheets transmitted for information only. #### **Absolute Maximum Ratings** | Supply Voltage | +12V | |-------------------------------------|-------------------------------------------| | Operating Temperature Range | -25°C to +70°C | | Storage Temperature Range | - 40°C to +125°C | | Voltage at Any Pin | $V_{SS} - 0.3V \text{ to } V_{DD} + 0.3V$ | | Lead Temperature (Soldering, 10sec) | 300°C | Electrical Characteristics Specifications apply over the operating temperature range and $3.5V \le V_{DD}$ to $V_{SS} \le 12V$ unless otherwise specified. | Symbol | Parameter | Min. | Max. | Units | Conditions | |----------------------------------|---------------------------------------------------------------------------------|-----------------------|-----------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $v_{DS}$ | Operating Voltage (VDD to VSS) | 8.0 | 13.5 | V | Ringing, THC pin open | | $v_{DS}$ | Operating Voltage | 4,0 | | V | "Auto" mode, non-ringing | | IDS | Operating Current | : | 500 | μА | Non-ringing, V <sub>DD</sub> = 10V, THC<br>pin open, DI pin open or V <sub>SS</sub> | | t <sub>DS</sub> | Operating Current | | 25 | μA | Non-ringing, V <sub>DD</sub> = 6V, THC<br>pin open | | | Output Drive | | | | | | iOHC | Output Source Current OUTH, OUTC outputs) | 5 | | mA | V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 9V | | IOLC | Output Sink Current<br>(OUTH, OUTC outputs) | 5 | i | mA | V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 0.5V | | ІОНМ | Output Source Current (OUTM output) | 2 | | mΛ | V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 9V | | IOLM | Output Sink Current (OUT <sub>M</sub> output) | 2 | | mA | $V_{DD} = 10V$ , $V_{OUT} = 0.5V$ | | IOHL | Output Source Current (OUTL output) | 1 | | mA | V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 9V | | $I_{\rm OLL}$ | Output Sink Current<br>(OUTL output) | 1 | | mA | $V_{DD} = 10V, V_{OUT} = 0.5V$ | | | CMOS to CMOS | | <del></del> | | | | VIH | Input Logic "1" Level | 0.7 V <sub>DD</sub> | V <sub>DD</sub> + 0.3 | v | All inputs | | $\overline{v}_{lL}$ | Input Logic "0" Level | V <sub>SS</sub> - 0.3 | 0.3 V <sub>DD</sub> | v | All inputs | | VOHR | Output Logic "1" Level (Rate output) | 0.9V <sub>DD</sub> | | V | I <sub>O</sub> = 10μA (Source) | | VOLR | Output Logic "0" Level (Rate output) | | 0.5 | V | $I_O = 10\mu A (Sink)$ | | V <sub>OZ</sub> | Output Leakage Current (OUTH, OUTM outputs in high impedance state) | | 1<br>-1 | μΑ<br>μΑ | V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 0V<br>V <sub>DD</sub> = 10V, V <sub>OUT</sub> = 10V | | Cin | Input Capacitance | | 7,5 | рF | Any pin | | Δfa/fo | Oscillator Frequency Deviation | -5 | +5 | % | Fixed RC component values $1M\Omega \leqslant R_{Si}, R_{ti} \leqslant 5M\Omega;$ $100k\Omega \leqslant R_{sm}, R_{tm} \leqslant 750k\Omega$ $150pF \leqslant C_{So}, C_{to} \leqslant 3000pF$ $330pF$ recommended value of $C_{SO}$ and $C_{to}$ , supply voltage varied from $9V \pm 2V$ (over temperature and unitunit variations) | | RLOAD | Output Load Impedance Connected<br>Across OUT <sub>H</sub> and OUT <sub>C</sub> | 600 | | Ω | Tone Frequency Range = 300Hz to 3400Hz | | I <sub>IH</sub> , I <sub>L</sub> | Leakage Current, Vin = VDD or VSS | | 100 | nA | Any input, except DI pin VDD - 10V | | V <sub>TH</sub> | POE Threshold Voltage | 6.5 | 8 | V | | | $v_{Z}$ | Internal Zener Voltage | 11 | 13 | V. | IZ = 5mA | The device power supply should always be turned on before the input signal sources, and the input signals should be turned off before the power supply is turned off ( $V_{SS} \le V_{I} \le V_{DD}$ as a maximum limit). This rule will prevent over-dissipation and possible damage of the input-protection diode when the device power supply is grounded. #### **Functional Description** The S2561 is a CMOS device capable of simulating the effects of the telephone bell. This is achieved by producing a tone that shifts between two predetermined frequencies with a frequency ratio of 5:4 at approximately 16Hz rate. Tone Generation: The output tone is derived from a tone oscillator that uses a 3 pin R-C oscillator design consisting of one capacitor and two resistors. The oscillator frequency is divided alternately by 4 or 5 at the shift rate. Thus, with the oscillator adjusted for 5120Hz, a tone signal is produced that alternates between 512Hz and 640Hz at the shift rate. The shift rate is derived from another 3 pin R-C oscillator which is adjusted for a nominal frequency of 5120Hz. It is divided down to 16Hz which is used to produce the shift in the tone frequency. It should be noted that in the special case where both oscillators are adjusted for 5120Hz, it is only necessary to have one external R-C network for one oscillator with the other oscillator driven from it. The oscillators are designed such that for fixed R-C component values an accuracy of ±5% can be obtained over the operating supply voltage, temperature and unit-unit variations. See Table 1 for component and frequency selections. In the single frequency mode, activated by connecting the SFS input to VSS only the higher frequency continuous tone is produced by using a fixed divider ratio of 4 and by disabling the shift operation. Ring Signal Detection: The incoming 20Hz ring signal can be applied to the "ENABLE" input after proper voltage limiting by diode clamping (see Figure 2). It is first squared up and then processed by an 2ms filter followed by a dial pulse reject filter. The 2ms filter removes undesirable noise transitions that may occur on the ring signal. The dial pulse reject filter is clocked by an 8Hz signal derived from the rate oscillator and insures that frequencies below 16Hz will not pass through. This helps eliminate dial pulse interference and insures that the tone ringer will not trigger during dial pulsing. Another benefit of the dial pulse reject filter is that an output tone is not produced unless the ring signal duration exceeds 125ms. This insures that the tone ringer will not respond to momentary bursts of ringing less than 125 milliseconds in duration (Ref. 1). In logic interface applications, the 2ms filter and the dial pulse reject filter can be inhibited by wiring the Det. INHIBIT pin to $V_{DD}$ . This allows the tone ringer to be enabled by a logic '1' level applied at the "ENABLE" input without the necessity of a 20Hz ring signal. Voltage Sensing: The S2561 contains a voltage sensing circuit that enables the output stage and the rate and tone oscillators, only when the supply voltage exceeds a predetermined value. Typical value of this threshold is 7.3 volts. This produces two benefits. First, it insures that the audible intensity of the output tone is fairly constant throughout the ringing period; and secondly, it insures proper circuit operation during the "auto" mode operation by reducing the power consumption to a minimum when the supply voltage drops below 7.3 volts. This extends the supply voltage decay time beyond 4 seconds (off period of the ring signal) with an adequate filter capacitor and insures the proper functioning of the "amplitude sequencing" counter. It is important to note that the operating supply voltage should be well above the threshold value during the ringing period and that the filter capacitor should be large enough so that the ripple on the supply voltage does not fail below the threshold value. A supply voltage of 10 to 12 volts is recommended. In applications where the tone ringer is continuously powered and below the threshold level, the internal threshold can be bypassed by connecting the THC pin to $V_{DD}$ . The internal threshold can also be reduced by connecting an external zener diode between the THC and $V_{DD}$ pins. Auto Mode: In the "auto" mode, activated by wiring the "auto/manual" input to VSS, an amplitude sequencing of the output tone can be achieved. Resistors $R_L$ and $R_M$ are inserted in series with the Out<sub>L</sub> and Out<sub>M</sub> outputs, respectively, and paralleled with the Out<sub>H</sub> output (Figure 1). Load is connected across OutH and OutC pins. RI is chosen to be higher than RM. In this manner the first ring is of the lowest amplitude, second ring is of medium amplitude and the third and consecutive rings thereafter are at maximum amplitude. For the proper functioning of the "amplitude sequencing" counter the device must have at least 4.0 volts across it throughout the ring sequence. The filter capacitor is so chosen that the supply voltake will not drop below 4.0 volts during the off period. At the end of a ring sequence when the off period substantially exceeds the 4 second duration, the counter will be reset. This will insure that the amplitude sequencing will start correctly beginning a new ring sequence. The counter is held in reset during the "manual" mode operation. This produces a maximum ring amplitude at all times, Output Stage: The output stage is of push-pull type #### Functional Description (Continued) consisting of buffers L, M, H and C. The load is connected across pins $\operatorname{Out}_H$ and $\operatorname{Out}_C$ (Figure 2). During ringing, the $\operatorname{Out}_H$ and $\operatorname{Out}_C$ outputs are out of phase with each other and pulse at the tone rate. During a non-ringing state, all outputs are forced to a known level such as ground which insures that there is no DC component in the load. Thus, direct coupling can be used for driving the load. The major benefit of the push-pull arrangement is increased power output. Four times as much power can be delivered to the load for the same operating voltage. Buffers M and H are three-state. In the "auto" mode buffer M is active only during the second ring and in the "high impe- dance" state at all other times. Buffer H is active beginning the third ring. In the "manual" mode buffers H, L and C are active at all times while buffer M is in a high impedance state. The output buffers are so designed that they can source or sink 5mA at a $V_{\rm DD}$ of 10 volts without appreciable voltage drop. Care has been taken to make them symmetrical in both source and sink configurations. Diode clamping is provided on all outputs to limit the voltage spikes associated with transformer drive in both directions $V_{\rm DD}$ and $V_{\rm SS}$ . Normal protection circuits are present on all inputs. Table 1. Pin/Function Descriptions | Pin | Number | Function | |-----------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power ( $V_{DD}$ , $V_{SS}$ ) | 2 | These are the power supply pins. The device is designed to operate over the range of 3.5 to 13.5 volts. A range of 10 to 12 volts is recommended for the telephone application. | | Ring Enable (EN, $\overline{\text{EN}}$ ) | 2 | These pins are to connect the 20Hz ring signal. EN can also be used for DC level enabling by wiring the DI pin to $V_{\rm DD}$ . | | Auto/Manual (A/M) | 1 | "Auto" mode for amplitude sequencing is implemented by wiring this pin to $V_{SS}$ , "Manual" mode results when connected to $V_{DD}$ . The amplitude sequencing counter is held in reset during the "manual" mode, | | $\mathbf{Outputs}\;(Out_L,Out_M,Out_H,Out_C)$ | 4 | These are the push-pull outputs. Load is directly connected across $\operatorname{Out}_H$ and $\operatorname{Out}_C$ outputs. In the "auto" mode, resistors $R_L$ and $R_M$ can be inserted in series with the $\operatorname{Out}_L$ and $\operatorname{Out}_M$ outputs for amplitude sequencing (see Figure 1). | | Oscillators | | | | Rate Oscillator $(OSCR_i, OSCR_m, OSCR_o)$ | 3 | These pins are provided to connect external resistors $RR_i$ , $RR_m$ and capacitor $CR_o$ to form an R-C oscillator with a nominal frequency of 5120Hz. See Table 2 for components selection. | | Tone Oscillator $(OSCT_i, OSCT_m, OSCT_o)$ | 3 | These pins are provided to connect external resistors $RT_i$ , $RT_m$ and capacitor $CT_0$ to form an R-C oscillator from which the tone signal is derived. With the oscillator adjusted to 5120Hz, a tone signal with frequencies of 512Hz and 640Hz results. See Table 2 for components selection. | | Threshold Control (THC) | 1 | The internal threshold voltage is brought out to this pin for modification in non-telephone applications. It can be bypassed by wiring the THC pin to $V_{DD}$ . It can be reduced by connecting a suitable zener diode between THC and $V_{DD}$ . | Table 1 (Continued) | Pin | Number | Function | |-------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Detector Inhibit (DI) | 1 | When this pin is connected to $V_{DD}$ , the dial pulse reject filter is disabled to allow DC level enabling of the tone ringer. This pin should be hardwired to $V_{SS}$ in normal telephone-type applications. | | Single Frequency Select (SFS) | 1 | When this pin is connected to VSS, only a single frequency continuous tone is produced as long as the tone ringer is enabled. In normal applications this pin should be hardwired to VDD. | Table 2. Selection Chart for Oscillator Components and Output Frequencies | Tone/Rate<br>Oscillator<br>Frequency<br>(Hz) | $R_{\mathbf{I}}$ $(\mathbf{k}\Omega)$ | Scillator Componer $\mathbf{R}_{\mathbf{M}}$ (k $\Omega$ ) | nts<br>C <sub>O</sub><br>(pF) | Rate<br>(Hz) | Tone<br>(Hz) | |----------------------------------------------|---------------------------------------|------------------------------------------------------------|-------------------------------|-----------------------|----------------------------------------------| | 5120 | | | | 16 | 512/640 | | 6400 | 1 | | | 20 | 640/800 | | 3200 | 1 | To Be Determined | l | 10 | 320/400 | | 8000 | 7 | | | 25 | 800/1000 | | fo | | | | f <sub>0</sub><br>320 | $\frac{\text{fo}}{10} / \frac{\text{fo}}{8}$ | #### Applications Typical Telephone Application: Figure 2 shows the schematic diagram of a typical telephone application for the S2561 tone ringer circuit. Power is derived from the telephone lines by the network formed by capacitor C1, resistor R1, diode bridge d1 through d4, and filter capacitor C2. C2 is chosen to be large enough so as to insure that the power supply ripple during ringing does not fall below the internal threshold level (typ. 7.3 volts) and to provide large enough decay time during the off period. A typical value of C2 may be $47\mu$ F. C1 and R1 are chosen to satisfy the Ringer Equivalence Number (REN) specification (Ref. 1). For REN = 1 the resistor should be a minimum of $8.2k\Omega$ . It must be noted that the amount of power that can be delivered to the load depends upon the selection of $C_1$ and $R_1$ . The device is enabled by limiting the incoming ring signal through resistors R<sub>2</sub>, R<sub>3</sub> and diodes d<sub>5</sub> and d<sub>6</sub>. Zener diode Z<sub>1</sub> (typ. 9-27 volts) may be required in certain applications where large voltage transients may occur on the line during dial pulsing. The internal 2ms filter and the dial pulse reject filter will suppress any undesirable components of the signal and will only respond to the normal 20Hz ring signal. Ring signals with frequencies above 16Hz will be detected. The configuration shown will produce a tone with frequency components of 512Hz and 640Hz with a shift rate of approximately 16Hz and deliver at least 50mW to an $8\Omega$ speaker through a 2000 $\Omega$ :8 $\Omega$ transformer. If "manual" mode is used, a potentiometer may be inserted in series with the transformer primary to provide volume control. If "automatic" mode is used, resistors R<sub>L</sub> and R<sub>M</sub> can be chosen to provide desired amplitude sequencing. Typically, signal power will be down 20 log $$\left(\frac{R_{LOAD}}{R_L + R_{LOAD}}\right)$$ dB during the first ring, and down 20 log $\left(\frac{R_{LOAD}}{R_M + R_{LOAD}}\right)$ dB during the second ring with maximum power delivered to the load beginning the third and consecutive rings. In applications where dial pulse rejection is not necessary, such as in DTMF telephone systems, the ENABLE pin may be connected directly to VDD. Det. Inh pin must be connected to VDD to allow DC level enabling of the ringer. Non-Telephone Applications: The configuration shown in Figure 3-A may be used in non-telephone applications where it is desired to simulate the telephone bell. The internal threshold is bypassed by wiring THC to VDD. The rate output (16Hz) is divided down by a 7 stage divider type 4024 to produce two signals: a 2 second on/2 second off signal and a 4 second on/4 second off signal. The first signal is connected to the EN pin and the second to the DI pin to produce a 2 second on/4 second off telephone-type ring signal. The ring sequence is initiated by removing the reset on the divider. If "auto" mode is used, a reset signal must be applied to the "amplitude sequencing" counter at the end of a ring sequence so that the circuit will respond correctly to a new ring sequence. This is done by temporarily connecting the "auto/manual" input to Vss. Figure 3-B shows a typical application for alarms, buzzers, etc. Single frequency mode is used by connecting the SFS input to VSS. A suitable on/off rate can be determined by using the 7 stage divider circuit. If continuous tone is not desired, the 16Hz output can be used to gate the tone on and off by wiring it into the ENABLE input. Many other configurations are possible depending upon the user's specific application. Reference 1. Bell system communications technical reference: PUB 47001 of August 1976 "Electrical characteristics of Bell System Network Facilities at the interface with Voiceband Ancillary and Data Equipment" — Sections 2.6.1 and 2.6.3. Figure 1-A. Output Stage Connected for Auto Mode Operation Figure 1-B. Output Stage Connected for Manual Mode Operation. Figure 2. Typical Telephone Application of the \$2561 ## REPERTORY DIALER #### **Features** - □ CMOS Process Achieves Low Power Operation - □ 8 or 16 Digit Number Capability (Pin Programmable) - ☐ Dial Pulse and Mute Output - ☐ Tone Outputs Obtained by Interfacing with Standard AMI \$2559 Tone Generator - ☐ Two Selections of Dial Pulse Rate - ☐ Two Selections of Inter-Digit Pause - ☐ Two Selections of Mark/Space Ratio (33-1/3/66-2/3 or 40/60) - ☐ Memory Storage of 32 8-Digit Numbers or 16 16-Digit Numbers with Standard AMI S5101 RAM - 16-Digit Memory for Input Buffering and for Redial with Access Pause Capability - □ Accepts the Standard Telephone DPCT Keypad or SPST Switch X-Y Matrix Keyboards; Also Capable of Logic Interface - Ignores Multi Key Entries - □ Inexpensive, but Accurate R-C Oscillator □ Design Provides Better Than ±3% Accuracy Over Supply Voltage, Temperature and Unit Unit Variations and Allows Different Dialing Rates, IDP and Tone Drive Timing by Changing the Time Base - ☐ Power Fail Detection - ☐ BCD Output with Update for Number Display Applications #### **General Description** The S2562 Repertory Dialer is a CMOS integrated circuit that can perform storing or retrieving, normal dialing, redialing or auto dialing and displaying of one of several telephone numbers. It is intended to be used with the AMI standard S5101—256x4 RAM that functions as telephone number storage. With one S5101 up to 32 8-digit or 16 16-digit numbers can be stored. It can provide either dial pulses or DTMF tones with the addition of the AMI S2559 tone generator for either the dial or tone line applications. Data subject to change at any time without notice. These sheets transferred for information only. #### **Absolute Maximum Ratings** | Supply Voltage | 13.5V | |---------------------------------------|-------------------------------------------------| | Operating Temperature Range | - 40°C to +85°C | | Storage Temperature Range | 40°C to +125°C | | Voltage at Any Pin | V <sub>SS</sub> - 0.3V to V <sub>DD</sub> +0.3V | | Lead Temperature (Soldering, 10 sec.) | 200°C | Electrical Characteristics Specifications apply over the operating temperature range and $4.5V \le V_{\rm DD}$ to $V_{\rm SS} \le 5.5V$ unless otherwise specified. Absolute values of measured parameters are specified. | Symbol | Parameter | Min. | Max. | Units | Conditions | |----------------------------------------|--------------------------------------------|------|----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Output Drive | | <b> </b> | <u> </u> | | | IOLDP | DP Output Sink Current | 400 | · · | μA | $V_{OUT} = 0.4V$ , $V_{DD} = 5V$ | | $I_{OHDP}$ | DP Output Source Current | 400 | | μA | $V_{OUT} = 3.6V$ , $V_{DD} = 5V$ | | $I_{OLM}$ | MUTE Output Sink Current | 400 | · <del>-</del> | μΑ | $V_{OUT}$ = 0.4V, $V_{DD}$ = 5V | | Іонм | MUTE Output Source Current | 400 | | μÂ | $V_{OUT} = 3.6V, V_{DD} = 5V$ | | IOLPF | PF Output Sink Current | 100 | | μΑ | $V_{OUT} = 0.4V, V_{DD} = 3V$ | | $I_{OHPF}$ | PF Output Source Current | 100 | | μA | $V_{OUT} = 3.6V, V_{DD} = 5V$ | | | CMOS to CMOS | | | | | | $V_{1L}$ | Logic "0" Input Voltage | | 1.5 | V | All inputs, V <sub>DD</sub> = 5V | | $v_{IH}$ | Logic "1" Input Voltage | 3.5 | | v | All inputs, V <sub>DD</sub> = 5V | | V <sub>OL</sub> | Logic "0" Output Voltage | - | 0.5 | v | All outputs except $\overline{DP}$ , $\overline{MUTE}$ , $\overline{PF}$ , $I_O = 10\mu A$ , $V_{DD} = 5V$ | | V <sub>OH</sub> | Logic "1" Output Voltage | 4.5 | | v | All outputs except $\overline{DP}$ , $\overline{MUTE}$ , $\overline{PF}$ , $\overline{IO} = -10\mu A$ , $\overline{V_{DD}} = 5V$ | | | Current Levels | | | | | | $I_{DD}$ | Quiescent Current | | 25 | μΑ | Standby, V <sub>DD</sub> = 5V | | $I_{DD}$ | Operating Current | | 500 | μÄ | All valid input combinations, DP, MUTE, PF outputs open V <sub>DD</sub> = 5V | | I <sub>IL</sub> , I <sub>IH</sub> | Input Current Any Pin<br>(keyboard inputs) | 10 | 100 | μА | $V_{IN} = V_{SS}$ or $V_{DD}$ , $V_{DD} = 5V$ | | $\overline{I_{IL}}, \overline{I_{IH}}$ | Input Current All Other Pins | | 100 | nA | $V_{\rm IN} = V_{\rm SS}$ or $V_{\rm DD}$ , $V_{\rm DD} = 5V$ | | I <sub>OZ</sub> | Output Current in High<br>Impedance State | | 1 | μΑ | V <sub>DD</sub> = 5V, V <sub>OUT</sub> = 0V data<br>outputs (D1-D4) | | | ·<br> | | -1 | μA | $V_{DD} = 5V$ , $V_{OUT} = 5V$ | | fo | Oscillator Frequency | 4 | 10 | kIIz | $V_{\rm DD} = 5V$ (min. duty cycle 30/70) | | Δfo/fo | Frequency Deviation | -3 | +3 | % | $\begin{array}{l} V_{DD} - V_{SS} \ from \ 4.5 V \ to \ 5.5 V. \\ Fixed \ R-C \ oscillator \ components \\ 50 k\Omega \leqslant R_M \leqslant 750 k\Omega ; \\ 1M\Omega \leqslant R_I \leqslant 5 M\Omega ; \\ 150 pF \leqslant C_O \leqslant 3000 pF ; \\ 330 pF \ most \ desirable \ value \ for \\ C_O, \ fo \leqslant 10 kHz \ over \ the \ operating \\ temperature \ and \ unit-unit \ variations \end{array}$ | | CIN | Input Capacitance, Any Pin | | 7.5 | pF | , | The device power supply should always be turned on before the input signal sources, and the input signals should be turned off before the power supply is turned off ( $V_{SS} \leqslant V_{T} \leqslant V_{DD}$ as a maximum limit). This rule will prevent over-dissipation and possible damage of the input-protection diode when the device power supply is grounded. #### **Functional Description** The S2562 is a CMOS controller designed for storing or retrieving, normal dialing, redialing or auto dialing and displaying of one of several telephone numbers. It is intended to be used with the AMI standard S5101 256x4 RAM that functions as a telephone number storage. A single S5101 RAM will store up to 32 8-digit or 16 16-digit telephone numbers. The S2562 can be programmed to work with either 8-digit or 16-digit numbers by means of the Number Length Select (NLS) input. The S2562 uses an inexpensive, but accurate R-C oscillator as a time base from which the dialing rate and inter-digit pause duration (IDP) are derived. Different dialing rates and IDP durations can be implemented by simply adjusting the oscillator frequency. The dialing rate and IDP can be further changed by a 2:1 factor by means of the dialing rate select (DRS) and inter-digit pause select (IPS) inputs. Thus, for the oscillator frequency of 8kHz, dialing rates of 10 and 20 pps and IDP's of 400 and 800ms can be achieved. The mark/space ratio is fixed independent of the time base and can be selected to be either 33-1/3 / 66-2/3 or 40/60 by means of M/S input. Over supply voltage (5V ±10%), operating temperature range and unitunit variations, timing accuracy of ±3% can be achieved. A mute output is also available for muting of the receiver during dial pulsing. See Figure 5 for timing relationship. The S2562 can be programmed by means of the MODE input for dual tone signaling applications as well. In this mode, it can interface directly with the AMI standard S2559 Tone Generator to produce the required DTMF signals. The tone on/off rate during an auto dial operation in this mode is derived from the time base. For the oscillator frequency of 8kHz, a tone drive rate of 50ms on, 50ms off is obtained. Different rates can be implemented by adjusting the time base as desired. See Tables 2 and 3 for the various combinations. In the tone mode, the mute output is used to gate the tone generator on and off. The 8 address lines that are normally used for addressing the RAM are also used to address the tone generator row, column inputs. Figure 6 shows a typical system application. The S2562 can perform the following functions: #### Normal Dialing The user enters the desired number digits through the keyboard after going off hook. Dial pulsing starts as soon as the first digit is entered. The entered digits are stored sequentially in the internal memory. Since the device is designed in a FIFO arrangement, digits can be entered at a rate considerably faster than the output rate. Digits can be entered approximately once every 50ms while the dialing rate may vary from 7 to 20 pps. Debouncing (min. 20ms) is provided on the keyboard entries to avoid false entries. The number entered is retained for future redial. Pauses may be entered when required in the dial sequence by pressing the "#" key, which provides access pauses for future redial. Any number of access pauses may be entered as long as the total entries do not exceed the total number of digits (8 or 16). An update pulse is generated to update the display digit as a new entry is made. In the tone mode the tones will be transmitted at the rate the user enters the digits. #### Redialing The last number entered is retained in the internal memory and can be redialed by going "off hook" and depressing the "redial" (RDL) key. The RDL key is a unique 2 of 12 matrix location (R5, C3). The number being redialed out is displayed as it is dialed out. In the tone mode, the redial tone drive rate depends upon the time base as discussed before. # Storing of a Normally Dialed or Redialed Number into the External Memory After the normal dialing or redialing operation, the telephone number can be stored in the external memory for future repertory dialing use by going on hook and initiating the following key sequence. - 1. Push "store" (ST) button. - 2. Depress the single digit key corresponding to the desired address location. Note that the "ST" key is a unique 2 of 12 matrix location $(R_{5}, C_{1})$ . # Storing of a Telephone Number into the External Memory This operation is performed "on hook" and no outdialing occurs. A telephone number can be stored in the desired address location by initiating the following key sequence. - Push the "\*" key (This instructs the device to accept a new number for storage into the internal memory). - Enter the digits (including any access pauses) corresponding to the desired number. - 3. Push the "ST" key. Push the single digit key corresponding to the desired address location. The entire sequence can be repeated to store as many numbers as desired. #### Displaying of a Stored Telephone Number This is an "on hook" operation. Either the last dialed number or the number stored in the external memory can be displayed one digit at a time. The key sequence for displaying the last dialed number is as follows: - 1. Push the "read" (R) key. - 2. Push the "RDL" key. The number in the external memory can be displayed as follows: - 1. Push the "R" key. - Push the single digit key corresponding to the desired address location. Note that the "R" key is a unique 2 of 12 matrix location $(R_5, C_2)$ . The number is displayed one digit at a time at a rate determined by the time base. With a time base of 8kHZ the display will be on 500ms, off 500ms. The display is updated by producing an update pulse. The update pulse must be decoded with external logic (one inverter and one 2-input gate) as shown in Figure 6. The display is blanked by outputting an illegal (non BCD) code such as 1111. The 4511-type BCD to 7 segment decoder driver latch will blank the display when the illegal code is detected. When other driver circuits are employed, external logic must be used to detect the illegal code. #### Repertory Dialing This is the most common mode of usage and allows the user to dial automatically any number stored in the memory. This mode is initiated by the following key sequence after going off hook. - Push the "\*" key. - Push the single digit key corresponding to the desired address location. The number is displayed as it is dialed out. In the tone mode, the tone driver rate is dependent on the time base as described earlier. #### Pause Note that the out dialing in the repertory or redial operation continues unless an access pause is detected. The outpulsing will stop and resume only when the user terminates the access pause by pushing the "\*" key again. #### Power Fail Detection This output is normally high. When the supply voltage falls below a predetermined value, it goes low. The output can then drive a suitable latching device that will switch the memory to either the tip and ring or an auxilliary battery supply. #### Memory Expansion The memory can be expanded by paralleling additional S5101 RAM's. External logic must be used to enable the desired RAM corresponding to a desired address location. The S2562 can drive up to 2 RAM's without the need of buffering address and data lines. #### **Keybounce Protection** When a key closure is detected by the \$2562, an internal timeout (min. 4ms at fo = 8kHz) is started. Any transitions that occur during this timeout will reset the timer to zero so that a key will only be accepted as valid after a noise free timeout period. The key must remain closed for an additional 16ms before released. Thus, the total make time of the key must be at least 20ms. The key must be released for at least 1ms before a new key is activated. Any transitions occurring when the key is released are ignored as long as the make time does not exceed 4ms. Table 1. Pin/Function Descriptions | Pin | Number | Function | |-----------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power (VDD, VSS) | 2 | These are the power supply inputs. The device is designed to operate from 3.5V to 13.5V. | | Keyboard (R <sub>1</sub> -R <sub>6</sub> , C <sub>1</sub> -C <sub>6</sub> ) | 12 | These are 6 row and 6 column inputs from the keyboard contacts. When a key is pushed, an appropriate row and column input must go to VDD or connect to each other. Figures 1 and 2 depict the standard telephone DPCT and X-Y matrix keyboard arrangements that can be used. A logic, interface is also possible as shown in Figure 3. Debouncing is provided to avoid false entry (typ. 20ms for oscillator frequency of 8kHz). Key pad entry options are shown in Figure 4. | | Number Length Select (NLS) | 1 | This input permits programming of the device to accept either 8-digit numbers or 16-digit numbers. | | Mode Select (MODE) | 1 | This input allows the use of the device in either dial pulsing applications or tone drive applications. | | Dial Rate Select (DRS) | 1 | This input allows selection of two different dialing rates such as $10$ or $20$ pps, $7$ or $14$ pps, etc. See Tables $2$ and $3$ . | | Inter-Digit Pause Select (IPS) | 1 | This allows selection of the pause duration that exists between dialed digits. It is programmed according to the truth table shown in Table 3. Note that preceeding the first dialed digit is an inter-digit time equal to the selected IDP. Two pause durations, either 400ms or 800ms are available at dialing rates of 10 and 20 pps. IDP's corresponding to other dialing rates can be determined from Tables 2 and 3. | | Mark/Space Ratio Sclect (M/S) | 1 | This input allows selection of the mark/space ratio as per Table $3$ . | | Mute Output (MUTE) | 1 | A pulse is available that can provide drive to turn on an external transistor to mute the receiver during dial pulsing. See Figure 5 for mute and dial pulse output relationship. It is also used as a keyboard disable in the tone drive applications. See Figure 6. | | Dial Pulse Output $(\overline{\mathrm{DP}})$ | 1 | Output drive is provided to turn on a transistor at the dial pulse rate. This output will be normally high and go low during "space" or "break." | | Display Memory I/O Data (D <sub>1</sub> -D <sub>4</sub> ) | 4 | These are 4 bidirectional pins for inputting and outputting data to the external memory and display driver. | Table 1. (Continued) | Pin | Number | Function | |----------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Memory Enable (CE) | 1 | This line controls the external memory operation. | | Memory Read/Write (R/W) | 1 | This line controls the read or the write operation of the external memory. This output along with the $\overline{\text{CE}}$ output can be used to produce a pulse to update the external display. See Figure 6. | | Tone Generator/Memory Address (A <sub>0</sub> -A <sub>7</sub> ) | 8 | These are 8 output lines that carry the external memory address and tone generator row/column information. | | Hook Switch $(\overline{\text{IIS}})$ | 1 | This input conveys the state of the subset. "Off hook" corresponds to VSS condition. | | Power Fail Detect $(\overline{PF})$ | 1 | This output is normally high and goes low when the power supply falls below a certain predetermined value. | | Oscillator (OSC <sub>i</sub> , OSC <sub>m</sub> , OSC <sub>o</sub> ) | 3 | These pins are provided to connect external resistors R <sub>I</sub> , R <sub>M</sub> and capacitor C <sub>O</sub> to form an R-C oscillator that generates the time base for the repertory dialer. The output dialing rate, tone drive rate and IDP are derived from this time base. | | | 40 | | Figure 2. SPST Matrix Keyboard Arranged in the 2 of 12 Row, Column Format SPST MATRIX KEYBOARD B77285 Table 2. Table for Selection of Oscillator Component Values for Desired Dialing Rate, IDP or Tone Drive Rate. | Dial Rate | Osc. Freq. | Oscillator Components | | Dial Rate (PPS) IDP (ms) | | Tone Drive | | | | |------------------|------------|------------------------|------------------------|--------------------------|----------------|-----------------------|------------------------|------------------------|-------------------------------------| | Desired<br>(PPS) | fo<br>(Hz) | R <sub>M</sub><br>(kΩ) | R <sub>I</sub><br>(kΩ) | (pF) | $DRS = V_{SS}$ | DRS = V <sub>DD</sub> | IPS = V <sub>SS</sub> | IPS = V <sub>DD</sub> | On/Off<br>Time (ms) | | 5,5/11 | 4400 | | • | | 5,5 | 11 | 1454 | 727 | 90/90 | | 6/12 | 4800 | 1 | | | 6 | 12 | 1334 | 667 | 83,3/83,3 | | 6.5/13 | 5200 | 1 | | | 6.5 | 13 | 1230 | 615 | 77/77 | | 7/14 | 5600 | ] | То Ве | | 7 | 14 | 1142 | 571 | 71/71 | | 7.5/15 | 6000 | İ | | | 7.5 | 15 | 1066 | 533 | 66.7/66.7 | | 8/16 | 6400 | ] D <sub>1</sub> | etermin | ed | 8 | 16 | 1000 | 500 | 62,5/62,5 | | 8,5/17 | 6800 | } | | | 8.6 | 17 | 942 | 471 | 59/59 | | 9/18 | 7200 | ]. | | | 9 | 18 | 888 | 444 | 55,5/55,5 | | 9.5/19 | 7600 | | | | 9.5 | 19 | 842 | 421 | 52,6/52,6 | | 10/20 | 8000 | | | | 10 | 20 | 800 | 400 | 50/50 | | (fo/800)/ | fo | 1 | | | fo/800 | fo/400 | 6400 x 10 <sup>3</sup> | 3200 x 10 <sup>3</sup> | $400 \times 10^3 / 400 \times 10^3$ | | (fo/400) | | | | | | | fo | fo | fo fo | Table 3. | Function | Pin Designation | Input Logic Level | Selection | |-----------------------------|-----------------|------------------------------|------------------------------| | Dial Rate Selection | DRS | ${ m V_{SS}} { m V_{DD}}$ | (fo/800) pps<br>(fo/400) pps | | Inter-Digit Pause Selection | IPS | $ rac{ m V_{DD}}{ m V_{SS}}$ | (3200/fo) S<br>(6400/fo) S | | Mark/Space Ratio | M/S | ${ m v_{ss}} { m v_{DD}}$ | 33-1/3/66-2/3<br>40/60 | | Hook Switch | HS | $ rac{ m V_{DD}}{ m V_{SS}}$ | On hook<br>Off hook | | Mode Selection | MODE | ${ m V_{SS}} { m V_{DD}}$ | Dial pulse<br>Tone drive | | Number Length Selection | NLS | ${ m v_{ss}} { m v_{pp}}$ | 8 digits<br>16 digits | Note: fo is the oscillator frequency and is determined as shown in Table 2. # SIGNAL PROCESSING PERIPHERAL #### **Features** - ☐ High Speed VMOS Technology - ☐ Programmable for Digital Processing of Signals in Voice-Grade Communications Systems and Other Applications with Signal Frequencies in the Range of DC to 10KHz - ☐ Extremely Fast 12-Bit Parallel Multiplier On Chip (300ns Max. Multiplication Time) - □ Built-In ROM (256 x 17), 3-Port RAM (256 x 16) and Add/Subtract Unit (ASU) - ☐ Pipeline Structure for High Speed Instruction Execution (300ns Max. Cycle Time) - ☐ Bus Oriented Parallel I/O for Easy Microprocessor Interface - □ Additional Serial I/O for Easy A/D-D/A Interface #### General Description The S2811 Signal Processing Peripheral (SPP) is a high speed special purpose arithmetic processor with on-chip ROM, RAM, multiplier, adder/subtractor, accumulator and I/O organized in a pipeline structure to achieve an effective operation of one multiply, add and store of up to 12-bit numbers in 300 nanoseconds. # CMOS SINGLE CHANNEL μ-LAW PCM CODEC/FILTER SET #### **Features** ☐ Full Independent Encoder with Filter and Decoder with Filter Chip Set Meets or Exceeds AT&T D3 and CCITTG, 712 Specifications On-Chip Phase-Lock Loop Derives All Timing Low Power Dissipation - Power Down Mode Wide Supply Voltage Range □ Low Absolute Group and Relative Delay Distortion □ Single Negative Polarity Voltage Reference Input ☐ Encoder with Filter Chip Has Built-In Auto Zero Circuit that Eliminates Long Term Drift Errors and Need for Trimming Serial Data Rates from 56KHz to 3.088MHz at 8KHz Nominal Sampling Rate □ Programmable Gain Input/Output Amplifier #### General Description The S2900 and S2901 form a monolithic CMOS Companding Encoder/Decoder chip set designed to implement the per channel voice frequency. CODECS used in PCM Channel Bank and PBX systems requiring a μ-255 law transfer characteristic. Each chip contains two sections: (1) a band-limiting filter, and (2) an analog ↔ digital conversion circuit that conforms to the u-255 law transfer characteristic. Transmission and reception of 8-bit data words containing the analog information is performed at 1.544Mb/s rate with analog sampling occurring at 8KHz rate. A strobe input is provided for synchronizing the transmission and reception of time multiplexed PCM information of several channels over a single transmission line. <sup>\*</sup>Common Channel Interoffice Signaling ### \$2900/\$2901 Typical Group Delay Characteristic | Device | Abs. Gr. Delay<br>μs | | Relative Gr. Delay<br>Distortion (Over Band<br>of 1000Hz to 2600Hz | | |---------------------------|----------------------|----------|--------------------------------------------------------------------|-------------| | | f=1000Hz | f=2600Hz | wrt 1000Hz)μs | | | Encoder Low Pass | 166.4 | 250 | 83.6 | · · · · · · | | Encoder High Pass | 104.0 | 22 | -82.0 | | | Encoder (Total) | 270.4 | 272 | 1.6 | | | Decoder Low Pass | 153.0 | 250.0 | 97.0 | | | Encoder + Decoder (Total) | 423.4 | 522.0 | 98.6 | | # Consumer and Interface Products ### **REMOTE CONTROL CIRCUITS** | PART NO. | DESCRIPTION | PROCESS | POWER SUPPLIES | VO BITS | PACKAGES | |----------|----------------------------|---------|----------------|---------|----------| | \$2600 | Remote Control Transmitter | CMOS | +7V to +10V | 11 | 16 Pin | | S2601 | Remote Control Receiver | P-1* | + 10V to + 18V | 5 | 22 Pin | | S2742 | Remote Control Decoder | P-MOS | +97 | | 18 Pin | | S2743 | Remote Control Encoder | P-MOS | +97 | | 16 Pin | ### **TOUCHCONTROL™ INTERFACE CIRCUITS** | PART NO. | DESCRIPTION | PROCESS | POWER SUPPLIES | INPUT/OUTPUT | PACKAGES | |--------------|-----------------------------|---------|----------------|--------------|----------| | 59260/61 | Seven-Switch Interface | P-12 | -13.5V to -18V | CMOS/TTL | 22 Pin | | \$9263/64/65 | Sixteen-Switch Interface | P. 2 | -13.5V to -18V | CMOS/MOS/TTL | 40 Pin | | S9262 | Fourteen-Switch Interlace | p-1* | -13.5V to -18V | MOS/TTL | 22 Pin | | S9266 | Thirty-Two-Switch Intertace | P-12 | -13.5V to -18V | MOS/TTL | 40 Pin | #### **CONSUMER CIRCUITS** | PART NO. | DESCRIPTION | PROCESS | POWER SUPPLIES | DIGITS | PACKAGES | |----------|------------------------------------------|---------|----------------|--------|--------------| | S1424A | Five Function LCD Walch with alternating | CMOS | + 1.5V | 31/2 | ΰie | | | time/date mode and voltage tripler | | | | | | | display options | | | | | | S1424C | Five Function LCD Watch Circuit | CMOS | + 1.5V | 31/2 | Die | | \$1425A | Five Function LCD Watch Circuit | CMOS | + 1.5V | 31/2 | Chip Carrier | | S1427A | Five Function LCD Watch Circuit | CMOS | + 1.5V | 31/2 | 40 Pin | | \$1865 | Digital Clock Circuit — LED/Gas | P-15 | +6V to +16V | 31/2 | 40 Pin | | | Discharge Auto Clock | | | | | | S1998A | 50/60Hz Line LED Clock Circuit | P. 2 | +8V to +26V | 4 | 40 Pin | | \$1998B | 50/60Hz Line Clock — Gas Discharge | p- ₹ | +8V to +33V | 4 | 40 Pin | | \$2709 | Fluorescent Automotive Digital Clock | P- 2 | +12V | 4 | 22 Pin | | \$2733 | Six Function LCD Watch Circuit | CMOS | +1.5V | 4 | 40 Pin | #### **ORGAN CIRCUITS** | PART NO. | DESCRIPTION | PROCESS | POWER SUPPLIES | POWER<br>DISSIPATION | PACKAGES | |----------|-------------------------------|-------------------|----------------|----------------------|----------| | \$10110 | Analog Shift Register | p. Jz | - 24V | | ß Pin | | S10111 | Analog Shift Register | p. <b>&gt;</b> | - 24V | | 8 Pin | | S10129 | Six-Stage Frequency Divider | p. z | -14V, -27V | 350mW | 14 Pin | | S10130 | Six-Stage Frequency Divider | P-I2 | -14V, -27V | 350mW | t4 Pin | | S10131 | Six-Stage Frequency Divider | P- 2 | -14V, -27V | 350m₩ | 14 Pin | | \$10377 | Analog Shift Register | P-IF MOS | | | 8 Pin | | S10430 | Divider-Keyer | P-I2 MOS | | | 40 Pin | | \$2193 | Seven-Stage Frequency Divider | p. 1 | - 14V, - 28V | 300mW | 14 Pin | | S2567 · | Rhythm Counter | HI V <sub>I</sub> | -15V, -27V | 400mW | 14 Pin | | \$8890 | Rhythm Generator | P- 2 | 12V | 400mW | 40 Pin | | \$9660 | Rhythm Generator | p. s | - 12V | 400mW | . 28 Pin | | \$50240 | Top Oclave Synthesizer | p. z | -11V, -16V | 360₼₩ | 16 Ріл | | \$50241 | Top Octave Synthesizer | P- 2 | -11V, -16V | 360∕nW | 16 Pin | | S50242 | Top Octave Synthesizer | P- * | - 11V, - 16V | 360mW | 16 Pin | | \$50243 | Top Octave Synthesizer | P- 2 | -11V, -16V | 360mW | 16 Pin | | S50244 | Top Octave Synthesizer | P- 2 | 11V, 16V | 360mW | 16 Pin | | \$50145 | Top Oclave Synthesizer | P- <b>≯</b> | -11V, -16V | 360mW | 16 Pin | # ENCODER/DECODER REMOTE-CONTROL 2-CHIP SET #### Features - $\square$ Small Parts Count No Crystals Required - ☐ Easily Used in LED, Ultrasonic, RF, or Hardwire Transmission Schemes - ☐ Very Low Reception Error - ☐ Low Power Drain CMOS Transmitter for Portable and Battery Operation - □ 31 Commands 5-bit Output Bus with Data Valid - ☐ 3 Analog (LP Filterable PWM) Outputs - ☐ Muting (Analog Output Kill/Restore) - ☐ Indexing Output 2½ Hz Pulse Train - □ Toggle Output (On/Off) - ☐ Mask-Programmable Codes #### **Functional Description** The S2600/S2601 is a set of two LSI circuits which allows a complete system to be implemented for remote control of televisions, toys, security systems, industrial controls, etc. The choice of transmission medium is up to the user and can be ultrasonic, infrared radio frequency, or hardwire such as twisted pair or telephone. The use of a synchronizing marker technique has eliminated the need for highly accurate frequencies generated by crystals. The S2600 Encoder typically generates a 40kHz carrier which it amplitude-modulates with a base-band message of 12 bits, each bit preceded by a synchronizing marker pulse. Bits 1 and 12 denote sync and end-of-message, respectively, bits 2 thru 6 constitute a fixed preamble which must be received correctly for the command bits to be received, and bits 7 thru 11 contain the command data. The S2601 Decoder produces an output only after two complete, consecutive, identical, 12-bit transmissions. Marker pulses, preamble bits, and redundant transmissions, have given the S2600/S2601 system a very high immunity to noise, without a large number of discrete components. #### S2600 Encoder The S2600 is a CMOS device with an on-chip oscillator, 11 keyboard inputs, a keyboard encoder, a shift register, and some control logic. The oscillator requires only an external resistor and capacitor, and to conserve power, runs only during transmission. Keyboard inputs are active-low, and have internal pull-up resistors to $V_{\rm DD}$ . When one keyboard input from the group A thru E is activated with one from the group F thru K, the keyboard encoder generates a 5-bit code, as given in the table entitled ((S2600/S2601 CODING," below. This code is loaded into a shift register in parallel with the sync, preamble, and end bits, to form the 12-bit message. The transmitter output is a 40 kHz square wave of 50% duty factor which has been pulse-code-modulated by (i.e., ANDed with) a signal having a recurring pattern, a bit frame of 3.2 millisecond duration. This bit frame is comprised of three signals: the Start signal which is 0.4 milliseconds of logic "1"; followed by the Data signal which is 1.2 milliseconds of the lowest-order shift register bit; followed by the Mark signal which is 1.6 milliseconds of logic "0" (except in the first bit frame where Mark = 1 to facilitate receiver synchronization). The shift register is clocked once per bit frame, so that its 12-bit message is transmitted once in 38.4 milliseconds. The minimum number of tranmissions that can occur is two, but if the keyboard inputs are active after the first 3.6 milliseconds of any 12-bit transmission, one more 12-bit transmission will result. Transmissions are always complete, never truncated, regardless of the keyboard inputs. The Test Input is used for functional testing of the device. A low level input will cause the oscillator frequency to be gated to the Data Output pin. This input has an internal pull-up resistor to $V_{\rm DD}$ . #### S2601 Decoder The S2601 is a PMOS LSI device with an on-chip oscillator, five keyboard inputs, a 40 kHz signal input, and 11 outputs. The oscillator requires only an external R and C. The five keyboard inputs are active-low with internal pull-up resistors to VSS; activation of any two causes one of 10 possible 5-bit codes to be generated and fed to the outputs of the S2601, overriding any 40 kHz signal input. Two counters, the signal counter and the local counter, are clocked respectively by the signal input and a 40 kHz signal from the local RC oscillator timing chain. A 40 kHz input lasting 3.2 milliseconds (i.e., an initial bit frame) causes the signal counter to overrun and reset both itself and the local counter. At specific intervals thereafter, the local counter generates pulses used to interrogate the contents of the signal counter. Resynchronization of the counters occurs every bit frame so that the interrogation yields valid data bits even if the transmitter oscillator frequency has deviated up to ½ 24% with respect to the receiver oscillator frequency. Decoded data bits from the next five bit frames following the initial synchronizing frame are compared with the fixed preamble code. The next five decoded bits, the command bits, are converted to a parallel format and are compared against the command bits saved from the prior transmission. If they match, and if the preamble bits are correct, the command bits are gated to the receiver outputs. However, a mismatch causes the receiver outputs to be immediately disabled, and the new command bits are saved for comparison against the command bits from the next 12-bit transmission. In the case where 2 identical, proper, 12-bit transmissions are immediately followed either by transmissions with erroneous preamble codes or by nothing, the receiver outputs will be activated during the end-frame of the second transmission, and will be disabled 45 milliseconds thereafter. In the rest (disabled) state the five Binary Outputs are at a "1" logic level; when not in the rest state, one or more of the open-sourced output transistors will conduct to $V_{\rm DD}$ . The Data Valid output is low during the rest state, and high whenever data is present at the Binary Outputs. The S2601 has five other outputs: Pulse Train, On/Off, Analog A, Analog B, and Analog C. The states of these outputs are controlled by the 10 particular Binary Output codes which the receiver Keyboard Inputs can cause to be generated. The Pulse Train output provides a 2.44 Hz square wave (50% duty factor) whenever 11011 appears at the Binary Outputs, but otherwise it remains at a logic "0". This pulse train can be used for indexing, e.g., for stepping a TV channel selector. The On/Off ("mains") output changes state each time 01111 appears at the Binary Outputs. In TV applications the On/Off output is most often used to kill and restore the main power supply. Analog Outputs A, B, and C are 10 kHz pulse trains whose duty factors are independently controllable. With a simple low-pass filter each of these outputs can provide 64 distinct DC levels suitable for control of volume, color saturation, brightness, motor speed, etc. Each Analog Output increases its duty factor in response to a particular Binary Output code and decreases its duty factor in response to another code — 6 codes in all. The entire range of 0% to 100% duty factor can be traversed in 26 seconds or at a rate of the oscillator frequency divided by 262,144. All three Analog Outputs are set to 50% duty factor whenever 01011 appears at the Binary Outputs. Analog A is mutable; 01100 sets it to 0% duty factor. If 01100 then disappears and reappears, the original duty factor is restored. This of course implements the TV "sound killer" feature. The S2601 has an on-chip power-on reset (POR) circuit which sets the Pulse Train and On/Off Outputs to "0," sets the Analog Outputs at 50% duty factor, and insures that Analog A is muted. No external components are required to implement POR, but a POR input has been provided for applications where externally controlled reset is desirable, e.g., where the power supply voltage rise time is extremely slow. The POR input has an internal resistor pull-up to $V_{SS}$ ; pulling it low causes a reset. #### S2600/S2601 Coding | Transmitter<br>Keyboard<br>Input Pins<br>Tied to Vss | Receiver<br>Keyboard<br>Apput Pins<br>Trad to V <sub>DD</sub><br>(See Note T) | Resulting<br>Raceiver<br>Binary<br>Outputs<br>1 2 3 4 5 | Receiver Dedicated Functions (Mask programmable except for rest state) | |------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------| | AB<br>AF | | 0 0 0 0 | | | AF<br>AG | <u>-</u> | 0 0 0 1<br>0 0 0 1 0 | | | ÄH | _ | 0 0 0 1 1 | | | ) Ai | BC BC | 0 0 1 0 0 | Increase Analog C pulse width | | AJ. | _ | 0 0 1 0 1 | | | AK | _ | | | | BF | Aξ | 0 0 1 1 1 | Decrease Analog B pulse width | | BG<br>BH | <u>-</u> | 0 1 0 0 0 | | | 18 | - | Ď i Ď i Ď | | | BJ | DE | 0 1 0 1 1 | RESET Analog (See Note 2) | | ΒK | ÇE | 0 1 1 0 0 | MUTE (See Note 3) | | CF | _ | 0 1 1 0 1 | | | <u>CG</u> | | 0 1 1 1 0 | T 1 0 /0// 0 | | CH<br>CI | CD | 0 1 1 1 1 1 1 1 1 1 0 0 0 0 | Toggle On/Off Output | | ែដំ | <u> </u> | 1 0 0 0 1 | | | Čĸ | _ | 1 0 0 0 1<br>1 0 0 1 0 | | | DF DF | AD | 1 0 0 1 1 | Increase Analog B pulse width | | DG DG | BD | f 0 1 0 0 | Increase Analog B pulse width<br>Becrease Analog C pulse width | | OH<br>OI | - | 1 | | | l bj | AB | 1 6 1 1 1 | Increase Analog A pulse width | | ľőĸ | 25 | 1 1 0 0 0 | Increase Analog in perse share | | EF | _ | 1 1 0 0 1 | | | l ĒĞ | _ | 1 1 0 1 0 | | | ĒĤ | 8E | 1 1 0 1 1 | Activate Pulse Train Output | | EI<br>EJ | _ | 1 1 1 0 0 | | | l Ēķ | ĀC | 1 1 1 1 1 | Decrease Analog A pulse width | | | _ | iiiii | Rest State | NOTES: 1. Receiver keyboard inputs overside any remote signal input. 2. Sets Analog A, B, and C waveforms to 80% Outy Factor. 3. First operation sets Analog A to 0% Outy Factor; second operation restores former Analog A Duty Factor. ## Electrical Specifications - 2600 Encoder All voltages measured with respect to $V_{\rm SS}$ . ## Absolute Maximum Ratings | · _ <del>-</del> _ | | |----------------------------------------------|----------------| | Operating ambient temperature T <sub>A</sub> | 0 to +70°C | | Storage temperature | 65°C to +150°C | | Positive voltage on any pin | +14V | | Negative voltage on any pin | 0.3V | ## **Electrical Characteristics** Unless otherwise noted, $V_{\rm DD}$ = 8.5 ± 1.5V and $T_A$ = 0 to +70°C. | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |------------------------------------------|-----------------------|------|-------------------------------------------------|------|------------------|------------------------------------| | fO | Oscillator frequency | 7 | 640 | 2000 | kHz | $R_{OSC}$ = 12K, $C_{OSC}$ = 100pF | | $\Delta f0/f0$ | Frequency deviation | -10 | | +10 | % | Fixed Rosc, Cosc, VDD ± 10% | | | | | <u>; — </u> | | | During transmission, | | $I_{DD}$ | Supply current | ] | 1 | 2 | mA | Data Output = 1mA | | ! | Standby | | | 10 | μA | No transmission (25°C) | | $\overline{V_{IH}}$ | Input "1" threshold | 25 | 50 | | %V <sub>DD</sub> | | | $ rac{V_{\mathrm{IH}}}{V_{\mathrm{IL}}}$ | Input "0" threshold | | 50 | 75 | $%V_{DD}$ | | | $I_{IL}$ | Input source currrent | 50 | ı" | 200 | μA | $\overline{V_{I}} = 0V$ | | I <sub>IL</sub> | Output source current | 1 | 1.5 | | mA | $V_0 = V_{DD} - 3V$ | | $I_{OL}$ | Output sink current | 2 | 5 | | mA | $V_0 = +0.5V$ | Note: Circuit operates with $V_{\mbox{DD}}$ from 3.0V to 12.0V. ## Electrical Specifications - S2601 Decoder All voltages measured with respect to VDD. ## Absolute Maximum Ratings | Operating ambient temperature $T_A$ $0^{\circ}C$ to $70^{\circ}C$ | |-------------------------------------------------------------------| | Storage temperature 65°C to +150°C | | V <sub>SS</sub> power supply voltage | | Positive voltage on any pin VSS +0.3V | | Negative voltage on any pin VSS -31V | ## **Electrical Characteristics** Unless otherwise noted, $V_{SS}$ = 14 ± 4V and $T_A$ = 0 to +70°C | Symbol | Parameter | Min. | Тур. | Max. | Units | Conditions | |----------------------------------|-----------------------------------------------------|-------------------|---------------------------------------|-----------------------|--------------------|--------------------------------------------------------------| | fO | Oscillator frequency | 7 | 640 | 2000 | kHz | $R_{OSC} = 71K, C_{OSC} = 25pF$ | | $\Delta \mathbf{f}0/\mathbf{f}0$ | Frequency deviation | -10 | · · · · · · · · · · · · · · · · · · · | +10 | % | Fixed Rosc, Cosc, Vss | | I <sub>SS</sub> | Supply current | | 34 | 50 | mA | No loads, V <sub>DD</sub> = 18V | | | : | | 28 | | mA | $V_{DD} = 10V$ | | Signal In | | | • | | | | | $\overline{V}_{IH}$ | "1" threshold | | 70 | 85 | $%V_{\mathrm{SS}}$ | | | $\overline{V_{\Pi_i}}$ | "0" threshold | 30 | 48 | | $%V_{SS}$ | | | V <sub>IH</sub> -V <sub>IL</sub> | Voltage hysteresis | 5 | | 35 | $%V_{SS}$ | | | Keyboar | d and POR Inputs: | | | | _ <del></del> | | | $\overline{v}_{IH}$ | "1" voltage | V <sub>SS</sub> 5 | V <sub>SS</sub> -3.0 | | V | | | $\overline{v_{IL}}$ | "0" voltage | | | V <sub>SS</sub> - 5.5 | V | | | ım | Source current | 50 | 150 | 300 | $\mu A$ | $V_{\rm I} = V_{\rm SS} - 10 \text{V}$ | | | Debounce delay<br>(Keyboard inputs only) | 1.45 | | 2.2 | msec | | | Binary O | utputs (open source): | | | | | | | I <sub>OL</sub> | Sink current | -1.28 | | ! | mA | V <sub>0</sub> =V <sub>SS</sub> - 5.2V, V <sub>SS</sub> =18V | | | | - 0.50 | - 0.60 | ì I | mA | $V_0 = V_{SS} - 5.2V, V_{SS} = 10V$ | | | Duration | 34.9 | | | msec | f0 = Max = 704 kHz | | Analog C | Outputs (open drain): | | | | | | | $\Delta V_{step}$ | Step Voltage change | | $V_{SS}/64$ | | V | | | I <sub>OH</sub> | Source current | | 1.04 | | mA | $V_0 = V_{SS} = 0.5 \text{ V}, V_{SS} = 10 \text{ V}$ | | ĺ | <u> </u> | | 1.15 | | mΑ | $V_0 = V_{SS} - 0.5V, V_{SS} = 18V$ | | | } | 1.0 | 1.2 | | m A | V <sub>0</sub> =V <sub>SS</sub> -1V | | fstep | Analog step rate | | 10 | | kHz | (f0 ÷ 64) | | Data Val | id, Pulse Train, and On/Off C | outputs: | | | | | | $I_{OH}$ | Source current | 1 | 1.5 | | mΑ | $V_0 = V_{SS} - 2V$ | | $I_{OL}$ | Sink current | - 40 | - 50 | | μΑ | $V_0 = .7V$ | | tr | Risetime (.1V <sub>SS</sub> to .9 V <sub>SS</sub> ) | | | 10 | μsec | $R_L = \infty$ , $C_L 50pF$ | | $\overline{\mathbf{t_f}}$ | Falltime (.9V <sub>SS</sub> to .1 V <sub>SS</sub> ) | | | 10 | µsec | $R_L = \infty$ , $C_L$ 50 pF | Note: Circuit operates with VSB from 7.0V to 30.0V # The AMI TouchControl Kit TCK-100 ## Instructions for Assembly and Operation #### INTRODUCTION The AMI TouchControl kit demonstrates the ease with which this unique system of capacitive switching may be implemented. Included in the kit are a printed circuit board and AMI's newly developed S9263 TouchControl circuit. The printed wiring board, which has 16 touch switches etched onto its top surface, contains on its reverse side all the interconnection necessary to interface the S9263 inputs with the 16 touch switches and the S9263 outputs with 16 light emitting diodes. As the touch switches are activated, the corresponding diodes are lighted to indicate the output states of the S9263. If desired, external logic may be operated by connecting a cable directly to the S9263 outputs. Additional components required for the kit are readily available, and assembly of the kit should take less than an hour's time. The circuit board may be mounted either on standoffs or on a standard aluminum chassis box. #### PARTS LIST FOR AMI TOUCHCONTROL KIT: | QUANTITY<br>REQUIRED | DESCRIPTION | QUANTITY<br>REQUIRED | DESCRIPTION | | | | |----------------------|----------------------------------------|----------------------|---------------------------------|--|--|--| | 1 | S9263 TouchControl circuit (Included) | 16 | 3.3KΩ Resistor 4 Watt | | | | | 1 | Printed wiring board (Included) | 1 | Transistor 2N3569 or equivalent | | | | | 1 | Transformer, 12.6 volt 300mA | 1 | 500μF capacitor/20 volts | | | | | | Radio Shack P/N 273-1385 or equivalent | 1 | 0.33µF capacitor | | | | | 1 | Line cord | 1 | 220 pF capacitor | | | | | 1 | Diode IN920 or equivalent | 16 | Light emitting diode - MV5023 | | | | | 2 | 100KΩ Resistor ¼ Watt | | or equivalent | | | | | 1 | 60KΩ Resistor ¼ Watt | 1 | Aluminum chassis box - 15" x 9 | | | | | 1 | 15KΩ Resistor ¼ Watt | | Bud # AC1421 or equivalent | | | | | 1 | $10 \mathrm{K}\Omega$ Resistor ¼ Watt | | (optional) | | | | #### ASSEMBLY The circuit board may be assembled easily by referring to Figure 2, a view of the reverse side of the board. For appearance, it is recommended that all components except the LED's and the S9263 be mounted on the reverse side of the board, with all leads cut off flush with the board's top surface. For convenience, a 15 volt power supply is provided on the circuit board, so that the system may be plugged into a standard 110 volt outlet. If desired, an external DC supply of 15 volts may be used, connecting the positive and negative outputs to the corresponding holes designated for C1. If a DC supply is used, the transformer, diode, and C1 may be eliminated. #### OPERATION The AMI TouchControl kit provides sixteen touch switches that interface with the S9263 to activate sixteen light emitting diodes. Each of the switches numbered from one to fifteen has a light associated with it which is labeled with the same number. The switch labeled "T" is used to select the mode of operation of the S9263, either momentary or toggle. When the LED labeled "T" is off, touch pads one through fifteen operate as momentary switches, and any switch's corresponding LED will turn on when the switch is touched, remaining on only for the duration of touching the switch. If "T" is touched, the "T" LED will turn on and stay on even after "T" is untouched. The S9263 is now operating in a toggle mode, and the brief touch of any switch from one through fifteen will cause its corresponding LED to turn on and latch. Subsequent activations of the switch will turn the LED off and on alternately. Touching "T" once again causes the "T" LED to turn off, and the S9263 once again operates in the momentary mode. By removing the $0.33\mu\text{F}$ capacitor, it is possible to use the "T" pad as a clear switch. In this mode, all numbered pads function as "push on, push off" switches. Touching the "T" pad turns off all LED's corresponding to the numbered switches. To operate external logic systems with the Touch-Control kit, a cable may be soldered, using a grounded soldering iron, directly to the outputs of the S9263. The voltage on an output that is turned off (corresponding LED is off) is - 15 volts (or V<sub>DD</sub>). When turned on, the output will rise towards ground (V<sub>SS</sub>). Appropriate loading conditions are specified in the advanced product description for this part. | PART NUMBER | PART DESCRIPTION | PART NUMBER | PART DESCRIPTION | |-------------|--------------------------------------------------|----------------|------------------------------------| | R1, R4 | 100 KΩ ¼ Watt resistor | Q1 | NPN transistor 2N3569 or equivalen | | R2 | 10 KΩ ¼ Watt resistor | D1 | Diode IN920 or equivalent | | R3 | 47KΩ¼ Watt resistor | L1 thru L16 | Light emitting diode — MV5023 or | | R5 | 15 KΩ ¼ Watt resistor | | equivalent | | R6 thru R21 | 3.3 K $\Omega$ ¼ Watt resistor | IC1 | AMI integrated circuit S9263 | | C1 | $500 \mu \text{F}$ capacitor $20 \text{Volts}$ | $\mathbf{r}$ 1 | Transformer 12, 6 VAC @ 800 mA. | | C2 | 220 pF capacitor | | Radio Shack P/N 273-1385 | | C3 | 0.33 μF capacitor | | or equivalent | PARTS LIST FOR ASSEMBLING TCK -100 KIT: #### TOUCHCONTROL INTERFACE ## **FEATURES** - Interfaces with up to 16 touch switches - Eliminates contact noise - Comparator sensing permits use with wide variety of touch switch configurations - Momentary or toggle operation electrically selectable - Outputs are TTL/CMOS/MOS compatible - Simplifies design of touch-sensitive switches #### GENERAL DESCRIPTION The S9260 series of MOS TouchControl interface circuits permits almost any control panel containing mechanical switches to be easily replaced by a flat-surface capacitive control panel providing superior styling, reliability, ease of cleaning, and safety. Connecting directly to a screened or etched pattern on the panel's reverse side, these MOS circuits provide outputs to drive a variety of logic systems from household appliances to industrial controls. All system functions are then selected by merely touching the flat conductive Touch-Control "switch" areas that have been deposited on the panel's front surface in practically any configuration desired. These circuits provide an individual output for each of up to 16 TouchControl switches. For applications requiring more switches or encoded outputs, refer to AMI's \$9262 and \$9266, which can interface with up to 32 switches. #### FUNCTIONAL DESCRIPTION Fabricated with P-channel ion implanted MOS/LSI technology, the S9260 family\* of TouchControl integrated circuits has been designed to interface with a variety of touch panel switches and provide a high degree of flexibility in the selection of touch panel materials, layout of touch pad configurations, and design of switching functions. These circuits can interface directly with either seven TouchControl switches (22 lead versions) or sixteen TouchControl switches (40 lead versions) sions). For each TouchControl switch input there is a corresponding output that may be used to interface with various logic families such as CMOS or TTL. Both momentary and "push on - push off" (toggle) switching operations are available on all AMI TouchControl circuits and are electrically selected by the logic levels of one input pin. To ensure reliable switch action, a built-in delay is incorporated in all circuits requiring a minimum touch time for switch response. #### TYPICAL APPLICATIONS - Appliance Control Panels - Home Entertainment Systems - Power Tool Controls - Televisions - Automotive Controls - Telephones - Games - Fast Food Waterproof Keyboards - Moisture Proofing - Industrial Controllers - Computer Terminals - Keyboards - Instrumentation - 16 to 1 Multiplexers - Microprocessor Interface - Vending Machines - Cash Registers #### ABSOLUTE MAXIMUM RATINGS Voltage on any pin relative to $V_{SS}$ : +0.3V to -20V Storage temperature (Ambient) -65°C to +150°C Operating temperature range: 0°C to +70°C <sup>\*</sup>FOR MULTIPLEXED TOUCHCONTROL CIRCUITS SEE AMI \$9262 and \$9266. #### ELECTRICAL CHARACTERISTICS $(0^{\circ}C \le T_A \le 70^{\circ}C; V_{SS} = 0V; V_{DD} = -13.5V \text{ to } -18.0V \text{ unless otherwise specified.})$ | SYMBOL | PARAMETER | MIN | TYP | MAX | UNITS | CONDITIONS | |-------------------------|--------------------------------------------------------------|--------------------------------------------------------|--------|--------------------------------------------|--------------|-----------------------------------------------------------------------------------------------| | V <sub>IL</sub> | Input logic 0 level all except "1" inputs. | + 0.3 | 0 | - 1.5 | Volts | Note: M/T input is internally pulled up to VSS | | $V_{\text{lH}}$ | Input logic 1 level - all except "I" inputs | - 10.0 | - 12.0 | - 18.0 | Volts | | | f <sub>RC</sub> | Internal oscillator frequency measured at RC input. | 50 | | 100 | kHz | | | $T_{S}$ $T_{RST}$ | Switch delay time Time to reset all latches using M/T input. | 65 | 100 | 135<br>135 | msec<br>msec | Frequency measured at RC Input = 50 kH2 | | Vol.<br>Voll | Output low voltage<br>Output high voltage | V <sub>SS</sub> | | - 1.0<br>V <sub>DD</sub> | Volts | V <sub>BB</sub> = V <sub>SS</sub> ; 10K<br>resistive load to V <sub>DD</sub> | | $V_{ m OL} \ V_{ m OH}$ | Output low voltage Output high voltage | $\begin{vmatrix} V_{SS} \\ V_{BB} + 0.4 \end{vmatrix}$ | | V <sub>SS</sub> - 0.5 <br>V <sub>BB</sub> | Volts | $V_{SS} = +5V$ ; $V_{BB} = 0V$<br>$V_{DD} = 12V$ ; $2800\Omega$<br>resistive load to $V_{SS}$ | | SC) | Sean clock output: Output low voltage | V <sub>SS</sub> | | - 1.5 | | Max. capacitive loading < 150 pF | | $I_{\mathbf{DD}}$ | Output high voltage Supply Current | | 7.0 | V <sub>DD</sub><br>15.0 | ma | Outputs unconnected | #### OPERATION Device operation can be understood by referring to Figure 1, depicting a typical application of the S9263. Each of the sixteen pairs of series capacitors labeled S1 – S16 is one touch switch located on a TouchControl panel. (For details on touch panel configuration and operation, see the TouchControl application note included in this APD.) In each capacitor pair, the two common plates represent the conductive area on the control panel surface that is to be touched. The other two plates are formed by two conductive surfaces parallel to the touched surface and located directly under it on the reverse side of the panel. Referring again to Figure 1, the S9263 generates a clock signal on output SCI that is applied to one plate of each capacitor pair; this signal passes through the two series capacitors and is detected in the MOS circuit. When a panel switch surface is touched, the signal level into the chip dimishes, and the on-chip differential amplifier senses the change and performs the appropriate switching function. For example, if surface S1 is touched, the signal at input 13 decreases, and output 03, normally open, now becomes active and drives the S1 input to the TTL circuitry toward voltage level V<sub>RB</sub>. #### **I INPUTS** Inputs from the touch switch pads to the TouchControl circuit are labeled I0 through I15 (S9263, S9264, and S9265) or I0 through I6 (S9260 and S9261). Each I input relates directly to an 0 output of identical numeral. #### RC INPUT A resistor connected to VDD and a capacitor connected to VSS are connected to the RC input pin to establish the on-chip clock frequency that controls the touch switch delay time. Nominal values for these components are suggested in Figure 1, but they may be varied to change clock frequency over a range of 50 kHz to 100 kHz. #### REF INPUT In order to allow flexibility in the choice of Touch-Control panel materials, switch layout, and switch size, AMI Touch Control inputs have been designed to detect a differential change rather than an absolute change in level. To obtain a reference level, two resistors are connected to input REF, one to VSS and the other to VDD. #### O OUTPUTS Each output pin labeled "O" corresponds to an input pin labeled "I." Whenever an input is selected, the output becomes active and will drive an external load toward supply voltage VBB. When outputs are not active, they are high impedance open drain. ## V<sub>BB</sub> SUPPLY The sources of all output devices are common and connected to pin $V_{BB}$ . This allows TTL compatibility as shown in Figure 1, as well as the ability to drive higher level signals. For instance, if $V_{SS} = 0$ volts, $V_{DD} = -16$ volts, and $V_{BB} = V_{SS}$ , then active outputs would drive a load connected to $V_{DD}$ towards $V_{SS}$ . The $V_{BB}$ pin can be used also to switch analog signals; in this configuration the analog signals are applied to the "O" pins and $V_{BB}$ is the output pin. ## M/T INPUT The M/T input pin selects the mode of switch operation, either momentary or toggle. With no connection to the M/T pin momentary operation is selected, and appropriate outputs are active only for the duration of touching a switch. In this mode, no output is active when no switch is touched. A $V_{\rm DD}$ #### SCI OUTPUT The SC1 output provides the clock signal for the Touch-Control panel. Its frequency is determined by the RC time con- #### MOMENTARY AND TOGGLE COMBINATION The S9261, S9264, and S9265 contain several outputs that are permanently in the momentary mode of operation. level applied to M/T causes the circuit to operate in the toggle mode. In this condition, the brief touch of any switch will turn on the appropriate output, which will remain latched on until the switch is touched again. Subsequent activations of the switch will toggle the corresponding output on and off alternately. To reset all outputs when the toggle mode is selected, a pulse of $V_{\rm SS}$ level may be applied to the M/T input. stant, and it is connected in common with one of each of the two common conductive surfaces on the reverse side of the touch panel. With the M/T input at V<sub>SS</sub> these parts function identically to the S9260 and S9263. With M/T at a logic 1 level, however, the S9261 has four momentary and three toggle inputs. Table 1 shows the combinations available on all three parts. TABLE 1. COMPARISON OF FEATURES | | | | Touch Switch Capacity | | | | |----------------|----|----|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------------------|--| | Part<br>Number | | | Touch Inputs Selectable For Either Momentary Or Toggle Operation Through Use of M/T Input | Touch Switch Inputs Fixed In Momentary Operation (Not affected by state of M/T input) | Number<br>of<br>Outputs | | | 89260 | 22 | 7 | 7 | 0 | 7 | | | <b>S</b> 9261 | 22 | 7 | 3<br>(14 thru 16) | 4<br>(10 thru I3) | 7 | | | S9263 | 40 | 16 | 16 | 0 . | 16 | | | S9264 | 40 | 16 | 8<br>(18 thru (15) | 8<br>(10 thru 17) | 16 | | | S9265 | 40 | 16 | 12<br>(14 thru (15) | 4<br>(10 thru 13) | 16 | | MULTIPLEXED TOUCHCONTROL INTERFACE SEPTEMBER 1976 BLOCK DIAGRAM - S9262 (14 SWITCHES) ## PIN/PACKAGE CONFIGURATION - 89262 BLOCK DIAGRAM - S9266 (32 SWITCHES) PIN/PACKAGE CONFIGURATION - S9266 #### **FEATURES** - Simplifies design of Touch-sensitive switches - Interfaces with up to 32 touch switches - Eliminates contact noise - Comparator sensing permits use with wide variety of touch switch configurations - Binary outputs provided - Outputs are TTL compatible - Permits design of totally isolated touch surfaces, facilitating UL approval #### GENERAL DESCRIPTION The S9262 and S9266 TouchControl interface circuits permit almost any control panel containing mechanical switches to be easily replaced by a flat-surface capacitive control panel providing superior styling, reliability, ease of cleaning, and safety. Connecting directly to a screened or etched pattern on the panel's reverse side, these MOS circuits provide outputs to drive a variety of logic systems from household appliances to industrial controls. All system functions are then selected by merely touching the flat conductive Touch-Control "switch" areas that have been deposited on the panel's front surface in practically any configuration desired. These circuits can operate up to 32 TouchControl switches, and their outputs are encoded for easy interfacing with microprocessors. For applications requiring an individual output for each TouchControl switch, refer to AMI's \$9260, \$9261, \$9263, \$9264 and \$9265. #### FUNCTIONAL DESCRIPTION Fabricated with P-channel ion implanted MOS/LSI technology, AMI TouchControl integrated circuits\* are designed to interface with a variety of touch panel switches and provide a high degree of flexibility in the selection of touch panel materials, layout of touch pad configurations, and design of switching functions. These parts are designed to address an array of TouchControl switches in either a 2 x 7 matrix (\$9262) or a 2 x 16 matrix (\$9266) to interface with a total of either 14 or 32 switches. The outputs are binary encoded for easy interfacing with microprocessors or TTL, CMOS or MOS logic. Both momentary and "push on — push off" (toggle) switching operations are available on AMI TouchControl circuits and are electrically selected by the logic fevel of the M/T input pin. To ensure reliable switch action, a built in delay is incorporated in all circuits requiring a minimum touch time for switch response. ## TYPICAL APPLICATIONS - Appliance Control Panels - Home Entertainment Systems - Power Tool Controls - Televisions - Automotive Controls - Telephones - Games - Fast Food Waterproof Keyboards - Moisture Proofing - Industrial Controllers - Computer Terminals - Keyboards - Instrumentation - 16 to 1 Multiplexers - Microprocessor Interface - Vending Machines - Cash Registers #### ABSOLUTE MAXIMUM RATINGS Voltage on any pin except EXT relative to VSS: + 0.3V to - 20V Operating temperature range: Storage temperature (Ambient) 0°C to + 70°C - 65°C to + 150°C Voltage on EXT pin relative to $V_{SS}$ : +0.3V to $\sim 27V$ <sup>\*</sup>For non-multiplexed TouchControl circuits see AMI S9260, S9261, S9263, S9264, S9265 #### S9262/S9266 MULTIPLEXED TOUCHCONTROL INTERFACE #### ELECTRICAL CHARACTERISTICS $(0^{\circ}C \le T_{A} \le 70^{\circ}C; V_{SS} = 0V; V_{DD} = -13.5V \text{ to } -18.0V \text{ unless otherwise specified.})$ | SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |----------------------------------------|-----------------------------------------------------|------------------------------------------|--------|--------------------------|---------|----------------------------------------------------------------------------------------------------| | V <sub>IL</sub> | Input logic 0 level all except "1" inputs. | + 0.3 | 0 | - 1.5 | Volts | Note: M/T and ENA inputs are internally pulled | | $V_{H1}$ | Input logic 1 level all except "I" inputs. | ~ 10.0 | - 12,0 | ~ 18.0 | Volts | up to V <sub>SS</sub> . | | f <sub>RC</sub> | Internal oscillator frequency measured at RC input. | 50 | | 100 | kHz | | | $T_{S}$ | Switch delay time | 65 | | 135 | msec | Frequency measured at | | T <sub>RST</sub> | Time to reset all latches using M/T input. | | 100 | 135 | msec | RC Input = 50 kHz. | | V <sub>OL</sub><br>V <sub>OH</sub> | Output low voltage. Output high voltage | V <sub>SS</sub> | | - 1.0<br>V <sub>DD</sub> | Volts | V <sub>BB</sub> = V <sub>SS</sub> ; 10K resistive load to V <sub>DD</sub> . | | $V_{\mathrm{OL}}$<br>$V_{\mathrm{OH}}$ | Output low voltage. Output high voltage | V <sub>SS</sub><br>V <sub>BB</sub> + 0.4 | | $V_{SS} = 0.5$ $V_{BB}$ | Volts | $V_{SS} = + 5V$ ; $V_{BB} = 0V$<br>$V_{DD} = -12V$ ; 2800 $\Omega$<br>resistive load to $V_{SS}$ . | | SC1, SC2 | Sean clock output. Output low voltage | V <sub>S\$</sub> | | - 1.5 | | Max. capacitive load-<br>ing ≤ 150 pF. | | I <sub>DD</sub> | Output high voltage. Supply Current | | 7.0 | V <sub>DD</sub><br>15.0 | i<br>ma | Outputs unconnected | #### OPERATION Device operation can be understood by referring to Figure 1, depicting a typical application of the S9266. Each of the 32 pairs of series capacitors labeled S1 – S32 is one touch switch located on a TouchControl panel constructed of glass, printed circuit board, epoxy, or other dielectric material. (For details on touch panel configuration and operation, see the TouchControl application note included in this APD.) In each capacitor pair, the two common plates represent the conductive area on the control panel surface that is to be touched. The other two plates are formed by two conductive surfaces parallel to the touched surface and located directly under it on the reverse side of the panel. Referring again to Figure 1, the S9266 generates a clock signal on output SC1 and a similar signal on output SC2. The SCI clock output is connected to the common conductors of 16 of the 32 touch switches; the SC2 clock connects to the remaining 16 switches. For each touch switch the clock signal passes through the two series capacitors and is detected in the MOS circuit. When a panel switch surface is touched, the signal level into the chip diminishes, and the on-chip differential amplifier senses the change and performs the appropriate switching function. #### LINPUTS Inputs from the touch switch pads to the TouchControl circuit are labeled 10 through 115 (S9266), or 10 through 16 (S9262). The I inputs in conjunction with SC1 and SC2 outputs form a touch switch matrix of $2 \times 16$ or $2 \times 7$ , respectively. In both these parts the outputs are binary coded and will be described later. #### RC INPUT A resistor connected to $V_{DD}$ and a capacitor connected to $V_{SS}$ are connected to the RC input pin to establish the on-chip clock frequency that controls the rate of multiplexing and the touch switch delay time. Nominal values for these components are suggested in Figure 1, but they may be varied to change clock frequency over a range of $50 \mathrm{kHz}$ to $100 \mathrm{kHz}$ . #### REF INPUT In order to allow flexibility in the choice of TouchControl panel materials, switch layout, and switch size, AMI Touch-Control inputs have been designed to detect a differential change rather than an absolute change in level. To obtain a reference level, two resistors are connected to input REF, one connected to input REF, one connected to input REF, one connected to VDD. ## VBB SUPPLY The sources of all output devices (both "O" and "B" outputs) are common and connected to pin $V_{BB}$ . This allows TTL compatibility as shown in Figure 1, as well as the ability to drive higher level signals. For instance, if $V_{SS}=0$ volts, $V_{DD}=-16$ volts, and $V_{BB}=V_{SS}$ , then active outputs would drive a load connected to $V_{DD}$ towards $V_{SS}$ . #### M/T INPUT The M/T input pin selects the mode of switch operation, either momentary or toggle. Applying $V_{SS}$ to the M/T pin selects momentary operation in which appropriate outputs are active only for the duration of touching a switch. In this mode, no output is active when no switch is touched. A $V_{DD}$ level applied to M/T causes the circuit to operate in the toggle mode for "push-on, push-off" operation. Subsequent activation of the switch will toggle the corresponding output on and off alternately. It should be noted that each input should be cleared to the off state before selecting a new input to obtain meaningful data from the binary outputs. To reset all outputs when the toggle mode is selected, a pulse of V<sub>SS</sub> level may be applied to the M/T input. #### SC1 and SC2 OUTPUTS The S9262 and S9266 have multiplexed inputs, using $2 \times 7$ and $2 \times 16$ matrices, respectively, to provide 14 and 32 input states. Clock signals SC1 and SC2 are used along with the "I" inputs to form these matrices as connected in the schematic of Figure 1. #### O OUTPUTS Each output pin labeled "O" corresponds to an input pin labeled "T". Whenever an input is selected, the output becomes active and will drive an external load toward supply voltage $V_{BB}$ . This is true for momentary operation only; toggle operation is described in the section labeled "MT input." When "O" outputs are not active, they are high impedance open drain. #### B AND AK OUTPUTS The S9262 has four and the S9266 has five outputs labeled "B." These supply a binary code relating to the state of the inputs. Fourteen unique states are available on S9262 and thirty-two on S9266. The output configuration is identical to the "O" outputs. An extra output labeled AK is available on the S9266 and is active whenever any key is selected. #### **ENA INPUT** Available on the S9266, the ENA input allows the outputs to be bussed and may be gated off by application of a logic 1 level. VSS applied to the input enables all five outputs and AK. #### **EXT** The EXT pin is used in the output circuitry and should be connected to $V_{DD}$ . | SCAN<br>DUTPUT | TOUGHED<br>INPUT | #B | | TPU<br>22 | | 7071 | 00 TPUT: | <u>s</u> | |----------------|------------------|-----|-----|-----------|-----|------|----------|----------| | 501 | IO | 3 | 0 | 0 | ę. | 1 | 3 | | | SCI | i | 1 | U | Ö | ć | a | i | | | 50.1 | 12 | ú | 1 | 0 | 6 | ú | 3 | | | SCF | ı.J | 1 | - 1 | U | 6 | п | П | | | SCI | -4 | - 0 | 0 | 1 | Ċ | Ü | Ü | | | SCI | g | 1 | 0 | 1 | C | ě. | 0 | | | SCI | 6 | 0 | - 1 | - 1 | C | á | i | | | \$62 | 10 | 1 | - 1 | - 1 | C | ō | Ü | | | 202 | - 11 | 0 | 0 | 0 | 1 | 0 | ū | | | SC? | , | 1 | 0 | u | 1 | Ð | 3 | | | 3C2 | - 13 | ó | - i | ō | i | ō | ī | | | 3C7 | 14 | i | - 1 | à | | ō | 5 | | | SEZ | 15 | Ü | Ü | ī | | ŏ | ă | | | SEZ | 16 | 1 | Ġ | - 1 | i | ó | ā | | | | None | t | 1 | - i | i i | ē | ō | | TABLE 1. OUTPUT ENCODING $(V_{BB} = 0 \text{ VOLTS})$ | SCAN<br>OUTPUT | TOUCHED<br>INPUT | ea | | 0. <u>21</u> 2 | | | bo | ונו | 10114<br>02 | 0.9 <b>T</b> I | PUTS<br>Dia | 05 | 06 | AK<br>OUTPUT | |----------------|------------------|-----|-----|----------------|-----|-----|------|-----|-------------|----------------|-------------|-----|-----|--------------| | | | | | | _ | | | | | | | | | | | 501 | 141 | D | D | 0 | 0 | 0 | 1 | u | 3 | 0 | 0 | 0 | 3 | | | SCI | - 11 | | 0 | - 3 | 0 | ti | 0 | - 1 | 0 | n | 0 | 0 | 3 | | | SCI | 12 | 0 | | J | lı | П | ū | n | | а | ø | Œ | J | | | SGI | 13 | | | - 3 | Ш | q | 0 | Ш | 0 | - 1 | Ш | ľ | ) | i | | 901 | 14 | П | 0 | 1 | ľ | П | 0 | U | 0 | II | - 1 | U | 3 | - 1 | | SCI | 15 | - 1 | 0 | - 1 | n | 0 | 0 | n | 0 | D | 0 | | J | 1 | | SCI | 16 | b | | - 1 | D | ۵ | 0 | 0 | 0 | U | 3 | 0 | - 1 | 1 | | 550 | 12 | | 7 | - 1 | li | 7 | Ш | 3 | Ш | û | Ĺ | U | Ш | - 1 | | 901 | 18 | c | ) | a | | ) | Į. | :1 | ľ | a a | Ü | 0 | 9 | 1 | | 501 | ië. | | | - 7 | | ) | li | п | 0 | 3 | I. | 0 | 0 | - 1 | | SC. | 120 | 0 | | - 0 | | - 0 | 9 | ŋ | C | O. | C | 0 | 3 | - 1 | | 501 | 111 | | | 2 | | 6 | 3 | 0 | U | 0 | C | 0 | ) | - 1 | | SC( | 112 | 0 | 9 | - 1 | | J | 0 | n | į) | Ц | U | Ú | 3 | - 1 | | SCI | 113 | | 0 | - 1 | | 0 | 3 | Ш | Ð | 1 | U | D | J | 1 | | SC: | 114 | 0 | - 1 | - 1 | 1 | 3 | n | 0 | U | G | C. | - 0 | ıl | | | 501 | 115 | - 1 | i i | - 1 | | 2 | 0 | q | 0 | 0 | C | 0 | U | - 1 | | 502 | 10 | 0 | J | II | 0 | - 1 | Ш | 0 | 0 | u | E | 0 | 0 | | | SC2 | 1 | , | 0 | II | D | - 1 | U | - 1 | U | 0 | i, | U | Ш | 1 | | 202 | 17 | - 0 | 1 | II. | C | 1 | li . | ıı | 0 | П | - 0 | ú | Ш | - 1 | | 802 | 13 | | - 1 | 0 | Q. | - 1 | 0 | 0 | ü | П | C | 0 | II | 1 | | 5 C 2 | 14 | 0 | U | - 1 | - 0 | - 1 | 0 | - ) | 6 | ) | 0 | 0 | | | | AC2 | 15 | - 1 | 0 | - 1 | ú | - 1 | D | - 2 | ı, | ) | 0 | a | C | | | 507 | 16 | 0 | | - 1 | 0 | - 1 | 17 | - 0 | U | 9 | 0 | 0 | e. | - | | 502 | 17 | 1 | - 1 | | 0 | - 1 | 0 | Q. | U | -) | 0 | 0 | Ľ | | | SEZ | .3 | 9 | J | Ш | - | - 1 | п | 0 | 0 | 0 | 0 | 0 | Ç | | | 800 | 19 | - 1 | 3 | U | - 1 | - 1 | 0 | 0 | 0 | C | 0 | ú | ù | | | 307 | 110 | 0 | - 1 | ıl | - 1 | - 1 | U | ų. | U | u | C | 0 | U | | | 502 | 116 | - 1 | : | C | | - 1 | ŋ | 3 | D. | | 9 | U | 0 | 1 | | 505 | 172 | 0 | U | 1 | | | 0 | 3 | 0 | 3 | 0 | 0 | C | 1 | | 902 | 113 | - 1 | U | | - 1 | - 1 | U | ١. | D | 3 | U | U | C | 1 | | 502 | 114 | n | - 1 | 1 | i | - 1 | 0 | 0 | 0 | - 0 | 9 | 뷥 | l, | | | 5.12 | 165 | - 1 | - 1 | • | - 1 | - 1 | 0 | 3 | 0 | - 1 | 3 | U | C | 1 | | | 3000 | | - 1 | | - 1 | - 1 | Ö | Ö | ō | 9 | ō | ä | r. | 0 | #### TOUCHCONTROL APPLICATION NOTES ## PANEL CONSTRUCTION A TouchControl switch panel consists of a single sheet of a rigid material with conductive surfaces applied on both sides as shown in Figure 3. A number of materials may be used for touch panels, the selection of the material most suited for a particular application being dependent on such things as durability, appearance, ease of assembly, cost, and dielectric constant of the material. Regardless of the selected panel material, a touch switch is formed by applying a single conductive surface to its front surface with two other conductive surfaces applied directly in line on the reverse side of the panel. Figure 3 shows three views of a typical touch panel containing two TouchControl switches. On switch one, conductive surface A is applied to the front of the panel and is the surface to be touched to effect a switch closure. Surfaces B and C are applied directly in line with A on the opposite side of the panel. A should cover completely and may overlap surfaces B and C. The application of the conductive surfaces depends on selection of the panel materials. If glass is used, for example, it is common to apply a coating of tin oxide, which is then fired on for durability; rear surface conductors may be screened on with a conductive ink. Touch panels may be made more simply from double-sided printed circuit boards in which the conductive TouchControl surfaces are created by standard etching. For breadboarding purposes, a number of conductive tapes and paints are available and may be applied to a variety of touch panel materials. #### ELECTRICAL OPERATION The three conductive surfaces in a TouchControl switch combine to form two capacitors connected in series, as shown in the schematic diagram of Figure 3. An AC signal generated in the MOS circuit is applied to the rear conductive surface labeled C. This signal is coupled through to surface A by the capacitor formed by C and A. The signal is then coupled to surface B by the capacitor formed by A and B and applied to one of the inputs of the MOS circuit, which detects the signal's presence. When surface A is touched, the amplitude of the signal is significantly decreased because of body capacitance. This is sensed by the MOS circuit, and the appropriate switching function is performed. #### TOUCH SWITCH LAYOUT GUIDELINES AMI TouchControl circuits have been designed to interface with a variety of touch switch configurations. However, there are several guidelines that must be observed to insure a satisfactory TouchControl system. The size of a TouchControl switch is dependent on the amount of capacitance needed to couple the clock signal to the "I" inputs of the MOS circuits. Because the input capacitance associated with the circuit input is typically five picofarads, it is advisable that each of the two series capacitors formed by the three conductive TouchControl panel surfaces be no less than seven picofarads. Since the capacitance in picofarads can be calculated by $C = 0.22 \le A + d$ , where $\le$ is the dielectric constant, A is area, and d is the material's thickness, it is apparent that minimum switch size is dependent on the thickness and dielectric constant of the panel material. If, for example, the panel is made from 1/8" thick glass with a dielectric constant of 8, then the minimum area of each of the two rear surface conductors is 0.5 sq. inches. Since the touch surface must cover the entire area of the two rear conductors, it must, then, be at least 1.0 sq. inch. It is desirable to separate the two rear-surface conductors by at least Q.125 inches, so the touch surface would be somewhat larger than 1.0 sq. inch. Higher capacitance, and thus smaller touch switches, can be obtained by using epoxy printed circuit material; though the dielectric constant is lower (around 5.0) the thickness can be decreased substantially. #### CIRCUIT TO PANEL CONNECTIONS There are a number of ways to make the necessary connections between TouchControl circuits and panels. A simple approach is to use a printed circuit board for the touch panel. In this case, the connections to the circuit are made by the etched copper pattern. In laying out a printed circuit, it is important to keep the copper traces running to the individual touch pads separated from each other as much as possible. In most instances a minimum spacing of 0.125" between traces is acceptable, though wider spacing might be necessary in cases where traces will run parallel to each other for distances of over six inches. It is also important to keep the clock output (SC1) at least 0.75 inches away from any input trace. These spacing requirements are guidelines to be followed regardless of the touch panel material. With glass touch panels, a simple method for bread-boarding systems is to fasten individual wires onto the conductive surfaces with a conductive epoxy. For production situations, it is possible to locate the electronic circuitry on a separate printed circuit board. Contact to the glass touch panel can be made through spring contacts mounted in the appropriate locations on the circuit board. An alternate approach is to route the traces on the glass to an edge of the glass, making connection through an edge connector, keeping in mind the spacing requirements between traces. # ENCODER/DECODER REMOTE-CONTROL 2-CHIP SET #### **Features** ## ☐ Lower System Costs - RC oscillator used on encoder (no crystal required) - Phase-locked-loop on decoder (no crystal required) - Single binary inputs allow inexpensive switches on pc board jumpers ## ☐ Flexibility of Application - 512 user selectable address codes - Decoder signal valid output - Externally selectable one-shot tailors message reception - User has choice of transmission media: infrared, ultrasonic, RF, or hardware - Eight ROM programmable preamble codes - Encoder operates on a single 9V battery ## ☐ Reliable System Operation - Frequency shift keying scheme means low reception error - PLL allows frequency variation $\pm 15\%$ between encoder and decoder - One-shot period allows adjustment for system noise - Triple message redundancy required - Preamble adds to message security - High noise immunity #### **General Description** #### Encoder/Decoder This two chip PMOS set includes a user programmable serial data encoder for use in a simple low power transmitter and a serial data decoder for use in a user addressable receiver. The user can select the transmission medium (RF, infrared ultrasonic, or hard wired). The externally selectable message allows up to 512 codes or addresses; this is done with the nine binary inputs on each device. An additional 3 bits of address can be programmed on chip as a fixed preamble. The serial data encoder encodes by means of a frequency-shift-keyed trinary data pattern composed of 16 data bits. Each data bit will have a length equivalent to 32 cycles of high frequency clock (20kHz typical). Each trinary data pattern will be 512 cycles of 1/2 the oscillator frequency length. The encoder frequency oscillator reference is controlled with an external RC network. The encoder transmitter can be powered by a single 9 volt battery so that a single momentary push button will activate the encoder and transmitter. In the off position there is no current flow. The serial data decoder in conjunction with a receiver amplifier decodes the transmitted 16 bit coded signal. The on-chip phase-locked-loop locks in on the 20kHz signal even if the transmitted frequency differs from the receiver by up to $\pm 15\%$ . The coded signal input is # S2743 Serial Data Encoder Block Diagram and Pin Configuration # \$2742 Serial Data Decoder Block Diagram and Pin Configuration compared with the externally selected code. The serial decoder looks at the transmitted signal a minimum of three times before validating a good message. A 3 bit "good" code counter or a 3 bit "bad" code counter accumulates the number of successive good and bad codes being received. The decoder has an on-chip one-shot which is user programmed by an external RC combination. Whenever three complete good codes are received in the "good" counter a signal enables the one-shot which controls the signal valid output. If a series of three sequencial bad codes enter the "bad" code counter the "bad" counter resets the "good" code counter and one-shot period and will not allow an active output until the end of the one-shot period. Any "good" code resets the "bad" code counter. If the "good" counter has accumulated three good codes and activated the output one-shot, any occasional "good" code (occurring within the one-shot period) will maintain the output by retriggering the one-shot. The output appears like a single switch, on when "good" codes are received, off when not, with the minimum total period being determined by twice the one-shot period. The one-shot can be used to prevent the output from switching on and off too rapidly due to system noise. The typical RC components shown in the block diagram give a period of about one half second. ## **Applications** ## Paired Operation - Entry access systems - Identity verification - Remote car starting and location - Telephone dial-in coded access - Remote control of equipment, toys, etc. ## ☐ Multiple Pairs - Intercom systems - Multiple station communication - Traffic control ## ■ Multiple Encoders - Security systems - Alarm/monitor/intrusion systems - Travel/traffic monitors, rally car identification - Safety beacons/portable alarms ## ☐ Multiple Decoders - Paging systems - Car/people/animal locator systems - Remote control of house appliances ## **Functional Description** #### Serial Data Encoder The AMI serial data encoder is comprised of three sections: Oscillator, Programming Logic, and Control Logic. Specifically it will provide logical ones "1," logical zeroes "0," and synchronization pulses "8" and arrange them into a trinary data pattern composed of 16 data bits. Each data bit will be 32 cycles of the high frequency (HF-1/2 Oscillator Frequency) in length. Each trinary data pattern will be 512 cycles of 1/2 the Oscillator Frequency length. A logical "1" is represented by 32 cycles of the high frequency. A logical "0" is represented by 16 cycles of the high frequency followed directly by 8 cycles of the low frequency (LF $\pm$ 1/2 HF). A synchronization pulse "S" is represented by 16 cycles of the low frequency. A 16-bit data pattern will be encoded in the device in such a manner as to have (3) bits programmed internally and (9) bits programmed externally. The Oscillator Frequency equals twice that of the High Frequency, and the High Frequency equals twice that of the Low Frequency. The Oscillator circuit will require a maximum of (3) external components (Refer to page 2 Figure 1). External programming inputs connected to the device $-V_{\rm DD}$ supply will be considered as a logical "1." The bit programming current will not exceed $50\mu a$ . The programming resistance should not exceed $1k\Omega$ . Unconnected external bit programming inputs will be considered at a logical "0." A "1" (-5 volts $\leq$ "1" $\leq$ $-V_{DD}$ ) presented to the "Test" input sets the Internal counter and maintains the output of the device "On." The input impedance of the test input is greater than $5M\Omega$ . For portable operation a 9V transistor battery can be used for the DC voltage supply. Proper circuit polarity must be observed ( $-V_{DD}$ , $+V_{SS}$ ). ## External Oscillator Components The Astable Multivibrator Circuit employed here required three (3) external components. $R_1$ aids in keeping the operating frequency independent of variators in supply voltage, $R_2$ and $C_1$ form the RC time constant which controls the oscillator frequency. In this case $R_1$ will be specified at $270 \mathrm{k}\Omega$ regardless of the oscillator operating frequency. Typically it will be found that $R_1 \geq 2T_2$ . $R_2$ should not be greater than $80 \mathrm{k}\Omega$ ; $C_1$ should not be less than $100 \mathrm{pF}$ . A method for determining the approximate value of $R_2$ and $C_1$ is: Start with the approximate formula for oscillator frequency osc, freq $$\approx \frac{1}{2\pi RC}$$ It must be noted that the oscillator frequency must be set at twice the desired device high frequency value. Using a set value of R or C and a known desires oscillator frequencies: Solve for C w/osc, freq. w/osc. freq. = 30kHz $R = 60k\Omega$ $$C\frac{1}{2\pi Rf} \approx \frac{1}{2(60 X 10^3) (30 X 10^3)} \approx 2.77 \ X \ 10^{-10} \ 277 pFd$$ Solve for R 2/osc. freq. = 30kHz C = 500 pF $$R \; \frac{1}{2cf} \approx \frac{1}{2(500 X 10^{-12}) \; (30 X 10^3)} \approx \; 3.33 \; X \; 10^4 \; 33 k \Omega$$ ## **Absolute Maximum Ratings** | DC Supply Voltage | |-------------------------------------------| | Input Voltage | | Operating Temperature Range | | Storage Temperature Range 65°C to + 150°C | | Lead Temperature (During Soldering) | ## Electrical Characteristics (25°C Air Temperature Unless Otherwise Specified) | Symbol | Parameter | Min. | Typ. | Max. | Units | Conditions | |--------|----------------------------------|----------|--------|--------------------|---------|------------------------------------------| | | Operating Supply Voltage | - 6.65 | - 9.5 | - 15 | v | $V_{\mathrm{DD}}$ | | | Operating Power Dissipation | | 27 | 40 | mW | - 8V, - 5mA | | | Operating Frequency | 2 | 20 | 60 | kHz | Oscillator | | | Frequency Stability | | | | | Refer to Page Graphs | | | Programming Bits 1-9, Current | | | 50 | $\mu$ A | Programming Input, R≤1kΩ | | | External Programming Resistance | | | 1 | kΩ | Bits 1-9 | | | (DC) Bit 1-9 Program Logical "1" | - 5 | - 6.05 | - V <sub>DD</sub> | v | | | | Input Levels Logical "0" | | - 0.4 | | v | | | | Bit 1-9 Current | | 55 | | μA | Input R 9V≥1.5M @ 5V | | | Test and R + C Input Impedance | 5 | | 75 | MΩ | Input Resistance 5MΩ | | | (DC) Test Input Levels Test On | - 5 | | $-V_{\mathrm{DD}}$ | V | Maintains Output Device On | | | (See Note 1) Test Off | $v_{ss}$ | | <b>–</b> 1 | V | Permits Normal Operation | | | R, C Resistance Logical "1" | | 12 | | kΩ | Resistance to V <sub>DD</sub> , ± 20% | | | Logical "0" | | 3 | | kΩ | Resistance to $V_{SS}$ , $\pm 20\%-30\%$ | | | Output Current (See Note 2) | 5 | | | mА | Output Voltage =8V | | | | | | | | $w/V_{DD} = 7V$ | #### NOTES: 1) Effect Noted at Pin 15 to $V_{\rm SS}$ 2) Output Voltage Pin 15 to $V_{\rm SS}$ All Voltages Measured with Respect to VSS #### General Description ## Serial Data Decoder The AMI serial data decoder is comprised of four sections: Phase locked loop (PLL), 16-bit digital decoder, Good/Bad code logic and the Retriggerable output one-shot. The decoder is always on and the phase locked loop is running. A small external capacitor determines the center frequency while an external low pass filter smooths out and generates the VCO control voltage. The typical center frequency of the PLL is 20kHz allowing the received signal to be slightly off frequency and the PLL will still "lock in." The 16-bit trinary data pattern includes: - 3 "1" bits (fixed) 32 cycles of 20kHz each - 1 Sync bit 16 cycles at 10kHz - 3 Mask programmable bits either "1" or "0" - 9 User selectable bits externally programmed The PLL locks on the "1" bits present in the data pattern. Once locked the PLL generates a clock which controls the digital decoder section (DDS). The DDS waits for a sync bit and then compares the incoming data pattern bits, one by one, to make sure all the bits are correct; fixed ones are ones, mask programmable bits match and finally is the user selectable 9-bit pattern correct. | Bit position | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | |--------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----| | Data Pattern | I | I | M | M | M | U | Ū | U | U | U | U | U | U | U | I | S | I = FIXED "1" (32 Cycles at 20kHz) U = USER SELECTABLE BITS S = SYNC BIT (16 cycles at 10kHz) M = MASK PROGRAMMABLE BITS 1 Time for one Pattern = 16 X 32 X $\frac{1}{20 \text{kHz}} \approx 25 \text{ms}$ If the pattern was correct a good count (GC) is stored in a "Good Pattern Counter" (GPC). If the pattern match did not occur a bad count (BC) is stored in a "Bad Pattern Counter" (BPC). - 1. Any GC resets the BPC. - 2. 3 BC's in a row will reset the GPC. - When the GPC reaches 4 the one-shot is triggered and an output will occur, i.e., 3 good codes completed. - Any one GC after an output, occurring within the one-shot time will retrigger the one-shot and maintain the output on. The retriggerable one-shot stabilizes the systems operations by introducing hysterisis. - 1. It takes more good pattern counts to turn the output on than to maintain it on. - After the output goes off, it will stay off for the one-shot period regardless of any good patterns being received. An external RC is used to control the one-shot period. ## **Absolute Maximum Ratings** | DC Supply | – 20V | |------------------------------------------|-------------------| | Input VoltageOperating Temperature Range | O°C to + 70°C | | Storage Temperature Range | 65°C to $+150$ °C | | Lead Temperature (During Soldering) | maximum 10 sec | ## Electrical Characteristics (25°C Air Temperature Unless Otherwise Specified) | Symbol | Parameter | Min. | Тур. | Max. | Units | Condition | |--------|---------------------------------------|-------|------|-------|-------------------|----------------------| | | Operating Supply Voltage | - 15V | | - 20V | V | $V_{\mathrm{DD}}$ | | | Operating Power Dissipation | | | 200 | mW | | | | Operating Frequency | 2 | 20 | 75 | kHz | Oscillator | | | Operating Current Static | | | - 10 | μA | No signal, no bit | | | Programming Bits 1-9 Current | | | | μA | Program input, R≤1kΩ | | | (DC) Bit 1-9 Program Logical "1" | | | - 20 | V V | | | | Input Levels Logical "0" | | | 0 | v | | | | Bit 1-9 Current | | | | $\mu$ A | | | | VCO Input Voltage | 1 | ] | ! | v | | | | VCO Input Current | | | | μA | | | | Output Voltage | | - 1 | | V | | | | Output Current (VOUT = -1V) | | 10 | | mA | | | | Signal Input, AC Coupled | 0.025 | 0.05 | 1.0 | $V_{apk\cdot pk}$ | | | | Input Impedance, AC Coupled Amplifier | | 20 | | kΩ | | | | Phase Output Voltage | | | | μΑ | | | | Phase Output Current | | | | μΑ | | | | R.C. Onc-Shot Voltage | | | | V | | | | R.C. One-Shot Current | | | | μA | | # **Application Notes** # Application Note ## Musical Application for an S2000 Microcomputer #### Introduction AMI's \$2000 is a complete single-chip computer ideal for a wide range of applications. The S2000 contains an on-chip 1024 byte instruction ROM, a 256 bit scratchpad RAM, an arithmetic logic unit, and a versatile input/output configuration capable of such tasks as driving displays and interfacing with TouchControl keyboards. Although the circuit is well-suited for use in such end-products as interval timers, appliance timers, and various process controllers, there are other seemingly unrelated applications in which the S2000 also excells. One of these is the generation of musical frequencies and the storage of tunes. This application note describes the capabilities of an S2000 programmed to generate any one of 60 musical frequencies and play on command any one of twelve preprogrammed tunes. ## **General Description** In typical usage, a mechanical selector switch would be used to tell the processor which song it is to play. Then, when the start switch is touched, the song will be played through to its end. It will then wait for the start switch to be touched again before replaying the song. The S2000 has the ability to generate five octaves of musical frequencies and can play notes of 16 different lengths. Musical rests [times during which no note is heard] are also obtainable. At any time, four octaves of frequencies are available, making possible the generation of complex waveforms [i.e., sawtooth and pulse]. A typical application of this product would be a musical doorbell capable of playing any one of a number of owner-selected tunes whenever the doorbell switch was touched. Other applications might include electronic games, alarm clocks, and telephones. #### TouchControl Start Switch To begin the playing of any tune, the start switch is touched. Although this switch may be a mechanical button, as found on conventional doorbells, the TouchControl capability of the S2000 allows for this to be a non-moving capacitive touch switch. As soon as this switch is touched, the tune will start playing until it reaches its end, at which time the processor waits for the switch to be touched again. ## Number and Length of Tunes Available In the present configuration, twelve tunes can be played by this \$2000. These tunes are programmed into the device during manufacture and can each be selected by switching either of two "A" outputs to one of six "K" and "I" inputs. Whichever of the twelve tunes has been pre-selected by a mechanical switch, that tune will play when the start switch is touched. The length of the tunes is dependent on several factors. There are 625 words in memory in which to store the notes of the twelve tunes. Since each note requires only a single word of memory, the S2000 is capable of playing up to 625 notes, or an average of 52 notes per tune. Some tunes may be longer than others; for example if one tune is only ten notes long, this leaves 94 notes for another tune. The exception to the 625 note storage capability comes from the fact that all notes are not of the same duration nor in the same musical octave. Each new note in a tune that is either in a different octave from or is a different length from its preceding note will require four words instead of one. Any note that changes both octave and length requires five words. In the unlikely event that all notes change octave and length, then all notes would require five words each, and a total of 125 notes [10 notes per tune] would be available. In a typical set of tunes, lengths and octaves of notes would most likely not change that often, so it should be possible to obtain 25 notes per song. In other versions of this application, it would be possible to obtain more tunes by using additional "A" outputs with the "I" inputs. Either 24 or 48 tunes could be stored, however the tunes would have to be proportionately shorter. ## Generation of Frequencies The S2000 is capable of generating all twelve notes of the tempered scale over a five octave range, a total of 60 frequencies. The highest note is C at 1047Hz and the lowest is C sharp at 34.6Hz. The relative tuning accuracy of the frequencies is fixed so that if the RC components used for the S2000 oscillator shift, the notes will still sound in tune with each other. If the S2000 is operating at 1MHz, the frequencies are accurate to $\pm$ 0.26%, or about $\pm$ 4.3 cents absolute. Each frequency in a tune is played for a given duration and this is programmable in 16 steps. That is, each note may be programmed to any one of 16 different lengths from length x to length 16x. The actual length of x is dependent on the tempo control, as mentioned below. ## Outputs The eight "D" lines are all used to supply musical outputs. Outputs D0 through D3 provide four octaves of tones, each a squarewave of 50 percent duty factor. The highest octave appears at D0, with the lowest at D3. Although in many applications, only a single output would be listened to, it is possible to add several outputs to create more complex waveforms having higher harmonic content, such as the sawtooth waveform of Figure 3. The remaining four "D" lines, D4 through D7, are identical to D0 through D3 except that they are 180° out of phase. This allows the S2000 to drive a speaker without the use of an amplifier. The technique is illustrated in Figure 1, where D0 and D4 are used as push-pull outputs connected to an impedance matching transformer to drive an 8 ohm speaker. ## **Tempo Adjustment** The speed of the tune, or tempo, can be controlled by the frequency of the external oscillator that is fed to the I8 input. If the tempo oscillator frequency is 600Hz, for example, then the shortest notes would be 0.1 second and the longest would be 1.6 seconds. Depending on the programmed note lengths, as mentioned above, with a 600Hz tempo oscillator, the length of the notes can be from 0.1 second to 1.6 seconds in 0.1 second intervals. If the tempo oscillator frequency is changed, the tempo of the tune changes accordingly, keeping the timing relationships among all notes intact. ## General Description of Logic An overview of the logical operations of this music processor is shown in the flow chart of Appendix A. Because the heart of the logic is the note subroutine, during which the musical frequencies are generated, this is presented as a separate flow diagram in Appendix B. Appendix C lists the entire source program minus all but one of the twelve tunes [only one tune listing is necessary to describe the tune logic]. Referring now to Appendix A, when power is first applied to the unit, the start switch continuously checks for a touched condition [if TouchControl is used] or for a switch depression [for a mechanical switch]. As soon as the switch is touched, the $A_0$ and $A_5$ outputs are used to scan the K1, K2, K4, I1, I2, and I4 inputs to determine which of the 12 tunes has been selected. This causes the program counter to jump to the location in ROM that stores the desired tune. At the beginning of each tune, the octave and duration of the tune's first note are stored from ROM into specific RAM locations. Next, a "note code", relating to the period of the note to be played, is stored in RAM. The note subroutine is then entered, in which the D lines are switched on and off at a rate corresponding to the desired frequency, as determined by the octave and "note code" previously stored in RAM. During each half period of the musical frequency the note subroutine checks information from the 18 timer input and the desired note length [previously stored in RAM] to determine if the end of the note has been reached. If so, the note subroutine returns the program counter to that location in ROM where the next note of the tune is stored. If the tune is over, the program counter returns to "start" and the start switch is scanned continuously until it is touched, causing the tune to be played again. ## **TouchControl Logic** The S2000 has the capability of interfacing with one or a number of capacitive TouchControl switches. However, only a single start switch is required for this musical application, and this switch may be either TouchControl or mechanical. Although the TouchControl type is discussed here, a mechanical momentary switch with normally closed contacts could be substituted for the two series capacitors of the TouchControl version. The TouchControl switch consists of two capacitors connected in series between the A4 output [pin 16] and the K8 input [pin 33]. Referring to Figure 1, when the switch is to be interrogated, a pulse is sent out the A4 output to one of the capacitors. Under normal conditions, the pulse is transmitted through the two capacitors to the K8 input. If the pulse appears at the K8 input, then the processor assumes the switch is not touched and does not go on to play a tune, but continues to send pulses from A4 to the switch. Touching the common connection between the two capacitors is the equivalent of loading this junction with a relatively large capacitance to ground. Under this condition, when a pulse is sent from the A4 output, it is attenuated at the K8 input, and the processor assumes the switch is touched and commences to play the tune. The area to be touched to start the tune is the junction between the two capacitors. These capacitors may be either discrete components or they may be formed by conductive areas on a rigid dielectric material. Reference may be made to AMI's Application Note, "TouchControl Circuits for Capacitance Switching," for a discussion on the construction of these switches. For conditions where stray capacitance loading is minimal, 25pF capacitors should be sufficient to operate the TouchControl system. The resistors in series with K8 and A4 and the two diodes on A4 are included for added protection against damage caused by static discharge. Referring to Appendix C, the source coded for the TouchControl begins at the label "Start", location 5. In structions in locations 5, 6, 7, and B force A4 to a logic 0 level. [Locations 8, 9, and A are used for an AK output and are not a part of TouchControl.] Location E removes the internal discharge device from the K8 input, and C, D, F, and 10 drive the A4 line high. Location 12 tests the K8 input, which, if high, will cause the program to jump back to "Start". If the K8 input is low, indicating a touched switch, the SZK instruction at location 12 causes a jump to location 14, where A4 is reset to a low level, and the scanning of the K1, K2, K4, I1, I2, and I4 inputs begins to determine which tune is to be played. ## Selector Switch Scanning Logic Tune selection is accomplished by the two mechanical switches of Figure 1. For each position of switch 1 there are six tunes that can be selected by switch 2. The source code controlling this selection process begins at label "Play", location 15, and ends at location 35. During the first scan of K1, K2, K4, I1, I2, and I4, the A0 output is high. If no K or I input is found to be at a logic 1, the A5 output is set high and a second scan of the K1 through I4 inputs begins. Flag 1 is set for the first scan and reset for the second scan; this flag is used later to cause the program counter to jump to either the first or second set of six tunes in the tune memory. ## **Tune Memory** The twelve tunes are stored in ROM from locations E4 through 3BF. In Appendix C, only the first tune [label TUN1] is shown, a typical example of how tunes would be coded. Suppose the scanning logic has caused the program counter to jump to "TUN1". At location E4, flag 1 is tested to determine if the jump was taken during the first or second scan of K1 through I4. If the jump was taken in the second scan, this means the selector switch SW1 was in the A5 position, flag 1 is reset, and the program counter would jump to "TUN7". If SW1 was in the A0 position, flag 1 will be set, the jump to "TUN7" will not be taken, and tune 1 will play. Assuming tune 1 is selected, locations E7 through EB store the octave and length of the first note in designated RAM locations. The octave code and length code information is shown at the start of the source listing in Appendix C. The first "note" in the tune is a reset, or a time during which no note is heard. This is done to synchronize the start of the tune with information from the I8 input and "sec FF", which determine the tempo [speed] of the tune. The "Rest" subroutine has the same effect as any of the C, D, etc. subroutines, except that during a rest "note", no D output states are changed. This causes no note, or frequency, to be heard during a rest. The first actual note to be played in TUN1 is a C in octave 2 foctave code 1], the second highest octave of musical frequencies. Its length code is 13, resulting in a length of 0.18 seconds when a frequency of 1KHz is applied to the I8 input. Subroutine "C" is located on page 15 of the ROM, as are all twelve note letter subroutines, and the subroutines, "Rest" and "Note". This was done to allow for the smallest possible tune memory. [If the note subroutines were not located on page 15, a "PP" instruction would have to appear before each note in the tune memory, almost doubling the required memory length.] The "C" subroutine begins with a jump statement to location "FC", because all note letter subroutines [FC, FCS, FD, etc.] would not fit on page 15. Likewise, all other note letter subroutines start with a jump statement to "F\_". The "C" subroutine loads a unique note code, comprising 3 words into three RAM locations. This note code, when used in a timer in the note subroutine causes the output frequencies to be C frequencies. After loading these codes into RAM, a jump is made to the "Note" subroutine, during which a C note in octave 2 is generated for the duration of the first note. On return from the note subroutine, the program counter is returned to the tune memory to look for the next note in the tune. Still following tune 1, after the first note, "C", has been played, the instructions in locations EE, EF, F0 cause the octave to change from octave 2 [octave code 1] to octave 1 [octave code 0], or the highest octave. The next note to be played is an F, followed by an A, C, Rest, and A. These four notes and Rest are all of the same length and octave. Then, for the note following A, the length is changed by location F6, F7, and F8 to a length code 7, or 0.54 seconds. The next note, which is the last note in the tune, is a C in the top octave and 0.54 seconds long. After the last note, the program counter returns to "Start" and scans the TouchControl switch to determine if the tune is to be played again. #### Note Subroutine The heart of this musical processor is the "Note" subroutine, whose job it is to generate the musical frequencies. Before entering the note subroutine, a three word note code must have been loaded into designated RAM locations along with the octave code and length code to determine the frequency and length of the note to be played. A detailed explanation of this subroutine would be lengthy and is omitted here in favor of a description of some of its key operations. The logic is presented in the flow-diagram in appendix B with source code in appendix C. Each half-period of the musical frequency to be generated is divided into two parts, a fixed and a variable part. The fixed part is 100 machine cycles long and it is this part that performs such tasks as determining if the length of the note has been reached, up- dating the output status, and handling the octave information stored in RAM. The variable part of the note subroutine is called the note period timer that is loaded with the three byte note code to time the length of the half period of the note. The note period timer occupies ROM locations 3EE through 3FB, and its length, in machine cycles, is equal to $9 + 3 \times [15 \text{-code } 1] + 4 \times [15 \text{-code } 2] + 5 \times [15 \text{-code } 3]$ . The highest frequency, C, has a note code of 15, 15, 13, resulting in a total of 19 machine cycles for the note period timer for a C note. Adding this to the 100 cycle fixed timer, there are 119 machine cycles in one half period of a C note or 238 cycles per period. For an operating frequency of 1MHz, the resulting 4µs per machine cycle yields a C period of $952\mu s$ , a frequency of 1050Hz. The same analysis for the A note with its note code of 12, 14, 11 gives an A period of 284 machine cycles or 1136µs, a frequency of 800Hz. The note codes used here result in relative accuracies of $\pm 0.26\%$ . which are easily acceptable for single note instruments. Octave information is handled by the E register. At the label, "Load", the octave code is loaded from RAM into register E, which is examined after each run of the note period timer. If E were always equal to 0, the program counter would always jump from the end of the note period timer to the label "CHGO" to change status of the outputs. If the octave code stored in RAM is 0, E will always be 0. If the octave code were 1 instead of 0 then, after the first run of the note period timer, E would equal 1; E would then be decremented, the 89 cycle "filler timer" is run, and the note period timer would be run again. E would now be 0, so the program jumps to "CHGO" to effect the end of a half period. This latter example results in an output of half the frequency. Thus, the lower the octave code, the higher the resulting output frequency. Mention was made above to an 89 cycle filler timer. These filler timers are used in various lengths throughout the "Note" subroutine to keep the fixed portion of the half period equal to 100 machine cycles for all possible paths in the flow diagram. The output status of D0 and D4 must be changed every half period of the generated frequency, since they both provide the highest octave output. D1 through D5 states change every other half period, and so on through D3 and D7 which change once every eight half periods. This is easily accomplished by adding one to the output status register in RAM at every half period of the note generated. To obtain the four D0, D1, D2 and D3 outputs 180° out of phase with the four D4, D5, D6, and D7 outputs, the output status register is loaded into the accumulator, complimented and a DISB instruction then updates all eight D outputs as desired. The length of a note is dependent on both the length code stored in RAM and the frequency applied to I8, which is internally divided by 60 to operate the seconds flip flop. Each time after the output status of the D lines is changed, the SOS instruction tests the seconds flip flop. If it is a 1, the length counter is incremented and, if it is greater than 15, the note is over. A higher length code results in a shorter note length, as indicated in the table at the beginning of appendix C. When the note is over, a fixed "space timer" is run to put a gap between adjacent notes. The "Note" subroutine then returns the program counter back to the note letter subroutine and, ultimately, back to the ## **Options for Outputs** next location in the tune memory. The musical frequencies generated by this S2000 are available at four different octaves on D0 through D3. In addition, the same frequencies are available on D4 through D7 but 180° out of phase. These eight outputs by themselves or in combination with one of the two AK outputs allow for a variety of sounds to be generated. The out-phased outputs allow for driving a speaker through an impedance matching transformer without the use of any power amplifier. Although the circuit in Figure 1 shows D0 and D4 connected as a push-pull output driving a speaker, lower frequency tones could be derived by driving with D1 and D5, D2 and D6 or D3 and D7. Figure 3 shows three of the D outputs mixed to form a stair-stepped [or sawtooth] waveform. This provides more harmonics to be used more effectively with filter circuits for obtaining the sounds of brass instruments, strings, and other complex voices. The two AK signals, outputs A2 and A3, are provided for creating percussive sounds, such as plucked strings, pianos, and bells. These signals are turned on at the beginning of a note, and off at the note's end to be used in the generation of an envelope to key on and decay gradually the audio signal. Figure 2 shows a simple percussive circuit that uses a single transistor driven by the AK signal of A3 to charge a capacitor that creates a keying envelope causing the amplitude of the audio signal to decay. The A2 signal is identical to A3 but opposite in polarity. #### Summary This application note describes a fairly specific product. As a doorbell, music box, telephone "tune" ringer, or other musical memory, this product may fit the application as is, or with some modifications. However, the broader intent has been to describe how an \$2000 could be used to create music and to suggest a variety of applications in which the \$2000 can be used musically to create many types of imaginative end products. STMT LOC OBJ SOURCE 0059 0011 05 PSL ``` 0001 TOTLE DOORSELL *THIS PROGRAM PLAYS THELVE TUNES OF VARIOUS LENGTHS. TUNES MAY OCCUPY 0002 *MEMORY LOCATIONS FROM GOEZ THROUGH GBSF.AT THE BEGINNING OF EACH 0003 *TUNE, THE LENGTH AND OCTAVE OF EACH NOTE SHOULD BE ENTERED, 0004 *FOLLOWED BY ONE "JMS REST" STATEMENT.NOTES MAY THEN FOLLOW 0005 *EACH OTHER IN SEQUENCE: ONE "UMS (NOTE LETTER)"AFTER ANOTHER; 0006 *UNLESS A NOTE CHANGES LENGTH OR OCTAVE FROM THE PREVIOUS NOTE. 0007 *THIS CHANGE MUST BE ENTERED BEFORE EACH NOTE THAT CHANGES 8000 0009 XLENGTH OR OCTAVE. XTO CHANGE LENGTH: TO CHANGE OCTAVE: TO CHANGE LEN. ROCT .: 0010 LBZ 1 LBZ 0 LBZ 0 0.011 0012 LAT (LENGTH CODE) LAT (OCTAVE CODE) LAT (OCTAVE CODE) XCT: 0 ж XCX 1 XC 1 0.013 0014 ж LAT (LENGTH CODE) 0015 XCT 1 * OCTAVE: OCTAVE CODE: 0016 0017 ж 1(554 TO 1046HZ) 0 2 0018 ж 1 0019 3 3 4 7 0029 * 5(35 TO 65 HZ) 1.5 0021 0022 0023 * RECTH A TEMPO OSCILLATOR EREQUENCY OF 1000 HZ.; 0024 * DURATION OF NOTE(SEC.): HETOME CYCLES: LENGTH CODE: 0025 ж 0.96 16 Ü 0.90 0.026 ж 1.5 1 14 2 0.84 0.027 ж 0.28 1/3 3 0028 ж 4 0029 0.72 1,2 5 0030 0.66 1.1. 0031 0.60 1.0 ó 9 7 0032 ж 0.54 0.033 ж 0.48 8 8 0.42 7 9 0034 * 0.36 0035 ж 6 1.0 0.30 5 0036 Ж 1.1 44 0.032 ж 0.24 1.2 0038 × 0.18 3 13 0.039 2 1.4 ж 0.12 1. 15 0040 0.06 0041 0000 ORG 0 0042 0000 6F 1545 0 0043 0001 SF FP Ü 0044 0002 ZD LAI 13 0045 6003 13 XAB 0046 0004 05 PSL. 0047 0005 ZF START SEEGIN TOUCH CYCLE LAT 15 0048 0086 13 XAB 0049 0007 05 PSL 0050 0008 72 LAI 2 0051 0009 13 XAB 0052 000A 04 PSH 0053 000B 19 MVS 0054 000C 24 LAT 4 0055 0000 13 XAB 0056 000E 78 8 LAI 0057 000F 04 PSH 0058 0010 19 MUS ``` ### STMT LOC DBJ SOURCE | 0060 0013 | 28 | | SZK | | | | | |--------------------------|------|-------|------------|-------------|-----------------|-----------------|---------------------| | 0061 0010 | 3 C5 | | JMP | START | | | | | 0062 0014 | | | MVS | | | | | | 0063 0015 | 5 40 | PIAY | LBZ | 0 | | | | | 0064 0016 | 3 2B | | SF1 | | SET | TUNE FLAC | ٠. | | 0065 0017 | 7 04 | SCAN | PSH - | | | | | | 0066 0018 | 3 19 | | MVS | | #TURN | ON AC O | R A5 | | 0067 8019 | 7.71 | | LAX | 1. | | | | | 0068 0014 | 1 28 | | SZK | | #TEST | TUNT | | | 0069 001E | 3 60 | | p.p. | TUN1.764 | | | | | 0070 0010 | C F4 | | JMP | TUN1 | #F¶AY | TUNE | | | 0071 0010 | | | SZI | | TEST | TUN4 | | | 0072 001E | | | pgi | TUN4764 | | | | | 0023 001F | 04 | | JMP | TUN4 | | | | | 0074 0020 | | | L.AX | 2 | | | | | 0025 0021 | | | SZK | <b>,,</b> | 3 TEST | 7118/2 | | | 0076 0023 | | | ŘΡ | TUN2764 | | 1 4 81 47 | | | 0077 0023 | | | ปกต | TUN2 | | | | | 0078 002 | | | SZI | 1 1.71 52,. | FTEST | THREE | | | 0079 0029 | | | PP | TUN5/64 | y 11c./ 1 | 1 * 1(3%) | | | 0080 602 | | | JMP | TUNE: | | | | | 0081 0027 | | | LAX | A CARCO | | | | | 0082 0029 | | | SZK | • | FTEST | 2011/81/20 | | | 0083 0029 | | | PP | TUN3/64 | 7 1 lings 1 | 10042 | | | 0084 002/ | | | JMF | TUN3 | | | | | 0085 0026 | | | SZX | LOIXO | TEST | THIALA | | | 0086 002 | | | PP. | TUN6/64 | 9 1 10.70 1 | 140865 | | | 0002 0020 | | | JMP | TUNG | | | | | 0088 0021 | | | TF1 | 1 (3)3(5) | A OFFICE CONTRA | TUNE FLA | A.C. | | 0089 0029 | | | JMP | START | > 1 10.35 f | 1086 14.0 | r)Ls | | 0090 003 | | | PSL. | DIPHE | | | | | 0091 003 | | | | | e mulimati | CUTT AO | | | 0092 003 | | | MVS | E: | | OFF AO | | | 0093 0033 | | | LAX | 5 | > LORN | ON A5 | | | 0094 003 | | | XAB<br>RF1 | | | | | | 0095 0035 | | | JMP | CCAN | | | | | 0096 0036 | | toro. | L.AX | SCAN<br>15 | 41 (0AD | a to material | Pattern of the land | | 0097 0032 | | | | | • IUPILI | TO THIR | BU=01BL=1 | | 0098 0038 | | | XC | 1 | 41 21 421 | 4 E. 305 (2022) | man a kmin a | | | | | LAI | 15 | ¥ L.UAND | TO THEE | BU=1;BL=1 | | -0099-0039<br>-0100-0036 | | | XC | 3 | 11 25025 | 4.00 00510020 | Part I are Part and | | | | | LAX | 13 | | | BU™2≠BL≈1 | | | | | XC | E. | 3 @U≈0 | | | | 0102 0036 | | | UMS | NOTE | ≇F¶≙Y | NUTE. | | | -0103 0030<br>-0104 0030 | | | RT | t a | | | | | | | | LAI | 14 | | | | | 0105 003F | | | XC | 1. | | | | | 0106 004 | | | LAI | 14 | | | | | 0102 004: | | | XC | 3 | | | | | 0108 0042 | | | LAX | 13 | | | | | 0109 0043 | | | XC | 2 | | | | | 0110 004 | | | JMS | NOTE | | | | | 0111 0045 | | | RT | | | | | | 0112 004 | | | LAX | 13 | | | | | 0113 0047 | | | XC. | Jł. | | | | | 0114 004 | | | LAI | 1.4 | | | | | 0115 0049 | | | XC | 3 | | | | | 0316 0046 | | | LAC | 12 | | | | | 0117 004 | | | XC | 2 | | | | | 0118 0040 | 2 90 | | JMS | NOTE | | | | ### STMT LOC OBJ SOURCE | 0119 | 904D | 02 | | RT | | |-------|-------|------------|--------------|-------|-------| | 0120 | 004E | ZC: | FA | ĻAII | 1.2 | | 0121 | 004F | 36 | | XC | 1 | | 0.122 | 0050 | ZE | | LAX | 1.4 | | 0423 | 0.051 | 38 | | XC | 3 | | 0124 | 0052 | ZB. | | LAT | 11 | | 0125 | 0053 | 39 | | | | | | | | | XC | 2 | | 0126 | 0.054 | 9C | | JMS | NOTE. | | 0127 | 0.055 | 02 | H 11 475 475 | RT | | | 0128 | 0056 | <b>7</b> B | FGS | L.A.I | 3.3. | | 0129 | 0.057 | 30 | | XC | 1. | | 0130 | 0.058 | ΖE. | | 加海道 | 14 | | 0131 | 0.059 | 38 | | XC | 3 | | 0.135 | 0.056 | ZA | | LAX | 1.0 | | 0.133 | 0.058 | 39 | | XC | 2 | | 0134 | 0050 | 90 | | JMS | BTON | | 0.135 | 0.050 | 98 | | RT | | | 0136 | 0.05E | 78 | FG | LAI. | 8 | | 01,37 | 0.05F | 36 | | XC | 1. | | 0138 | 0060 | ZE | | LAI | 14 | | 0139 | 1900 | 38 | | XC | 3 | | 0140 | 0062 | 7A | | LAT | 10 | | 0141 | | 39 | | | | | | 0063 | | | XC | 2 | | 0142 | 0064 | 9C | | JMS | NOTE | | 0143 | 0065 | 022 | 4101.01.4-1 | RT | | | 0144 | 0066 | 25 | FFS | LAI | 5 | | 0445 | 0.067 | 36 | | XC | 1. | | 0146 | 0068 | ZE. | | LAT | 14 | | 01.47 | 0049 | 38 | | ΧC | 3 | | 0148 | 006A | ZA | | L.AX | 10 | | 0149 | 0.06B | 39 | | XC | 2 | | 0.150 | 0060 | 90 | | JMS | NOTE | | 0.151 | 006D | 02 | | RT | | | 0.152 | 006E | Z5 | tale. | L,AX | 5 | | 01,53 | 006F | 36 | | XC | 1. | | 0.154 | 0.070 | 7E, | | LAX | 14 | | 0.155 | 0.021 | 38 | | XC 3X | 3 | | 0.056 | 0.072 | 78 | | L600 | 8 | | 0.157 | 0.023 | 39 | | XC | 2 | | 0.158 | 0074 | 90 | | JMS | NOTE | | 91,59 | 0.02% | 02 | | RT | , | | 0460 | 0076 | 74 | FE | LAT | 4 | | 0161 | 0022 | 3A | , | XC | 1 | | 0162 | 0079 | 20 | | | 12 | | 0163 | 0029 | 38 | | LAX | | | | | | | XC | 3 | | 0164 | 00ZA | 28 | | LAT | 9 | | 0165 | 0.078 | 39 | | XC | 2 | | 0166 | 00ZC | 90 | | JMS | MOTE | | 0.167 | 0020 | 02 | | RT | | | | 00ZE | | FOS | 1AX | 3 | | 0169 | 00ZE | 36 | | XC | :1 | | 01.70 | 0080 | ZΔ | | LAI | 1.0 | | 0171 | 0081 | 38 | | XC | 3 | | 0172 | 0.085 | 28 | | LAI | 8 | | 0173 | 0.083 | 39 | | XC | 2 | | 0.124 | 0084 | 90 | | JMS | NOTE | | 0.175 | 0.085 | 0.2 | | RT | | | 0126 | 0086 | <i>7</i> 3 | FD | LAI | 3 | | 0177 | 0.087 | 34 | | XC | j. | | | | | | | | - -- | A.M.I. 92000<br>VERSION 1.3 | ASSEMBLER | DOORBELL | PAGE 0005 | |----------------------------------------------------------------------------------------------|----------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------| | STMT LOC OBJ | SOURCE | | | | 0237 03EC 13<br>0230 03ED 3E<br>0239 03EE 51<br>0240 03EF F1<br>0241 03F0 EE | Li<br>LOOP1 Al<br>Ji<br>Ji | 48<br>4M 1<br>07S 1<br>4P 00T1<br>4P L00F1 | #BEGIN TIMER LOOP STARTING AT LOOP1<br>#TIME=9+3(15-CODE1)+4(15-CODE2)+5(15-CODE3 | | 0242 03F1 3C<br>0243 03F2 51<br>0244 03F3 F6<br>0245 03F4 60<br>0246 03F5 F2<br>0247 03F6 3D | LOOP2 AF<br>JI<br>P1<br>Ji | 9M 9<br>DTS 1<br>MP 0UT2<br>P LOOP2/64<br>MP LOOP2<br>AM 2 | | | 0248 03F7 51<br>0249 03F8 6D<br>0250 03F9 D6<br>0251 03FA 00<br>0252 03F8 F7<br>0253 0094 | 19<br>N<br>N<br>Ji | DIS 1 0 | | | 0254 0096 40<br>0255 0097 08<br>0256 0098 DA<br>0257 0099 66 | OCTAV LI<br>SI<br>JI | 3Z 0<br>BE<br>MP DECE<br>MP CHGO | \$SKIP IF E≈0 | | 0258 009A 0D<br>0259 009B 5F<br>0260 009C 00 | DECE X | AE<br>DIS 15<br>DF | \$LOAD OCTAVE INFO IN ACC<br>DECREMENT ACC | | 0261 009D 0D<br>0262 009E 71<br>0263 009F 00<br>0264 00A0 51 | FTLL1 LA | 4E<br>4I L<br>DF<br>DIS 1 | *BEGIN 89 CYCLE TIMER | | 0265 00A1 60<br>0266 00A2 EA<br>0267 00A3 00<br>0268 00A5 00 | N | MIP TIME<br>DP<br>DP | STIMER OVER | | 0269 00A5 E0<br>0270 00A6 42<br>0271 00A7 3B<br>0272 00A8 51<br>0273 00A9 00 | CHGO LI<br>XI<br>Al | MP FILL2<br>8Z 2<br>5 6<br>DIS 1<br>DP | SET RAM ADDRESS TO OUTPUT STATUS SINCREMENT OUTPUT INFORMATION | | 0274 00AA 38<br>0275 00AB 3F<br>0276 00AC 10<br>0277 00AD 2F | C)<br>T) | AM 0<br>MA<br>F2 | FDONT CHANGE OUTPUTS IF REST ON | | 0278 00AE 18<br>0279 00AF 07<br>0280 00B0 F9<br>0281 00B1 43<br>0282 00B2 38 | S:<br>Ji | ISB<br>OS<br>MP FILLS<br>OZ 3<br>C 0 | DON'T INCREMENT INC LENGTH IF SEC NOT 1 | | 0283 0083 51<br>0284 0084 60<br>0285 0085 C8<br>0286 0086 38 | 64<br>191<br>JJ<br>X | DIS 1<br>P ENNOT/64<br>MP ENNOT<br>C 0 | FEND NOTE OF OVER | | 0287 0087 6D<br>0288 0088 FE<br>0289 0089 00<br>0290 0084 00<br>0291 0088 00<br>0292 008C 00 | FULLS NO<br>NO<br>NO<br>NO | FIGULAZ64 MP FITLL 4 DP DP DP | | | 0272 00BD 00<br>0293 00BD 74<br>0295 00BE 74 | FTLL4 L | or<br>or<br>al 4 | SBEGIN 21 CYCLE TIMER | - . - 0295 00BF 00 NOF SYMT LOC OBJ SOURCE ``` 0296 0000 51 FILLS ADES 0297 0001 60 [24]24 FINEL 764 0298 0002 06 JML FINEL 0299 0003 00 NOI» 0300 0004 60 rara F01.1.5764 JMP 0301 0005 00 F71.1.5 0302 0006 60 ENFL [949] - 1.0商076件 0303 0007 EZ JMP L.OAD 0304 0008 73 ENNOT LAI 3 ⇒SET A3 LO№ 0305 0009 13 XAB 0306 00CA 05 P91... 0307 0008 72 LAX 2 XAB 0308 0000 13 PSH 0309 00CD 04 #SET AZ HIGH 0310 00CE J2 MVS 0311 00CF 70 LAX *BEGIN SPACE TIMER 0312 0000 OD XAE 0313 00D1 40 UBZ 0314 0002 Z0 SPACE LAIL n 0315 00D3 51 SP1 ADTS E JHP 0316 00D4 D6 SP2 0317 0005 03 JMP SPE 0318 00D6 0D SP2 XAE 0319 0007 51 ADIUS JMP 0320 09D8 DB SP3 0321 0009 00 XAE 0382 000A 02 JMP SPACE 0323 00DB 13 SP3 XAB 0324 00DC 51 ADIS 0325 0000 00 JMP SPOUT 0326 06DE 13 XAB 0322 000F D2 JMP SPACE 0328 00E0 40 SPOUT L8Z 0 0329 00E1 3B ХC 0 0330 00E2 33 XCT Ü 0331 00E3 02 RT 0332 00E4 2E TUNI TF3 SITEST FOR SCAN NUMBER 0333 00ES 66 [24]2 TUN27/64 JP4F* TUNZ 0334 00E6 (I) 0335 0067 46 1.62 Ü S CHARGE 1 0336 0008 71 LAC 0337 00F9 3A \times 0 SLOAD OCTAVE INFO IN RAM 0338 00EA ZD LAX 13 0339 00FB 32 XCT RAME OF CHARGE PARTY OF STREET 0340 00EC 80 JBS REST 0341 05ED 84 JMS C SPLAY MOTE C 0342 00EE 40 U82 0343 00EF 20 LAX FORARGE DOTAVE n \times cx 0344 00F0 33 Ü 0345 00F1 3E JMS 1:: 0346 0002 96 JMS 0347 00F3 84 JMS 0348 00F4 80 JR69 PEST 0349 08F5 9A Θ JMS 0350 00F6 41 1.82 1. 0351 00FZ 72 A30 0352 0018 32 :1. X \in \mathfrak{X} FICHANGE NOTE LENGTH JMS 0353 0069 84 C 0354 00FA 6F pip STARTZ64 ``` | A.M.J. | 52000 | ASSEMBLER | |---------|-------|-----------| | VERSION | 1.43 | | DOORBELL PAGE 0007 ### STMT LOC OBJ SOURCE | 0355 0 | 0 FB | CS | JMP | START | | | |----------------|----------------------|---------|-----|------------------|-----------|-------| | -0.356 - 0 | OFFC | 2E TUN2 | TF1 | | 7 JOINGLE | BELLS | | -0.357 - 0 | 04%) | 66 | рþ | TUN8/64 | | | | 0358 0 | 0176. | E9 | JMP | TUMB | | | | -0.359 - 0 | 0416 | 40 | LBZ | 0 | | | | -0360-0 | 1, 1) () | 2.0 | LAX | 0 | | | | -0361 - 0 | 1.01 | 3A | XC | i. | | | | 0362 0 | 102 | 20 | UAX | 1.2 | | | | 0363 0 | 1.03 | 32 | XCX | 1. | | | | 0364 0 | 1.04 | 80 | JM5 | REST | | | | -0.365 - 0 | 105 | 8E | JMS | ļ: <del>"</del> | | | | 9366 0 | 106 | 8周 | JHS | <del></del> | | | | 0337 0 | 1.07 | AE. | JMS | <del> </del> | | | | 0368 0 | 1.03 | 80 | JMS | REST | | | | <b>0</b> 369 0 | 1,09 | BE | JMS | l <del>.</del> . | | | | 0370 0 | $1.0 \Delta_{\rm L}$ | 8E | JMS | F | | | | -0.324, -0 | <b>1</b> 0B | 86 | JMS | <b>₽</b> | | | Ap Notes ## **Application Note** ### S2559 Digital Tone Generator ### Applications of the S2559 Digital Tone Generator The S2559 Series Digital Tone Generators were designed specifically for use in the implementation of the DTMF tone dialing push-button telephones. Other applications of the device include radio and mobile telephones, Remote Control, Point of Sale and Credit Card Verification Terminals, Alarm Reporting Devices, Automatic Dialers, etc. This application note describes design considerations, test methods and results obtained using the S2559 Tone Generator in these applications. For detailed specifications of the device refer to the S2559 Data Sheet. ### Push-Button Dual Tone Telephone The primary application of the Digital Tone Generator is in the design of a push-button dual tone telephone. To help explain how it can be used in a modified standard telephone, a description of the standard telephone is presented first. Figure 1 shows the circuit diagram of a 500 type telephone set, an industry standard. Although there are various manufacturers of the 500 type telephone set, the internal circuitry is similar. Some manufacturers encapsulate all the active circuits with access provided at terminals only. The nomenclature of these terminals and their number may vary, depending upon the telephone model and its manufacturer. The telephone set is composed of a transmitter, a receiver, an electrical network for equalization and associated circuitry to control sidetone and to connect power and signaling. The transmission circuitry of the telephone set is designed to separate the transmitter and receiver circuits to limit the amount of the talker's signal appearing in his own receiver (sidetone) and to block the direct current in the transmitter from the receiver. A controlled amount of sidetone is necessary for maintaining a natural conversation. In the diagram of Figure 1, L1, L2 and L3 form a 3 winding transformer and V2, C3, R3, C4 form the sidetone balancing network. With the phone on-hook, hookswitch contacts S1, S2 are open and S3 is closed to protect the transmitter and receiver from ringing current from the central office to pass through the transmitter. When the phone is off the hook, contacts S1, S2 close, S3 opens and direct current flows in the transmitter. Capacitors in the sidetone balance network prevent the direct current flowing in the transmitter from appearing in the receiver. During dialing, contact S6 across the receiver is closed to eliminate undesirable clicks and contact S5 interrupts the direct current at the dial pulse rate. Capacitor C2 forms a dial pulse filter to suppress high frequency interference into radio sets. Varistor $V_3$ suppresses clicks in the receiver. Varistors $V_1$ and $V_2$ are part of the equalizing network to reduce transmitting and receiving efficiency on short loops. The varistors have a property of decreasing in resistance with increasing currents. On long loops the direct current from the central office battery is low; the varistor impedances are therefore high and the maximum telephone set efficiency is obtained. On short loops the high direct current results in low varistor impedances which shunt the speech currents and reduce the set efficiency. The overall effect is to make speech volumes at the central office and at the subscriber receivers less dependent on loop length. The voltage developed in the local transmitter is divided in the windings L1 and L2 so that the voltages induced in the winding L3 are opposing. The voltage across the sidetone network resistance R3 arising from current flowing in winding L2 is arranged to oppose the resultant of voltages induced in L3. The overall effect of this balance is that the current in the receiver as a result of voltages developed in the transmitter is small and thus produces a low sidetone level. On the other hand, speech currents received from the loop pass through windings L1 and L2 and produce additive voltages in winding L3 which is connected to the receiver. These additive voltages are opposed by an approximately equal voltage 180° out of phase which results from the receiving current in winding L2. As a result there is little voltage drop across R3 and maximum receiving levels are obtained without appreciable power loss in resistor R3. ### Implementation Using Mechanical Switching Figure 2 shows how the circuit of Figure 1 can be modified to incorporate the Digital Tone Generator eliminating the dial, adding a push-button keyboard to achieve a push-button dual tone telephone. It is seen that the device interfaces directly with the encapsulated circuitry without modification of it. Diodes D1 through D4 are inserted to insure that the polarity of the direct voltage across the device is the same even if connections to the phone terminals are reversed. When the phone goes off-hook and a digit key is pushed, the device is powered up by the closure of common switch contact K2B. Zener $V_z$ insures that the voltage across the device will not exceed the maximum operating voltage. The recommended value for Vz is 12 volts. Common switch K2A opens, removing the drive to the transmitter. The common switch K1 opens, which leaves the receiver connected through resistor Rs. Resistor Rs determines the amount of digit sidetone heard in the receiver. Typical value of Rs is $5.1 \mathrm{K}\Omega$ . The tone output of the device can be connected directly to the phone line through resistor $R_{\rm T}$ . To obtain tone amplitudes in the acceptable range, typically a resistor in the range of 100 ohms to 200 ohms is required. Lower resistor values produce higher amplitudes at the phone terminals but at increased distortion. An alternate way to produce higher amplitudes at the same time keeping distortion low is to use an emitter follower transistor, as shown in Figure 2. $R_T$ is now increased to $10 K\Omega$ while $R_L$ is chosen in the range of 100 to 200 ohms to produce the desired amplitude. Lower values of $R_L$ tend to increase amplitude seen at the phone terminals as before. ### Implementation Using Electronic Switching Electronic switching using transistors can be employed to control the transmit and receive functions of the telephone as shown in Figure 3, which depicts an interface circuit for the 2500 type network. PNP transistors $Q_T$ and $Q_R$ are used as series contacts with the microphone and the receiver. In the tone dialing mode, transistors $Q_T$ and $Q_R$ are turned off, while in the voice mode they are turned "on." There is a slight loss in the transmission efficiency due to the finite "on" impedances of the transistors and due to base drive currents required by the two transistors for "hard switching." ### Performance Evaluation The two major criteria in the evaluation of the Digital Tone Generator in the telephone application are 1) the Amplitude/Loop Current characteristic, and 2) Distortion. Figure 4 shows a test circuit suitable for these measurements. Note that the circuit allows simulation of DC Loop Conditions only. With this circuit, loop current can be varied over the range of 20mA to 80mA. ### **Amplitude Loop Current** Figure 5 shows a typical plot of amplitude vs loop current superimposed on the recommended AT&T specification (ref. 1) obtained using the circuit of Figure 2 with $R_T = 150\Omega$ (external emitter follower stage disconnected) in the test configuration of Figure 4. The absolute amplitude can be increased or decreased in a variety of ways. One way is to vary RL. RL typically will be in the range of 100 to 200 $\Omega$ . Increasing R<sub>L</sub> tends to decrease amplitude but improve distortion. Another alternative for increased amplitude is to use a bypass capacitor across RL. This, however, tends to increase distortion. An emitter-follower transistor can be connected on the tone output. This allows increased amplitude and reduced distortion at the same time. These alternatives are shown in Figure 6. Use of the extra emitter-follower stage, however, decreases the amplitude slope characteristic. In general, a trade-off between amplitude, amplitude slope and distortion is necessary. ### Distortion The AT&T specification (ref. 1) reads "The total power of all extraneous frequencies in the voiceband above 500Hz accompanying the signal should be at least 20dB below the level of the frequency pair." The key words here are the total power, voiceband and level of frequency pair. The voiceband is normally defined to be 300Hz to 3400Hz. Therefore, the total power of all extraneous components in the 500Hz to 3400Hz is of interest. The measurement of total power is not easy. To measure it precisely, first the total power of the DTMF signal with extraneous components in the 500Hz to 3400Hz band should be measured. The DTMF signal then should be removed by use of two notch filters centered around the appropriate low group and high group frequencies and the total power measured again. The ratio of the two readings gives a measure of distortion. An alternative is to plot a spectrum of the dual tone waveform and compute distortion using the following formula. Dist. (dB) = 20 log $$\frac{\sqrt{\sum_{i=1}^{n} (V_i)^2}}{\sqrt{(V_L)^2 + (V_H)^2}}$$ $$= 10 \left\{ log \left[ \sum_{i=1}^{n} (V_i)^2 \right] - log \left[ (V_L)^2 + (V_H)^2 \right] \right\}$$ (1) Table 1. dB to (rmsV) and (rmsV)2 Conversion Chart | #8 | (ramV) | (ramV)2 | 48 | (rsmV) | (rsmV) <sup>2</sup> | 1 | dB | (rsmV) | (ramV)² | 1 | dB | (rsmV) | (rsm∀)² | |-------|---------|---------|------|----------|---------------------|-----|------|----------|-----------|-----|------------|-----------|-----------| | ~ 1.0 | 0.8913 | 0.79433 | 20 | 0 1 | 0.0100000 | | - 33 | 0.02238 | 0.0005012 | | - 46 | 0.005011 | 0.0000251 | | -1.5 | 0.8414 | 0.70795 | -21 | 0.089 | 0.0079433 | | -34 | 0.01995 | 0.0003981 | | -47 | 0.00446 | 0.0000199 | | -2.0 | 0.7943 | 0.63096 | -22 | 0.07943 | 0.0063096 | - i | ~ 35 | 0.01778 | 0.0003162 | 1 | - 48 | 0.00398 | 0.0000158 | | -2.5 | 0 7498 | 0.56234 | -23 | 0.0707 | 0.0050119 | | -36 | 0.01584 | 0.0002512 | | - 49 | 0.00354 | 0 0000126 | | -3.0 | 0.7079 | 0.50119 | -24 | 0.063 | 0.0039811 | | -37 | 0.014125 | 0.0001995 | L | - 50 | 0.00316 | 0.0000100 | | -3.5 | 0.6583 | 0.44668 | - 25 | 0.0562 | 0 0031623 | - 1 | -38 | 0.01259 | 0.0001585 | | - 51 | 0.002818 | 0.0000079 | | -4.0 | 0.6309 | 0.39811 | - 26 | 0.050118 | 0.0025119 | - 1 | - 39 | 0.01122 | 0.0001259 | ſ | -52 | 0.00251 | 0.0000063 | | -4.5 | 0.5957 | 0.35481 | -27 | 0.0446 | 0.0019953 | - 1 | | | | 1 | - 53 | 0.00223 | 0.0000050 | | -5.0 | 0.5623 | 0.31623 | - 28 | 0.0398 | 0.0015849 | | -40 | 0.01 | 0.0001000 | ı | - 54 | 0.00199 | 0.0000040 | | -55 | 0.53088 | 0.28184 | -29 | 0 03548 | 0.0012589 | | - 41 | 0.0089 | 0.0000794 | | - 55 | 0.00177 | 0.0000032 | | -6.0 | 0.5012 | 0 25119 | | | | - 1 | - 42 | 0.00794 | 0.0000631 | 1 | 56 | 0.00158 | 0 0000025 | | -6.5 | 0.4732 | 0.22387 | -30 | 0.03162 | 0.0010000 | | -43 | 0.00707 | 0.0000501 | | <b>-57</b> | 0.0014125 | 0.0000020 | | -7.0 | 0.4467 | 0.19953 | →31 | 0.02818 | 0.0007943 | ı | -44 | 0.0063 | 0.0000398 | i i | - 58 | 0.001259 | 0.0000016 | | -7.5 | 0.4217 | 0.17783 | -32 | 0 0251 | 0 0006310 | i | 45 | 0.00562 | 0 0000316 | 1 | - 59 | 0 001122 | 0.0000013 | where $V_L$ and $V_H$ correspond to the rms voltage levels of the low group and high group signal components in the dual tone signal and $V_i$ is the ith extraneous (either intermodulation or harmonic) component in the voice-band (500Hz to 3400Hz). Individual component amplitudes in dB can be readily read off from the spectrum plot, converted to (rmsv)<sup>2</sup> by the use of the conversion chart shown in Table 1. Distortion is then calculated by use of equation (1), above. Figures 7 and 8 show typical spectrum plots obtained in the test circuit of Figure 4 on a \$2559D device in the circuit of Figure 3. Detailed distortion calculations on these spectrum plots are shown in Tables 2 and 3. The results show the distortion at 20mA loop current to be -24.9dB and at 30mA loop current -36.3dB. It is evident that distortion decreases rapidly as the supply voltage increases and as the modulation of the supply voltage decreases. A rule of thumb for quick estimate of distortion is: As a first approximation, distortion in dB equals the difference between the levels in dB of the extraneous component with the highest amplitude and the low group signal component; or Dist. (dB) = $$V_{ih}$$ (dB) - $V_{L}$ (dB) (2) Using this rule of thumb gives estimates of -25dB and -37dB respectively for the loop currents of 20 and 30mA which are close to the computed values of -24.9dB and -36.3dB. Table 2. Distortion Calculations for Spectrum of Figure 7 Device: S2559D in Circuit of Figure 3, Test Circuit Figure 4, 20mA Loop Current | Component | Measured<br>(dB) | rmsV<br>INV log dB<br>20 | (rmsV) <sup>2</sup> | | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------|---------------------|------------|-------|----------------------------|-----------------|---------------------------------|------------------| | V <sub>L</sub><br>V <sub>H</sub> | -5.5<br>-2.5 | | | 2 8<br>5 6 | | 8<br>3 | | | | | V <sub>1</sub><br>V <sub>2</sub><br>V <sub>3</sub><br>V <sub>4</sub><br>V <sub>5</sub><br>V <sub>6</sub><br>V <sub>7</sub><br>V <sub>8</sub><br>V <sub>9</sub><br>V <sub>10</sub> | -31<br>-57<br>-47<br>-42<br>-57<br>-38<br>-30<br>-50<br>-34<br>-41 | | | 0 0 | 00000 | 0<br>0<br>0<br>1<br>0<br>3 | 0 1 6 0 5 0 1 9 | 2<br>9<br>3<br>2<br>8<br>0<br>8 | 09105001 | | $\begin{array}{c} V_{11} \\ V_{12} \\ V_{13} \\ V_{14} \\ V_{15} \\ \hline \\ \Gamma \\ \Sigma (V_i)^2 \end{array}$ | -46<br>-38<br>-56<br>-47 | | | 000 | 0 0 0 | 0 0 0 | 2<br>5<br>0 | 5<br>8<br>2<br>9 | 1<br>5<br>5<br>9 | | $i=1$ $(V_L)^2 + (V_H)^2$ | | | $\perp$ | 8 4 | | | 8 | <br> -<br> | | DIST = $$20 \log \frac{\sqrt{\sum_{i=1}^{n} (V_i)^2}}{\sqrt{(V_L)^2 + (V_H)^2}}$$ = $10 \left\{ \log \left[ \sum_{i=1}^{n} (V_i)^2 \right] - \log \left[ (V_L)^2 + (V_H)^2 \right] \right\}$ = $10 \left\{ -2.56 - (-0.074) \right\}$ = $-24.9 dB (5.7%)$ ### Other Considerations The supply voltage available to the Tone Generator is a function of the DC loop current flowing through the telephone network and the DC impedance presented by the network. The insertion of the diode bridge and voltage drop in the transformer winding further reduce the available voltage. Typically, the DC voltage available to the device is 1.7 volts less than that Table 3. Distortion Calculations for Spectrum of Figure 8 Device: S2559D in Circuit of Figure 3, Test Circuit Figure 4, 30mA Loop Current | Component | Measured<br>(dB) | rmsV<br>INV log d8/20 | (rmsV) <sup>2</sup> | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------|---------------------------------------|------------|--| | V <sub>L</sub><br>V <sub>H</sub> | -6.0<br>-3.0 | | 25118 | | | | V <sub>1</sub><br>V <sub>2</sub><br>V <sub>3</sub><br>V <sub>4</sub><br>V <sub>5</sub><br>V <sub>6</sub><br>V <sub>7</sub><br>V <sub>8</sub><br>V <sub>10</sub><br>V <sub>11</sub><br>V <sub>12</sub><br>V <sub>13</sub><br>V <sub>14</sub><br>V <sub>15</sub> | - 46<br>- 53<br>- 46<br>- 51<br>- 44<br>- 48<br>- 47<br>- 53<br>- 52<br>- 51<br>- 47 | | 000039<br>000015<br>0000019<br>000005 | 01 9889039 | | | $ \begin{array}{c} n \\ \Sigma(V_i)^2 \\ i = 1 \end{array} $ | | | . 0 0 1 7 7 7 | | | | $(V_L)^2 + (V_H)^2$ | | | . 75236 | П | | DIST = $$20 \log \frac{\sqrt{\sum_{i=1}^{n} (V_i)^2}}{\sqrt{(V_L)^2 + (V_H)^2}}$$ = $10 \left\{ \log \left[ \sum_{i=1}^{n} (V_i)^2 \right] - \log \left[ (V_L)^2 + (V_H)^2 \right] \right\}$ = $10 \left\{ -3.75 - (-0.124) \right\}$ = $-36.3 dB (1.5\%)$ measured at the TIP and RING terminals. The instantaneous minimum voltage as seen by the device is even smaller because of the DTMF signal riding on the DC component. The instantaneous minimum voltage can be expressed as $V_{\rm min} = V_{\rm dc} - V_{\rm ac}$ (peak). Because the signal amplitude is larger at lower loop currents, i.e., at lower DC voltages, the instantaneous minimum voltage is significantly less than the average voltage measured across the device. This causes higher distortion at lower loop currents. The DC voltage across the device is under the designer's control during DTMF dialing. The AT&T specification (ref. 1) recommends a minimum DC voltage of 6 volts (4 volts preferred) across the TIP and RING during voice and initial off-hook condition at a loop current of 20mA. However, during DTMF dialing, the DC voltage is permitted to increase to 8 volts (6 volts preferred). The designer can take advantage of this specification to insure adequate voltage across the device at low loop currents. Even with a preferred 6 volt specification, allowing for 1.7 volts drop in the bridge and transformer winding, the average voltage across the device will be at least 4.3 volts. The instantaneous minimum voltage will not drop significantly below 3.6 volts, assuring good distortion performance down to lower loop currents. The voltage across the device can be increased by allowing the telephone DC impedance to increase during DTMF signalling. Since the microphone is switched out during signalling, this is directly a function of the DC current drawn by the device. Since the DC current required by the device is low, it is primarily a function of the load RL. Increasing R<sub>L</sub> will increase the DC impedance and thereby increase the average supply voltage, thus reducing distortion. Increasing RL, however, reduces signal amplitude so a trade off has to be made between amplitude and distortion. Consideration should also be given to insure adequate base drive to the external transmit and mute transistors when operating at low loop currents if electronic switching is used. ### Transient Voltage Protection An important consideration in the design of electronic equipment to be connected to the telephone network is that adequate transient voltage protection circuitry must be incorporated such that the equipment can withstand lightning surges without causing harm to the telephone network. In particular, all equipment must meet the metallic and longitudinal surge voltage specifications outlined in the FCC part 68 (ref. 2). When aplied to tone generator interface circuits, such as those in Figures 2 and 3, transient voltage protection requires proper selection of components for the diode bridge and the zener diode. It is necessary that the diode bridge utilize high voltage breakdown and high current capacity diodes. 1N4004 type diodes may be adequate but higher rated diodes might be required. Selection of the zener diode depends upon its transient response characteristic. A slow zener diode will not clamp voltage to its rated value. However, it should be noted that the S2559 Tone Generator can withstand pulse voltages that exceed the absolute maximum continuous DC voltage ratings (10.0V for S2559C, D; 13.5V for S2559A, B). Typically, the S2559 devices can withstand up to 20 volts of pulse voltages for durations of less than 1mS. It should also be noted that the zener diode and the device are behind the network transformer winding and not directly across the telephone terminals. These considerations allow selection of a wide range of zener diodes as protection elements. A zener diode of the type 1N4742 may be adequate in most cases. ### Ancillary Interface to Phone Lines The Digital Tone Generator can be used in ancillary station apparatus (such as alarm reporting devices, automatic dialers, data terminals, etc.) for tone dialing or low speed data transmission applications. A transformer interface, such as that shown in Figure 9, can be used. Consideration must be given to the device latch up possibility due to induced voltage spikes in the transformer winding connected to the tone output. Latch up can be prevented by diode clamping the tone output to $V_{\rm DD}$ and $V_{\rm SS}$ . #### Precise Dial Tone Generator The Digital Tone Generator can be used in other single or multitone applications by selecting a crystal of appropriate frequency. The precise dial tone is defined to be a multifrequency tone consisting of 350Hz and 440Hz. By selecting a crystal of 1.3071124MHz, a dial tone of 346Hz and 444Hz can be obtained by activating the R4, C1 inputs of the device. ### References - Ref. 1: Bell System Communications Technical Reference (PUB 47001). Electrical Characteristics of Bell System Network Facilities at the Interface with Voiceband Ancillary and Data Equipment. August 1976. - Ref. 2: Rules and Regulations, FCC part 68. Connection of Terminal Equipment to the Telephone Network. July 1977. # **Application Note** ### TouchControl<sup>™</sup>Circuits For Capacitance Switching ### INTRODUCTION As more manufacturers turn to solid state electronics to enhance the reliability and performance of their products, the need arises for more reliable, noise-free, nonmechanical switches to control these products. To satisfy this need, AMI offers a series of seven MOS TouchControl circuits that will interface directly with a stationary panel to create a capacitive, nonmechanical switching system. The individual capacitors, or touch switches, are formed simply by conductive areas screened or etched onto the panel's front and rear surfaces; connections between the panel's rear surface and the TouchControl interface circuit create the capacitance switches. As many as 32 touch switches can be implemented with a single TouchControl interface circuit. Outputs from the S926X series are offered in two configurations: S9260, S9261, S9263, S9264, and S9265 have an individual output associated with each input; the S9262 and S9266 outputs are encoded in binary for use with more complex logic such as microprocessors. All outputs may be used to drive a variety of logic levels such as MOS, CMOS, and TTL. TouchControl panels may be constructed from many different materials, offering the engineer flexibility in his design. Commonly used panel materials are glass, printed circuit board, plexiglass, and polycarbonate. Selection of a particular material depends on the intended application, as discussed later in this note. Technical specifications for all seven TouchControl circuits may be found in two data sheets. One describes the S9260, S9261, S9263, S9264, and S9265; the S9262 and S9266 are included in a separate data sheet. ### KEYBOARD SCANNING DESCRIPTION A TouchControl switch panel consists of a single sheet of a rigid material with conductive surfaces applied on both sides as shown in Figure 1. Regardless of the selected panel material, a touch switch is formed by applying a single conductive area to its front surface with two other conductive areas applied directly in line on the reverse side of the panel. Figure 1 shows three views of a typical touch panel containing two TouchControl switches. On switch one, conductive surface A is applied to the front of the panel and is the surface to be touched to effect a switch "closure." Surfaces B and C are applied directly in line with A on the opposite side of the panel. Surface A should cover completely and may overlap surfaces B and C so that a capacitor is formed between "plates" B and A and another between A and C. This forms two capacitors connected in series, their common connection point being the surface to be touched to effect switch operation. For all non-multiplexed parts, all "C" surfaces are connected to the SCI output. Multiplexed parts (S9262, and S9266) will be discussed later. Shown in Figure 2, the SCI output appears as alternating sets of 16 pulses. The peak-to-peak voltage of the SCI output is approximately equal to the $V_{\rm DD}$ supply level, and the logic 1 (negative) level duration is twice the period of the oscillator frequency at pin 18. Since the SCI logic 0 level between two adjacent pulses lasts one oscillator period, then the duration of all 16 pulses is $(2+1) \times 16 = 48$ oscillator periods. Following the 16 pulses, a logic 0 level appears for a duration of 96 oscillator periods before the next series of 16 pulses commences. The oscillator period is determined by the external RC time constant with values for R and C shown in Figure 3. Note that, if several TouchControl interface parts are used in a given system, all RC pins may be connected together to a single RC time constant. Each of the 16 pulses in the SCI signal corresponds to an individual "I" input to the interface circuit. Figure 2 shows the input 15 for both the untouched (VINU) and touched (VINT) conditions. The SCI signal is coupled through to input 15 through the two touch panel capacitors, Cp. Note that instead of observing 16 pulses at the 15 input as might be expected, only one pulse appears for every 16 SCI pulses; this is because of an active device on the MOS circuit that grounds the 15 input at all times except for the duration of the sixth of the 16 pulses. (This technique allows the input conductors to be run close to each other, as described in the section on "Proximity of Clock and Input Lines.") It is during this sixth pulse that the touch switch connected to the 15 input is interrogated. (The first SCI pulse related to 10, the second to II, etc.) With the switch untouched, the voltage of the single pulse at 15 will be dependent on the ratio of $C_p$ (touch switch capacitance) to $C_S$ (input stray capacitance, usually equal to MOS input capacitance). For example, if $V_{DD} = -15$ volts and $C_p = C_S$ , then $V_C = 15$ volts, and $V_{INU} = 5$ volts. When the capacitive switch is touched, capacitor $C_B$ (human body capacitance) loads the signal to ground; in this condition, the higher $V_{INU}$ level decreases to a lower $V_{INT}$ level, and the MOS comparator circuitry detects the change, causing the appropriate output to occur. For every set of 16 pulses on the SC1 output, the circuit scans all 16 switches. Although the values of $V_{INU}$ and $V_{INT}$ depend on all capacitances involved, typical values might be $V_{INU} = 5$ volts; $V_{INT} = 1$ volt. Calculation of these values, required to insure a reliable system design, is described in the section on "Capacitance Calculations." Keyboard scanning behaves identically in the S9264 and S9265. The S9260 and S9261 scanning is similar, although only seven inputs are available instead of 16. The S9266 employs a 2 x 16 matrix to scan 32 touch switches. One set of 16 switches is clocked by SC1 and the other by SC2, as indicated in Figure 4. The first switch and the seventeenth switch share input 10, the second and eighteenth share input 11, etc. Every group of 16 pulses appearing on the SC1 output is followed immediately by a group of 16 identical pulses on the SC2 output. Following the 16 SC2 pulses, both outputs remain at a logic 0 level for a time equal to one set of 16 pulses, after which time the pulses on SC1 again commence. The S9262 device is similar to the S9266, except that its matrix of 2 x 7 (i.e. SC1 and SC2 by seven inputs) scans 14 instead of 32 touch switches. ### NOISE IMMUNITY Just as mechanical switches have a certain amount of contact bounce associated with them, capacitance switches have the same inherent problem. This contact bounce, or noise, occurs as a finger makes contact with or removes contact from the touched switch surface. All seven TouchControl interface parts contain circuitry to prevent this "contact bounce" from appearing on any output. As discussed in the section on "Keyboard Scanning," the S9263 scans all 16 keys in the time required for 48 periods of the oscillator, and a total of 96 additional periods are required before the scan begins again. During the first 48 of these 96 additional periods, the SC2 output scans its 16 key inputs. Thus, for any of the seven parts, a complete scan of the keyboard occurs in 48 + 96 = 144 periods of the RC oscillator. After every 23 of these complete keyboard scans, a signal is generated on the circuit that clocks the most recent scan information into 32 two-bit shift registers (one for each of 32 switches). Thus, this load pulse occurs every 144 x 23 (=3312) oscillator periods. If a logic one level is loaded into the first bit of one of the registers, indicating a touched switch, no change in output condition occurs, because the second bit of the register is at a zero level. When the next load pulse is generated 3312 periods later, however, if the switch is still touched, another logic one level is clocked into the register, and a one level is transferred from register bit one to register bit two: since both register bits are now "ones," the output is allowed to change state. This means that a minimum of 3312 and a maximum of 6624 oscillator periods are required between the touching of any switch and the changing of any output condition. For an oscillator frequency of 90 kHz, for example, an average of 55 ms of debounce time is obtained. The same debouncing method is applied to the release of any touch switch. ### DETERMINATION OF TOUCH SWITCH SIZES Because one of TouchControl's major advantages is the versatility it offers the design engineer, the actual size of the TouchControl switch becomes an important consideration. As shown in Figure 1, a TouchControl switch consists of three conductive areas, one of which is applied to the front surface of a panel. The other two areas are each slightly less than half the area of the first and are located directly behind on the rear side of the panel so that each forms a capacitor, $\mathbf{C}_{\mathbf{p}}$ , with the larger conductive area on the front surface of the panel. To insure a reliable TouchControl system, it is important that each of these capacitors, $C_p$ , has the required capacitance value. This value depends on a number of factors such as power supply, reference voltage, scan clock voltage, and input stray capacitance; it is discussed in detail in the section on "Determining Required Capacitance Values." After determining the required value for $C_p$ , it is then easy to calculate the area of the touch switch from the relationship $C_p = \frac{0.225 \text{ KA}}{1.00 \text{ KA}}$ in which K is the relative dielectric constant of the panel material, A is the area in square inches of one of the two rear surface conductive areas, and t the panel thickness in inches. This equation calculates $C_p$ in picofarads. Figure 5 provides some nomographs for quick determination of pad area. Since two of the three variables in the equation, K and t, depend entirely on the touch panel, it is clear that the selection of the panel material entails some electrical as well as aesthetic consideration. Touch switches of small area can be formed by choosing a panel material of high dielectric constant and minimum thickness. A typical touch switch area calculation might take these steps: From the information determined in the section on "Determining Required Capacitance Values" it is discovered that a particular system requires 7 picofarad $C_p$ capacitors. The panel material is to be a .062 inch thick printed circuit board with a dielectric constant of 5.0. From the relationship $$Cp = \frac{0.225 \text{ KA}}{t}$$ it is seen that an area, A, of 0.386 square inches is required for each of the two rear surface conductors. If the touch switch area is to be approximately square, then each of the two rear surfaces must have a length about twice its width. Each rear surface conductor can be $0.44 \times 0.877$ inches, giving an area of 0.386. Separating the two conductors by 0.125 inches, the area required for the front surface touch switch then, is $(2 \times .44 + 0.125)$ by .88 or $1.0 \times 0.88$ inches. Of course the touch switch can be designed in many different shapes by altering the dimensions of the three conductors, keeping the rear surface areas constant and insuring that each rear surface conductor is "covered" completely by the front surface conductor (touch pad). If, in this example, the 1.0 x 0.88 inch touch switches are too large, there are several options available. The most obvious would be to use a thinner panel material to increase the Cp capacitance, allowing the switch areas to be smaller. Another alternative is to increase the scan clock voltage, as described in the section on "Determining Required Capacitance Values," to allow the use of smaller Cp capacitors. ### DETERMINING REQUIRED CAPACITANCE VALUES What is required for a reliable TouchControl system is that the peak-to-peak signal level appearing at any "I" input of the interface IC be equal to or greater than a certain value when the switch is untouched and equal to or less than another fixed value when the switch is touched. It is this variation in amplitude that causes the circuit to recognize whether or not a switch is being touched. Referring to Figure 2, the higher voltage level appearing on an input and caused by an untouched switch has been designated VINU. The lower level, VINT, occurs whenever the switch is touched. It can be seen that the VINIT level is determined by the peak-to-peak scan clock output level, VC, the value of the series touch capacitors, Cp, and the value of stray capacitance, CS, at the input to the circuit. The VinT level is affected by all these parameters plus the value of human body capacitance, CB, which ranges typically from 100 to 200 picofarads with a typical minimum value of 50 pF. Because most of the capacitances involved are on the order of 10 pFs or less, it is not meaningful to measure $V_{INU}$ to $V_{INT}$ with conventional equipment. However, it is possible to calculate their values accurately, given $V_C$ , $C_p$ , $C_S$ , and $C_B$ , and these calculations are the first steps in determining the required touch capacitors for a given system. The simplest approach is to assume a $C_p$ value and then determine $V_{INU}$ and $V_{INT}$ . To calculate VINU and VINT for all conditions: $$V_{INU} = \frac{C_p V_C}{C_p + 2C_S}$$ $$V_{INT} = \frac{C_p^2 V_C}{C_p^2 + C_p C_B + C_S C_B + 2C_p C_S}$$ As already stated, VINU must be equal to or greater than a specified value, and VINT must be equal to or less than another specified value. What these values are is determined by the use of the input pin labeled VREF. This pin is used to establish a reference voltage which the internal comparator compares against the "I" input voltage levels to determine if a switch is touched. In some cases it is possible to connect the VREF pin to ground (VSS). In others, it may be beneficial to set VREF, using two resistors, to a value that is 20 percent of the VDD supply level. If VREF is connected to ground (VSS), then VINU must be $\geq$ 4.0 volts and VINT must be $\leq$ 1.3 volts. If these two conditions are met, the resulting TouchControl system will operate satisfactorily. In many proposed TouchControl systems, calculations of $V_{INU}$ and $V_{INT}$ will indicate that the range of 4 to 1.3 volts is difficult to achieve due to high CS capacitance or the need for small switches. In such cases it may be beneficial to use the $V_{REF}$ input to provide a reference voltage for the internal comparator. This comparator typically operates over a $V_{REF}$ range of from -2.5 volts to -3.8 volts. Whenever $V_{REF}$ is within this range, the TouchControl system will function properly under the conditions: $V_{INU} \ge V_{REF} + 1.0$ volt and $V_{INT} \le V_{REF} - 0.5$ volt. If the VREF voltage is derived from the VDD supply voltage using two resistors as a voltage divider, an additional advantage is obtained. As VDD varies, the VC level (SC1 output level) changes, and so does the VREF level. This causes the VREF level to track the scan clock voltage, making the circuit less vulnerable to supply fluctuations. If, for example, VREF is set to a value 20% of the VDD supply voltage, then as the supply, and hence VC, varies from -13.5 to -18.0 volts, VREF will vary from -2.7 to -3.6 volts, remaining within the comparator's operating range. Setting VREF equal to 20% of the VDD (or VC) level, the following expressions will insure a functioning TouchControl system: TOUCHED UNTOUCHED | SWITCH CONDITIO | N SWITCH COND | - | |-------------------------------|------------------------------------------------|-------------------------| | $v_{INU}\!>\!v_{REF}\!+\!1.0$ | $v_{INT} < v_{REF} - 0.5$ | | | $V_{REF} = .2 V_{C}$ | $V_{REF} = .2V_{C}$ | | | Substituting | the expressions for $V_{ m INU}$ and $^{ m v}$ | VINT: | | $c_p v_C > 2v_C + 1.0$ | $C_p^2 V_C$ | <.2 V <sub>€</sub> ~0.5 | | $\overline{C_p + 2C_S}$ | $C_p^2 + C_p C_B + C_S C_B + 2C_p C_S$ | | | | O1 | | | C <sub>p</sub> >.2 + 1 | $c_p^2$ | <.2 - 0.5 | | $C_p + 2C_S$ $V_C$ | $C_p^2 + C_p C_B + C_S C_B + 2C_p C_S$ | $-\widetilde{v_C}$ | From these expressions, it can be seen that the required Cp value is highly dependent on the stray capacitance at the TouchControl input, and only slightly on the fluctuation of the VC level. It is also of interest to note that, in both cases, the "worst case" condition is the lowest expected VC value, and the highest expected VC value is irrelevant. For calculation of the required touch switch capacitance, Cp, for a given input stray capacitance, CS, reference can be made to Figure 6. These curves may be used for any TouchControl system in which the reference voltage is set to between 18 and 22 percent of VDD, VDD is within the specified limits of - 13.5 volts to - 18.0 volts, and VC, the peak-to-peak scan clock voltage, is determined by the SCI output (i.e., VC = VDD and no external amplification of VC is used). The upper curve represents the case where the switch is touched, and the lower corresponds to the antouched condition. Operating TouchControl between the two curves results in a properly functioning system. As a specific example, assume that a proposed Touch-Control system is to be implemented on a printed circuit board. The traces that connect the individual switch areas to the 1 inputs are to be arranged on the board such that the longer traces contribute 4 pF to the stray input capacitance, while the shorter traces contribute only 1 pF. Since the MOS input capacitance is typically 6 pFs, then the total stray capacitance on any input, CS, will vary from $(1 \pm 6 \text{ pFs})$ to $(4 \pm 6 \text{ pFs})$ , or 7 to 10 pFs. Referring to the curves in Figure 6 again, it can be seen that the system will function over the 7 to 10 pF CS range if a touch capacitor, Cp, is chosen between 8.2 pFs and 14.5 pFs. Now that the required Cp capacitance is known, the switch area can be determined from the relationship $$C_p = \frac{.225 \text{ K A}}{1}$$ as previously discussed. If the resulting switch area is too large for the intended application, it is possible to decrease the required C<sub>p</sub> value by increasing the V<sub>C</sub> scan clock level. This is discussed in the following section. #### INCREASING SCAN CLOCK VOLTAGE As has been described, the capacitance required for TouchControl switches, and hence the area required for the switches, is dependent on input stray capacitance, CS, human body capacitance, CB, and the scan clock output level, VC. If it is necessary in a given system to use small switches, or if the CS loading is high, it is possible to reduce the required touch pad capacitance, Cp, by increasing VC. Although it is not advisable to increase VDD higher than - 18.0 volts, it is possible to insert external circuitry between the SC1 output and the keyboard clock bus to increase V<sub>C</sub>. One method of increasing VC is to use a voltage doubler circuit, such as shown in Pigure 7. This circuit is driven by the SC1 (or SC2) output, doubles the voltage, and provides a scan clock with a VC of twice the VDD level (minus 3 to 4 volts). At VDD = -13.5 volts, the doubler consumes typically 20 mA, and at VDD = -18 volts, it uses about 28 mA. The curves in Figure 8 can be used to calculate the required Cp, given CS. The solid lines apply to a system in which a voltage doubler is used to provide a VC of 23 to 32 volts from a VDD supply of -13.5 to -18.0 volts. The dotted lines represent the best performance obtainable with the doubler circuit, describing a a system with a 30 volt VC and -2.7 volt reference. It can be seen that both these sets of curves allow the use of smaller touch capacitors. Cp, than if the doubler were not used, as in the curves of Figure 6. If a still smaller $C_p$ is required, $V_C$ may be increased further by use of a separate power supply and a non-inverting buffer, as shown in Figure 9. For these higher $V_C$ values, the expressions already given for $V_{INU}$ and $V_{INT}$ can be used to determine the required $C_p$ values, keeping in mind the conditions that $V_{INU} > V_{REF} + 1.0$ volts, $V_{INT} < V_{REF} - 0.5$ volts, and $V_{REF}$ is set between - 2.5 and - 3.8 volts. For high values of $V_C$ , it is possible to use very low touch capacitors, as indicated by Figure 10. These curves plot $V_C$ vs. $C_p$ for two values of $C_S$ , 9 pFs and 14 pFs. A fixed $V_{REF}$ of - 3 volts is assumed. If $C_S = 9$ pFs, for example, it can be seen that an 8 pF $C_p$ is required for a $V_C$ of 16.0 volts, whereas raising $V_C$ to 40 volts permits the system to function with a 2 pF $C_p$ value. ### MULTIPLEXED OPERATION To permit a larger number of switches to be interfaced by a single TouchControl circuit, two parts employ a keyboard matrix approach. The S9262 uses a 2 x 7 matrix to control 14 switches, and the S9266 uses a 2 x 16 matrix to control 32 switches. As described in the section on "Keyboard Scanning," these parts provide two scan clock outputs, SC1 and SC2. Each of the "P" inputs shares two touch switches, one clocked by SC1 and the other by SC2, as shown in Figure 4. The multiplexed parts operate similarly to the non-multiplexed circuits, and the expressions and curves already presented for VINU and VINT calculations are valid for all TouchControl parts. It is important to note, however, that there are two touch capacitors connected to each input of the multiplexed devices. When one of a pair is being scanned, the other acts like two capacitors connected in series loading the input, and that load must be added to Cs. For example, if 8 pF $C_p$ capacitors are being used with a multiplexed part, and the stray capacitance developed on an input node due to the printed circuit traces is 2 pFs, then the total $C_S$ capacitance will be 6 pF (circuit's input capacitance) plus 2 pF (from P.C. traces) plus 4 pF (two 8 pF capacitors in series), or a total of $C_S = 12$ pF. When using the S9262 or S9266 multiplexed parts, attention must be paid to any unused inputs. Whereas unused inputs may be left unconnected in all nonmultiplexed devices, this is not possible with the S9262 and S9266. Two solutions exist for unused inputs on these parts. The first is to connect a capacitor between the input and the appropriate scan clock output, causing the capacitor to look like a "dummy" touch capacitor. Its value should be 0.5 $C_p$ . The other solution is to connect all unused inputs to a=5 volt supply level, which may be derived from two external resistors, each of which should be less than $2K\Omega$ . If an odd number of switches is to be unused, then at least one "dummy" capacitor is required. Available only with the S9266, a two key rollover feature is provided. This feature is selected by hard-wiring pin 17 to VDD. When selected, this feature causes the circuit to ignore two simultaneously touched switches. If switch A is selected first, and then switch B is selected, only the output associated with switch A will be observed. If A is then released while still touching B, the B output condition will occur. ### TOUCHCONTROL PANEL MATERIAL Selection of the best material for a given TouchControl panel depends on the intended application. Many materials are suitable for the panels, the main requirements being that they must have controllable thickness and dielectric constant. Some of the more common materials in use today are glass, printed circuit material, plexiglass, and polycarbonates. The use of glass as a panel material has several advantages. The first is the ability to apply conductive tin oxide coatings to a glass panel's front surface to form the touch switches. The tin oxide is then fired at a high temperature, and the result is an extremely durable TouchControl panel. The transparent property of the tin oxide coatings would permit the design of virtually invisible touch switches. Another favorable property of glass is its high dielectric constant. Though it varies depending on specific compositions, a relative dielectric constant of 8 can be achieved with glass. Plastic materials, such as plexiglass, can also be used to make TouchControl panels. These panels are lightweight and, in some cases, may be less expensive than the comparable glass panel. In place of the tin oxide coatings, various conductive inks or paints can be applied to form the switch areas on a plastic panel. These materials are not quite as durable as the tin oxide coating but appear to be durable enough for most switch panel applications. Where small switches are required, plexiglass has the disadvantage of a low dielectric constant (about half that of glass), although this often can be compensated for by use of the clock doubling methods discussed earlier. The use of polycarbonate material may be applicable for panels requiring a high impact resistance. Aside from its durability and somewhat higher cost, it behaves similarly to plexiglass. Whenever possible, the most convenient material to use for a TouchControl panel is printed circuit material. The TouchControl switches are formed by conventional etching of a standard double-sided circuit board. To avoid the problem of discoloration of the copper, it is advisable to plate the board with a nickel alloy. The advantage obtained by using a circuit board is the ability to locate all connections between the switches and the interface circuit on the rear surface of the board as a part of the etched pattern. The TouchControl circuit plugs directly into the TouchControl panel, along with other associated components. Connections from the panel to external circuitry can then be made with an edge connector. The dielectric constant of printed circuit materials is somewhat lower than glass, but this is compensated by the ability to produce much thinner circuit boards. Whereas 0.125 inches is the practical minimum glass thickness, circuit boards can be produced easily as thin as 0.031 inches. The biggest objection to the use of printed circuit touch panels is appearance. Although standard printed circuit material is often not aesthetically pleasing, it is possible through the use of decorative inks to design an attractive TouchControl panel for use in a variety of applications. Connecting TouchControl switches to the interface circuit inputs is as important a consideration as the selection of the panel material. As already stated, this task is easiest if a printed circuit touch panel is used. If glass or plastic panels are used, one method of connecting the circuitry to the panel is inserting individual contactors in a printed circuit board which is then forced up against the rear surface of the panel. It is also possible to use an edge connector into which the glass or plastic panel can be inserted. ## SEPARATION BETWEEN INPUT AND SCAN CLOCK CONDUCTORS A typical concern in the design of a TouchControl panel is the allowable spacing between the conductors that run from the switches to the interface circuit's inputs. Because of a unique feature offered by all AMI TouchControl parts, this poses less of a problem than might be anticipated. Every "I" input has an active output transistor connected to it that actually pulls that input to VSS for all times except when that input is interrogated by the scanning logic. Stated differently, whenever any input is being interrogated, all other inputs are pulled to VSS. This means that no matter how much capacitance is developed between adjacent "I" inputs, there can be no crosstalk between them to supply invalid information. It should be noted, however, that running adjacent traces or wires close together for long distances develops capacitance to ground; this capacitance must be measured and added to the stray capacitance, CS, when calculating VINU and VINT values. Since some switches will usually be farther from the circuit than others, CS may vary for different inputs. To compensate for this, it is possible to use larger rear-surface conductive areas for switches whose inputs develop higher CS capacitance, usually the switches farthest from the circuit. Note that the front surface touch switch areas can remain identical in size. A related concern involves the location of the SCI or SC2 clock outputs. These outputs contain a clock signal at all times and thus would adversely affect operation if substantial coupling developed between either output line and any "I" input. It is a good practice to keep the clock output(s) isolated from any inputs. To insure proper operation, it is necessary to keep the ratio of touch capacitor, Cp, to the capacitance developed between SC1 (or SC1) and any input greater than 20 to 1. Another related item is the allowable proximity of the two rear surface conductors of a touch switch to each other. It is necessary that a minimum amount of capacitive coupling exists between these conductors so that the clock signal is coupled through the two $C_p$ capacitors and not directly between the two rear surface conductors. The spacing between these two areas should insure that the ratio of $C_p$ to the capacitance developed between the two conductors be at least 20 to 1. For example, if the series touch capacitance, $C_p$ , is 8 pFs, there should be no more than 0.4 pFs developed between the two rear surface conductors. Two typical rear surface conductors of dimensions 0.375 inches by 0.75 inches spaces 0.188 inches apart would develop about 0.3 pFs capacitance between them. For example, Figure 15 shows an S9266 whose VBB supply pin has been tied to VSS, or +15 volts. When an output device (B0 through B4) turns on, it supplies + 15 volts to the logic gate it drives. When an output is off, the pulldown resistor R5, causes the B output to return to VDD, or 0 volts. Because of the output configuration, it is possible to use TouchControl devices to multiplex analog or digital information. Although the VBB pin would often be connected to a supply voltage, it does not need to be. It can actually be used as an output, using the 00 through 015 "output" pins as inputs. For example, if the Touch pad connected to 15 input is touched, then whatever signal is present on the 05 "output" pin is switched to the VBB pin. A specific application of this is shown in Figure 16, the TouchControl Organ. All musical frequencies are continuously generated by the S50240 top octave synthesizer and the \$10131 divider circuits. These frequencies are fed to the "0" pins on the \$9263 TouchControl devices. As the TouchControl I inputs are activated by touching the capacitive keys, the desired musical frequencies appear at the VBB "output" and are amplified. Multiple keys may be played simultaneously, making the TouchControlled organ completely polyphonic. ### **OUTPUT CONFIGURATION** Each output stage of all seven TouchControl circuits consists of a single MOS transistor, as shown in Figure 11. This is true regardless of whether the outputs are direct, as in the \$9260, \$9261, \$9263, \$9264, and \$9265, or encoded, as in the S9262 and S9266. The drain of each output transistor is connected to the appropriate output pin; the sources of all output transistors are connected in common and tied to the VBB supply pin. When an output transistor is turned on, either by the touching of a Touch pad or by the latching on of an output in the toggle mode, its output pin becomes a low impedance to the VRR supply voltage. The data sheets for these parts should be referenced to determine actual impedance values. This allows the user to define the magnitude and polarity of the output voltage swing by setting the VBB supply voltage to any desired level over the range of VSS to VDD. It should be noted that, since the outputs are open-ended (i.e., not push-pull), an external load or pullup resistor must be connected to each output and tied to whatever output level is expected when the output transistor turns off. ### TOUCHCONTROL INPUT PROTECTION All seven TouchControl interface parts have devices on all inputs to protect them from the effects of static charge that could be introduced by a charged body touching a switch. TouchControl systems in some environments, however, may be subjected to an excessive amount of static discharge that might damage the circuits. An extremely dry room with heavy carpeting would be an example of such an environment. To protect TouchControl circuits from excessive static discharge, we recommend the addition of the following external components: - 1) $-150K\Omega$ resistor in series between each touch switch and "P' input. - 2) $-10K\Omega$ resistor in series between SC1 and/or SC2 outputs and the TouchControl panel. - 3) Clamp diodes (such as 1N914) on SC1 and/or SC2 outputs. Connect anode of one diode to SC1, with its cathode connected to V<sub>SS</sub>. Connect cathode of a second diode to SC1, with its anode connected to V<sub>DD</sub>. (The S9262 and S9266 have two clock outputs, SC1 and SC2, and hence will require four diodes.) ### MECHANICAL KEYBOARD ENCODER The S9262 and S9266 can both be used as conventional mechanical keyboard encoders if capacitance switches are not required. Figure 12 shows an S9266 connected to a set of 32 mechanical switches. The capacitors in series with each normally-closed mechanical switch take the place of the $C_p$ touch capacitors that would be used in a capacitance keyboard. When switch one is opened, for example, the SC1 signal can no longer pass through the capacitor to input $I_0$ , and output code 0.00000 will appear on B outputs (AK output will equal "1"). This configuration will encode a set of 32 switches onto five binary outputs. These outputs can be wire-ored to allow the encoding of additional keys. That is, two S9266 devices could be used to encode 64 switches; their "B" outputs are connected in common, and the most significant bit is obtained from the AK output of the second S9266 circuit. A corollary to this application is a touch panel that uses some mechanical switches along with some capacitance switches. The only concern here is that the capacitor, C, should be half the value of touch capacitor, Cp. If, instead of mechanical switches, logic levels are to be used to operate the TouchControl I inputs, the mechanical switch can be directly replaced by a transmission gate. The logic level output would then be connected to the control pin of the transmission gate. ### INTERLOCKING FEATURE A feature that is desirable for a number of TouchControl applications is interlocking. As defined here, interlocking is a mode of keyboard operation in which any previously latched output is cancelled whenever a new output is selected. A typical example of this would be a TV channel selector; only a single channel would be selected at a time, and when a new channel is selected, the previously selected channel would be cancelled. The schematic in Figure 13 shows an easy method for obtaining this interlock feature. This circuit takes advantage of the fact that each time a new output is selected, more current is drawn on the $V_{\rm BB}$ supply input. The current is sensed, and a pulse is sent to the M/T input, placing the device temporarily in the momentary mode. This cancels all previously latched outputs, while retaining the newly selected output. When the M/T input returns to its normal logic 1 level ( $V_{\rm DD}$ ), the device returns to the Toggle mode, latching only the newly selected output. Referring to the schematic, resistor R1 is selected so as to cause a voltage drop of I volt whenever an output turns on. This voltage drop causes transistor Q1 to turn on, placing the device in the momentary mode and cancelling any previously latched outputs. Referring again to the schematic diagram, D1 and R5 are used to obtain a -0.6 volt bias voltage that allows D1 to hold Q1's base bias slightly negative. This enables R1 to be small enough so that $V_{BB}$ drops only I volt when an output is selected. Components D3 and R4 prevent more than one output from being latched simultaneously. This method for interlocking TouchControl switches is effective and inexpensive. It should be noted that it is applicable only on the non-multiplexed devices and that the output voltage levels will be decreased by I volt, but for most cases this approach represents an easy way to implement a desirable feature. Figure 15 shows a scheme for obtaining the interlocking feature with the S9266. Output information is latched in five CMOS latches. Whenever a new key is touched, the AK output provides a pulse to unlatch the previously latched condition. The "B" outputs latch on the newly selected output condition. AMERICAN MICROSYSTEMS, INC. 3800 Homestead Rd., Santa Clara CA 95051 Telephone: (408) 246-0330 TWX: 910-338-0018