## Signetics' Approach to Logic Flexibility for the '80's

Signetics reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Signetics assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified. Applications that are described herein for any of these products are for illustrative purposes only. Signetics makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

## LIFE SUPPORT POLICY

SIGNETICS PRODUCTS ARE NOT FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT EXPRESS WRITTEN APPROVAL OF AN OFFICER OF SIGNETICS CORPORATION. As used herein:

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

Signetics registers eligible circuits under the Semiconductor Chip Protection Act.

## Preface

Application Specific Products

The continuing trend of system integration has created new challenges for Design Engineering. They must strive to consolidate higher complexity, and more feature intensive circuits into designs without sacrificing flexibility. Today's competitive electronic marketplace has created the need for logic devices, which can provide cost effective methods of reducing random logic requirements, interface with fixed and custom LSI logic, and maintain the flexible features required to make necessary system modifications prior to production. Signetics has responded to this need with Signetics Programmable Logic Devices (Signetics PLD).

The Signetics Programmable Logic family consists of a relatively few devices which are designed to address logic needs ranging from random gates in the case of the Field Programmable Gate Arrays, to highly sophisticated state machines in the case of Field Programmable Logic Sequencers. Signetics pioneered the fully-programmable AND/OR/INVERT architecture in 1975. In 1987, Signetics will introduce a new concept in PLD architectures. Moving away from an AND-OR array structure, the Signetics' Programmable Macro Logic architecture relies on a single NAND array concept. Signetics' novel architectural approach to Programmable Logic incorporates all the advantages associated with more dense complex gate arrays while retaining all the benefits of instantly programmable PLDs. By using the programmable features allowed by either powerful architecture, Signetics Programmable Logic can encompass wide-ranging levels of integration without the necessity of a multitude of devices, each with a different I/O configuration. The flexible programming structure allows the designer to "mold" the device architecture to the range of applications typically found in system design. In this way, one device can be used to perform several functions in the same design.
The 1987 Signetics Programmable Logic Data Manual contains information that the designer will require in order to effectively utilize these products.
Signetics Application Specific Products Marketing

| DEFINITIONS |  |  |
| :---: | :---: | :--- |
| Data Sheet <br> Identification | Product Status | Definition |
| Objectlve Specification | Formative or In Design | This data sheet contains the design target or goal <br> specifications for product development. Specifications may <br> change in any manner without notice. |
| Preliminary Specification | Preproduction Product | This data sheet contains preliminary data and supplementary <br> data will be published at a later date. Signetics reserves the <br> right to make changes at any time without notice in order to <br> improve design and supply the best possible product. |
| Product Specification | Full Production | This data sheet contains Final Specifications. Signetics <br> reserves the right to make changes at any time without <br> notice in order to improve design and supply the best <br> possible product. |

## Signetics

## Contents

## Application Specific Products

Preface ..... iii
Product Status ..... iv
Section 1
Quality and Reliability ..... 1-3
Alphanumeric Index ..... 1-9
Selection Guide ..... 1-10
Ordering Information ..... 1-11
Note to Users ..... $1-12$
Section 2 - Introduction
What is Signetics' Programmable Logic ..... 2-3
Programming Information ..... 2-48
Section 3-Advanced Product Preview
PLMC153 Mask-Programmable Logic Array $(18 \times 42 \times 10)$ ..... 3-3
PLUS153 Field-Programmable Logic Array $(18 \times 42 \times 10)$. ..... 3-5
PLUS173 Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ..... 3-7
PLHS501 Programmable Macro Logic Random Logic Unit ( $32 \times 72 \times 24$ ) ..... 3-9
PLHS502 Programmable Macro Logic Sync/Async Register Macro Unit ( $32 \times 64 \times 24$ ) ..... 3-19
Section 4 - PLD̄ Data S̄heets
Series 20
PLS151 Field-Programmable Gate A.rray $(18 \times 15 \times 12)$ ..... 4-3
PLS153 Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 4-9
PLS153A Field-Programmable Logic Array $(18 \times 42 \times 10)$ ..... 4-15
PLHS153 Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 4-21
PLS155 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4-27
PLS157 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4-37
PLS159 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4-47
PLS159A Field-Programmable Logic Sequencer $(16 \times 45 \times 12)$ ..... 4-57
PLHS18P8A Programmable AND Array Logic $(18 \times 72 \times 8)$ ..... 4-67
Section 5-PLD Data Sheets
Series 24
PLS161 Field-Programmable Logic Array ( $12 \times 48 \times 8$ ) ..... 5-3
PLS162 Field-Programmable Address Decoder $(16 \times 5)$ ..... 5-9
PLS163 Field-Programmable Address Decoder $(12 \times 9)$ ..... 5-15
PLS167 Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ ) ..... 5-21
PLS167A Field-Programmable Logic Sequencer; Enhanced Speed $(14 \times 48 \times 6)$ ..... 5-33
PLS168 Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ ) ..... 5-45
PLSi68A Fieldu-Programmable Logic Sequencer; Enhanced Speed ( $12 \times 48 \times 8$ ) ..... 5-57
PLS173 Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ..... 5-69
PLS179 Field-Programmable Logic Sequencer ( $20 \times 45 \times 12$ ) ..... 5-75
PLHS473 Field-Programmable Logic Array ( $20 \times 24 \times 11$ ) ..... 5-85
PLC473 Erasable-Programmable Logic Array $(20 \times 24 \times 11)$. ..... 5-91
Section 6-PLD Data Sheets
Series 28
PLS100/PLS101 Field-Programmable Logic Array $(16 \times 48 \times 8)$ ..... 6-3
PLS103 Field-Programmable Gate Array ( $16 \times 9 \times 9$ ) ..... 6-10
PLS105 Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ ) ..... 6-16
PLS105A Fieid-Programmable Logic Sequencer ( $16 \times 48 \times 8$ ) ..... 6-27
PLUS405A Field-Programmable Logic Sequencer $(16 \times 64 \times 8)$ ..... 6-38
Section 7 - Military Products
Military Errata ..... 7-1

## Contents

Section 8 - Development Software
AMAZE - Automatic Map and Zap Equations Design Software ..... 8-3
Section 9 - Application Notes
AN7 Single Chip Multiprocessor Arbiter ..... 9-3
AN8 Introduction to Signetics Programmable Logic ..... 9-15
AN10 4-Bit Binary-to-7 Segment Decoder ..... 9-27
AN11 PLD Programmable Retriggerable One-Shot ..... 9-51
AN12 Low Cost Programmer for PLD 20-Pin Series ..... 9-55
AN13 Oscillator With PLS159 ..... 9-71
AN14 Latches and Flip-Flops With PLS153 ..... 9-76
AN15 PLS159 Primer ..... 9-89
AN16 PLS159 as Modulo Counters ..... 9-100
AN17 Electronic Combination Lock ..... 9-107
AN18 Schmitt Trigger Using PLS153 and PLS159 ..... 9-110
AN19 Electronic Dice ..... 9-118
AN2O Single Pin Debouncer Using PLS153/159 ..... 9-122
AN21 9-Bit Parity Generator/Checker With PLS153/153A ..... 9-125
AN22 PLS151 Tookkit ..... 9-131
AN23 PLS168/168A Primer ..... 9-139
AN24 PLS173 as a 10 -Bit Comparator, 74LS460 ..... 9-152
AN25 A Simple Entry/Exit Meeting Device (PLS157) ..... 9-158
AN26 PLHS18P8A Primer ..... 9-164
AN27 PLHS473 Primer ..... 9-172
AN28 High-Speed 12-Bit Tracking A/D Converter Using PLS179 ..... 9-180
AN29 PLHS501 Programmable Macro Logic Primer ..... 9-190
Section 10 - Package Outlines
Package Outlines
A PLASTIC: Leaded Chip Carrier ..... 10-3
F CERAMIC: Dual-In-Line ..... 10-5
FA CERAMIC: Dual-In-Line With Quartz Window ..... 10-7
N PLASTIC: Dual-In-Line ..... 10-9
Section 11-Sales Offices Office Listing ..... 11-3

## INDEX

## Section 1

Quality and Reliability ..................................................................... 1-3
Alphanumeric Index ............................................................................ $1-9$
Selection Guide ............................................................................... 1-10
Ordering Information .......................................................................... 1-11
Note to Users.................................................................................... 1-12

## Application Specific Products

## SIGNETICS PROGRAMMABLE LOGIC QUALITY

Signetics has put together winning processes for manufacturing Programmable Logic. Our standard is zero defects, and current customer quality statistics demonstrate our commitment to this goal.
The PLD's produced in the Application Specific Products Division must meet rigid criteria as defined by our design rules and as evaluated with a thorough product characterization and quality process. The capabilities of our manufacturing process are measured and the results evaluated and reported through our corporate-wide QA05 data base system. The SURE (Systematic Uniform Reliability Evaluation) program monitors the performance of our product in a variety of accelerated environmental stress conditions. All of these programs and systems are intended to prevent product-related problems and to inform our customers and employees of our progress in achieving zero defects.

## RELIABILITY BEGINS WITH THE DESIGN

Quality and reliability must begin with design. No amount of extra testing or inspection will produce reliable ICs from a design that is inherently unreliable. Signetics follows very strict design and layout practices with its circuits. To eliminate the possibility of metal migration, current density in any path cannot exceed $2 \times 10^{5} \mathrm{amps} / \mathrm{cm}^{2}$. Layout rules are followed to minimize the possibility of shorts, circuit anomalies, and SCR type latch-up effects. Numerous ground-to-substrate connections are required to ensure that the entire chip is at the same ground potential, thereby precluding internal noise problems.

## PRODUCT CHARACTERIZATION

Before a new design is released, the characterization phase is completed to insure that the distribution of parameters resulting from lot-to-lot variations is well within specified limits. Such extensive characterization data
also provides a basis for identifying unique application-related problems which are not part of normal data sheet guarantees. Characterization takes place from $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ and at $+10 \%$ supply voltage.

## QUALIFICATION

Formal qualification procedures are required for all new or changed products, processes and facilities. These procedures ensure the high level of product reliability our customers expect. New facilities are qualified by corporate groups as well as by the quality organizations of specific units that will operate in the facility. After qualification, products manufactured by the new facility are subjected to highly accelerated environmental stresses to ensure that they can meet rigorous failure rate requirements. New or changed processes are similarly qualified.

## QA05 - QUALITY DATA BASE REPORTING SYSTEM

The QA05 data reporting system collects the results of product assurance testing on all finished lots and feeds this data back to concerned organizations where appropriate action can be taken. The QA05 reports EPQ (Estimated Process Quality) and AOQ (Average Outgoing Quality) results for electrical, visual/mechanical, hermeticity, and documentation audits. Data from this system is available on request.

## THE SURE PROGRAM

The SURE (Systematic Uniform Reliability Evaluation) program audits/monitors products from all Signetics' divisions under a variety of accelerated environmental stress conditions. This program, first introduced in 1964, has evolved to suit changing product complexities and performance requirements.
The SURE program has two major functions: Long-term accelerated stress performance audit and a short-term accelerated stress monitor. In the case of Bipolar Memory and Programmable Logic products, samples are
selected that represent all generic product groups in all wafer fabrication and assembly locations.

## THE LONG-TERM AUDIT

One-hundred devices from each generic family are subjected to each of the following stresses every eight weeks:

- High Temperature Operating Life: $T_{J}=150^{\circ} \mathrm{C}, 1000$ hours, static biased or dynamic operation, as appropriate (worst case bias configuration is chosen)
- High Temperature Storage: $T_{J}=150^{\circ} \mathrm{C}$, 1000 hours
- Temperature Humidity Biased Life: $85^{\circ} \mathrm{C}$, $85 \%$ relative humidity, 1000 hours, static biased
- Temperature Cycling (Air-to-Air): $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}, 1000$ cycles


## THE SHORT-TERM MONITOR

Every other week a 50 -piece sample from each generic family is run to 168 hours of pressure pot ( $15 \mathrm{psig}, 121^{\circ} \mathrm{C}, 100 \%$ saturated steam) and 300 cycles of thermal shock $\left(-65^{\circ} \mathrm{C}\right.$ to $\left.+150^{\circ} \mathrm{C}\right)$.

In addition, each Signetics assembly plant performs SURE product monitor stresses weekly on each generic family and molded package by pin count and frame type. Fiftypiece samples are run on each stress, pressure pot to 96 hours, thermal shock to 300 cycles.

## SURE REPORTS

The data from these test matrices provides a basic understanding of product capability, an indication of major failure mechanisms and an estimated failure rate resulting from each stress. This data is compiled periodically and is available to customers upon request.

Many customers use this information in lieu of running their own qualification tests, thereby eliminating time-consuming and costly additional testing.

## Quality and Reliability

## RELIABILITY ENGINEERING

In addition to the product performance monitors encompassed in the Programmable Logic SURE program, Signetics' Corporate and Division Reliability Engineering departments sustain a broad range of evaluation and qualification activities.

Included in the engineering process are:

- Evaluation and qualification of new or changed materials, assembly/wafer-fab processes and equipment, product designs, facilities and subcontractors.
- Device or generic group failure rate studies.
- Advanced environmental stress development.
- Failure mechanism characterization and corrective action/prevention reporting.

The environmental stresses utilized in the engineering programs are similar to those utilized for the SURE monitor; however, more highly-accelerated conditions and extended durations typify the engineering projects. Additional stress systems such as biased pressure pot, power-temperature cycling, and cy-cle-biased temperature-humidity, are also included in the evaluation programs.

## FAILURE ANALYSIS

The SURE Program and the Reliability Engineering Program both include failure analysis activities and are complemented by corporate, divisional and plant failure analysis departments. These engineering units provide a service to our customers who desire detailed failure analysis support, who in turn provide Signetics with the technical understanding of the failure modes and mechanisms actually experienced in service. This information is essential in our ongoing effort to accelerate and improve our understanding of product failure mechanisms and their prevention.

## ZERO DEFECTS PROGRAM

In recent years, United States industry has increasingly demanded improved product quality. We at Signetics believe that the customer has every right to expect quality products from a supplier. The benefits which are derived from quality products can be summed up in the words, lower cost of ownership.

Those of you who invest in costly test equipment and engineering to assure that incoming products meet your specifications have a special understanding of the cost of ownership. And your cost does not end there; you are also burdened with inflated inventories, lengthened lead times and more rework.

## SIGNETICS UNDERSTANDS CUSTOMERS' NEEDS

Signetics has long had an organization of quality professionals, inside all operating units, coordinated by a corporate quality department. This broad decentralized organization provides leadership, feedback, and direction for achieving a high level of quality. Special programs are targeted on specific quality issues. For example, in 1978 a program to reduce electrically defective units for a major automotive manufacturer improved outgoing quality levels by an order of magnitude.
In 1980 we recognized that in order to achieve outgoing levels on the order of 100PPM (parts per million), down from an industry practice of $10,000 \mathrm{PPM}$, we needed to supplement our traditional quality programs with one that encompassed all activities and all levels of the company. Such unprecedent-
ed low defect levels could only be achieved by contributions from all employees, from the R and D laboratory to the shipping dock. In short, from a program that would effect a total cultural change within Signetics in our attitude toward quality.

## QUALITY PAYS OFF FOR OUR CUSTOMERS

Signetics' dedicated programs in product quality improvement, supplemented by close working relationships with many of our customers, have improved outgoing product quality more than twenty-fold since 1980. Today, many major customers no longer test Signetics circuits. Incoming product moves directly from the receiving dock to the production line, greatly accelerating throughput and reducing inventories. Other customers have pared significantly the amount of sampling done on our products. Others are beginning to adopt these cost-saving practices.

We closely monitor the electrical, visual, and mechanical quality of all our products and review each return to find and correct the cause. Since 1981, over $90 \%$ of our customers report a significant improvement in overall quality (see Figure 1).


Figure 1. Signetics Quality Progress


Figure 2. Performance To Schedule On-Time Delivery

At Signetics, quality means more than working circuits. It means on-time delivery of the right product at the agreed upon price (see Figure 2). Signetics considers Performance to Customer Request and Performance to Original Schedule Date to be key Quality issues. Employees treat delinquencies as quality defects. They analyze the cause for the delinquency and seek corrective action to prevent future occurance. Continuous effort is given to try to acheive the ultimate goal of zero delinquencies.

## ONGOING QUALITY PROGRAM

The quality improvement program at Signetics is based on "Do it Right the First Time'. The intent of this innovative program is to change the perception of Signetics' employees that somehow quality is solely a manufacturing issue where some level of defects is inevitable. This attitude has been replaced by one of acceptance of the fact that all errors and defects are preventable, a point of view shared by all technical and administrative functions equally.

This program extends into every area of the company, and more than 40 quality improvement teams throughout the organization drive its ongoing refinement and progress.

Key components of the program are the Quality College, the "Make Certain' Program, Corrective Action Teams, and the Error Cause Removal System.

The core concepts of doing it right the first time are embodied in the four absolutes of quality:

1. The definition of quality is conformance to requirements.
2. The system to achieve quality improvement is prevention.
3. The performance standard is zero defects.
4. The measurement system is the cost of quality.

## QUALITY COLLEGE

Almost continuously in session, Quality College is a prerequisite for all employees. The intensive curriculum is built around the four absolutes of quality; colleges are conducted at company facilities throughout the world.

## "MAKING CERTAIN" ADMINISTRATIVE QUALITY IMPROVEMENT

Signetics' experience has shown that the largest source of errors affecting product and service quality is found in paperwork and in other administrative functions. The "Make Certain' program focuses the attention of management and administrative personnel on error prevention, beginning with each employ. ee's own actions.

This program promotes defect prevention in three ways: by educating employees as to the impact and cost of administrative errors, by changing attitudes from accepting occasional errors to one of accepting a personal work standard of zero defects, and by providing a formal mechanism for the prevention of errors.

## CORRECTIVE ACTION TEAMS

Employees with the perspective, knowledge, and necessary skills to solve a problem are formed into ad hoc groups called Corrective Action Teams. These teams, a major force within the company for quality improvement, resolve administrative, technical and manufacturing problems.

## ECR SYSTEM (ERROR CAUSE REMOVAL)

The ECR System permits employees to report to management any impediments to doing the job right the first time. Once such an impediment is reported, management is obliged to respond promptly with a corrective program. Doing it right the first time in all company activities produces lower cost of ownership through defect prevention.

## PRODUCT QUALITY PROGRAM

To reduce defects in outgoing products, we created the Product Quality Program. This is managed by the Product Engineering Council, composed of the top product engineering and test professionals in the company. This group:

1. Sets aggressive product quality improvement goals;
2. provides corporate-level visibility and focus on problem areas;
3. serves as a corporate resource for any group requiring assistance in quality improvement; and
4. drives quality improvement projects.

As a result of this aggressive program, every major customer who reports back to us on product performance is reporting significant progress.

## VENDOR CERTIFICATION PROGRAM

Our vendors are taking ownership of their own product quality by establishing improved process control and inspection systems. They subscribe to the zero defects philosophy. Progress has been excellent.

## Quality and Reliability



Figure 3. Lot Acceptance Rate From Signetics Vendors

Through intensive work with vendors, we have improved our lot acceptance rate on incoming materials as shown in Figure 3. Simultaneously, waivers of incoming material have been eliminated.

## MATERIAL WAIVERS

1986-(0) (Goal)
1985- 0
1984- 0
1983- 0
1982- 2
1981-134
Higher incoming quality material ensures higher outgoing quality products.

## QUALITY AND RELIABILITY ORGANIZATION

Quality and reliability professionals at the divisional level are involved with all aspects of the product, from design through every step in the manufacturing process, and provide product assurance testing of outgoing product. A separate corporate-level group provides direction and common facilities.

Quality and Reliability Functions

- Manufacturing quality control
- Product assurance testing
- Laboratory facilities - failure analysis,
chemical, metallurgy, thin film, oxides
- Environmental stress testing
- Quality and reliability engineering
- Customer liaison


## COMMUNICATING WITH EACH OTHER

For information on Signetics' quality programs or for any question concerning product quality, the field salesperson in your area will provide you with the quickest access to answers. Or, write on your letter-head directly to the corporate director of quality at the corporate address shown at the back of this manual.

We are dedicated to preventing defects. When product problems do occur, we want to know about them so we can eliminate their causes. Here are some ways we can help each other:

- Provide us with one informed contact within your organization. This will establish continuity and build confidence levels.
- Periodic face-to-face exchanges of data and quality improvement ideas between your engineers and ours can help prevent problems before they occur.
- Test correlation data is very useful. Line-pull information and field failure reports also help us improve product performance.
- Provide us with as much specific data on the problem as soon as possible to speed analysis and enable us to take corrective action.
- An advance sample of the devices in question can start us on the problem resolution before physical return of shipment.

This team work with you will allow us to achieve our mutual goal of improved product quality.

## MANUFACTURING: DOING IT RIGHT THE FIRST TIME

In dealing with the standard manufacturing flows, it was recognized that significant improvement would be achieved by "doing every job right the first time", a key concept of the quality improvement program. During the development of the program many profound changes were made. Figure 4, Programmable Logic Process Flow, shows the result. Key changes included such things as implementing $100 \%$ temperature testing on all products as well as upgrading test handiers to insure $100 \%$ positive binning. Some of the other changes and additions were to tighten the outgoing QA lot acceptance criteria to the tightest in the industry, with zero defect lot acceptance sampling across all three temperatures.

The achievements resulting from the improved process flow have helped Signetics to be recognized as the leading Quality supplier of Programmable Logic. These achievements have also led to our participation in several Ship-to-Stock programs, which our customers use to eliminate incoming inspection. Such programs reduce the user cost of ownership by saving both time and money.

## OUR GOAL: 100\% PROGRAMMING YIELD

Our original goal back in the early 1970s was to develop a broad line of programmable products which would be recognized as having the best programming yield in the industry. Within the framework of a formal quality program, our efforts to improve circuit designs and refine manufacturing controls have resulted in major advances toward that goal.

Also within the framework of our formal quality program we have now established a stated goal of $100 \%$ programming yield. Through the increasing effectiveness of a quality attitude of "Do it Right The First Time" we're moving ever closer to that target.

Signetics PLD programming yields have been shown in collected data from internal audits and customer reporting to be consistently higher than comparable devices produced by our competition. We use systematic methods involving publication of exacting specifications of our programming algorithms, and through evaluation of those algorithms as implemented in industry standard programming equipment. Because of this we can assure our customers who program Signetics PLD's on such qualified equipment they will see consistently high yields. Our data base shows that average lot programming yield exceeds $97 \%$.

## Quality and Reliability

As time goes on the drive for a product line that has Zero Defects will grow in intensity. These efforts will provide both Signetics and our customers with the ability to achieve the mutual goal of improved product quality.
The Application Specific Quality Assurance department has monitored PPM progress, which can be seen in Figure 5. We are pleased with the progress that has been made, and expect to achieve even more impressive results as the procedures for accomplishing these tasks are fine tuned.

The real measure of any quality improvement program is the result that our customers see. The meaning of Quality is more than just working circuits. It means commitment to On Time Delivery at the Right Place of the Right Quantity of the Right Product at the Agreed Upon Price.

## Alphanumeric Index

## Application Specific Products

AN7 Single Chip Multiprocessor Arbiter ..... 9-3AN8AN10AN11AN12
AN13AN14
AN15
AN16
AN17
AN18
AN19
AN20
AN21AN22
AN23
AN24
AN25
AN26
AN27
AN28
AN2s
PLC473

Series 24
PLHS153
PLHS473
PLHS501PLHS502PLHS18P8A
PLMC153
PLS100/PLS101
PLS103
PLS105
PLSi05A
PLS151
PLS153
PLS153A
PLS155
PLS157
PLS159
PLS159A
PLS161
PLSi62
PLS163
PLS167
PLS167A
PLS168
PLS168A
PLS173
PLS179
PLUS153
PLUS173
PLUS405A

Series 20
Series 24
Series 52
Series 52
Series 20
Series 20
Series 28
Series 28
Series 28
Series 28
Series 20
Series 20
Series 20
Series 20
Series 20
Series 20
Series 20
Series 24
Series 24
Series 24
Series 24
Series 24
Series 24
Series 24
Series 24
Series 24
Series 20
Series 24
Series 28
Introduction To Signetics Programmable Logic ..... 9-15
4-Bit Binary-To-7 Segment Decoder ..... 9-27
PLD Programmable Retriggerable One-Shot ..... 9-51
Low Cost Programmer For PLD 20-Pin Series ..... 9-55
Oscillator With PLS159 ..... 9-71
Latches \& Flip-Flops With PLS153 ..... 9-76
PLS159 Primer ..... 9-89
PLS159 As Modulo Counters ..... 9-100
Electronic Combination Lock ..... 9-107
Schmitt Trigger Using PLS153 and PLS159 ..... 9-110
Electronic Dice ..... 9-118
Single Pin Debouncer Using 82S153/159 ..... 9-122
9-Bit Parity Generator/Checker With 82S153/153A ..... $9-125$
PLS151 Tookit ..... 9-131
PLS168/168A Primer ..... 9-139
PLS173 As A 10-Bit Comparator, 74LS460 ..... 9-152
A Simple Entry/Exit Meeting Device (PLS157) ..... 9-158
PLHS18P8A Primer ..... 9-164
PLHS473 Primer ..... 9-172
High-Speed 12-Bit Tracking A/D Converter Using PLS179 ..... 9-180
PLHS501 Programmable Macro Logic Primer ..... 9-191
Erasable-Programmable Logic Array $(20 \times 24 \times 11)$ ..... $5-91$
Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 4-21
Field-Programmable Logic Array $(20 \times 24 \times 11)$ ..... 5-85
Programmable Macro Logic Random Logic Unit ( $32 \times 72 \times 24$ ) ..... 3-9
Programmable Macro Logic Sync/Async Register Macro Unit ( $32 \times 64 \times 24$ ) ..... 3-19
Programmable AND Array Logic ( $18 \times 72 \times 8$ ) ..... 4-67
Mask-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 3-3
Field-Programmable Logic Array $(16 \times 48 \times 8)$ ..... 6-3
Field-Programmable Gate Array ( $16 \times 9 \times 9$ ) ..... 6-10
Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ ) ..... 6-16
Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ ) ..... 6-27
Field-Programmable Gate Array ( $18 \times 15 \times 12$ ) ..... 4.3
Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 4-9
Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 4-15
Field-Programmable Logic Sequencer $(16 \times 45 \times 12)$ ..... 4-27
Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4-37
Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4.47
Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) ..... 4-57
Field-Programmable Logic Array $(12 \times 48 \times 8)$ ..... 5-3
Field-Programmable Address Decoder $(16 \times 5)$ ..... 5-9
Field-Programmable Address Decoder ( $12 \times 9$ ) ..... 5-15
Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ ) ..... 5-21
Field-Programmable Logic Sequencer; Enhanced Speed ( $14 \times 48 \times 6$ ) ..... 5-33
Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ ) ..... 5-45
Field-Programmable Logic Sequencer; Enhanced Speed ( $12 \times 48 \times 8$ ) ..... 5-57
Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ..... 5-69
Field-Programmable Logic Sequencer ( $20 \times 45 \times 12$ ) ..... 5-75
Field-Programmable Logic Array $(18 \times 42 \times 10)$ ..... 3-5
Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ..... 3-7
Field-Programmable Logic Sequencer ( $16 \times 64 \times 8$ ) ..... 6-38

Application Specific Products


## OUTPUTS:

$\mathrm{C}=$ Combinatorial output
$\mathrm{R}=$ Registered output
I/O = Combinatorial I/O
R $/ / O=$ Registered $/ / O$

* State registers shared with output registers
** Under development
NOTES:

1. $T_{P D}=T_{I S}+T_{C K O}$ for registered devices
2. For worst case specifications refer to data sheets for individual product.

## Application Specific Products

Signetics Programmable Logic Devices may be ordered by contacting either the local Signetics sales office, Signetics representatives or authorized distributors. A complete listing is located in the back of this manual.

Table 1 provides part number definition for Signetics PLD's. The Signetics part number system allows complete ordering information to be specified in the part number. The part number and product
description is located on each data sheet.

Military versions of these commercial products may be ordered. Please refer to the military products data manual for complete ordering information.

Table 1. New Signetics PLD Part Numbering System


## Signetics

## Note To Users Of 82SXXX Part Numbering System

## Application Specific Products

Signetics has changed its part numbering system for Programmable Logic Products. The change is simple and straightforward. Simply replace the old temperature code and '' 82 ' Bipolar Memory designator with "PL." This change in part numbering has been done to create a unique, identifiable image for Signetics Programmable Logic

Products. As we continue to introduce PLD's with new features, processes, and fusing technology, the new system will allow us to better describe these products through the product part number. In addition, more critical information can be placed on the device itself even when plastic leaded chip carriers are used. The new part number system does not
indicate any change in process or technology has occurred. The only thing changing is the nomenclature.
We sincerely hope this necessary change causes no inconveniences to our many customers. Thank you for your loyalty.

## PART NUMBERING EXAMPLES

| OLD PART NUMBER | NEW PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| N82S100N | PLS100N | Signetics Programmable Logic Field Programmable Logic Array (FPLA) Bipolar Schottky Process - Nichrome Fuses -28-Lead Dual-in-Line Package. |
| N82S105AA | PLS105AA | Signetics Programmable Logic Field Programmable Logic Sequencer (FPLS) Bipolar Schottky Process - Nichrome Fuses - High Speed Option -28-Lead Plastic Leaded Chip Carrier. |
| N/A | PLC473FA | Signetics Programmable Logic Field Programmable Logic Array (FPLA) CMOS - UV Erasable Fuses - <br> 24-Lead Cerdip Dual-In-Line Package with quartz window. |
| N/A | PLMC153F | Signetics Programmable Logic Programmable Logic Array CMOS - Mask Programmable -20-Lead Cerdip Dual-In-Line Package. |
| N/A | PLHS18P8AA | Signetics Programmable Logic Field Programmable Array Oxide Isolated, Bipolar-Vertical Fuses - High Speed Option -20-Pin Plastic Leaded Chip Carrier. |

This change affects commercial product only.

## Section 2

 IntroductionSection 2 - Introduction
What is Signetics' Programmable Logic ................................................ 2-3
Programming Information ................................................................... 2-48

## Signetics

## Application Specific Products

## WHAT IS PROGRAMMABLE LOGIC

In 1975, Signetics Corporation developed a new product family by combining its expertise in semi-custom gate array products and fuse-link Programmable Read Only Memories (PROMs). Out of this marriage came Signetics Programmable Logic Family. The PLS100 FieldProgrammable Logic Array (FPLA) was the first member of this family. The FPLA was an important industry first in two ways. First, the AND/OR/INVERT architecture allowed the custom implementations of Sum of Product logic equations. Second, the three-level fusing allows complete flexibility in the use of this device family. All logic interconnections from input to output are programmable.

## Introduction

Signetics Programmable Logic

Development of this family did not stop with the PLS100. In 1977, the PLS103 Field-Programmable Gate Array (FPGA) and the PLS107 Field-Programmable ROM Patch (FPRP) were introduced.
The PLS105 Field-Programmable Logic Sequencer (FPLS) was announced in 1979. This device represents a significant step forward for PLD. The FPLS is a fully-implemented Mealy State Machine on a chip. Incorporated into its architecture are 48 P-terms, an 8 -bit Output Register, and a 6-bit internal State Register. Reference Figure 1.

The FPLS can synchronously perform sequential routines at 20 MHz . All of these products are now known as the Signetics PLD Series 28 Programmable Logic Family.

Signetics' next innovation in this area was the Series 20 Programmable Logic Family. All members of this family are assembled in 20 -pin packages. While reducing the number of pins in this family, Signetics has utilized controlled I/O in order to maintain the utility of the Series 20. Appropriate control terms have been included to allow active control of pin direction. Reference Figure 2.
The latest addition to the Signetics Programmable Logic families is the Series 24 devices. The PLS161 FPLA and the PLS167 FPLS are 24-pin devices comparable to the 28 -pin PLS100 and PLS105 respectively. These devices have been followed by the PLS162/ PLS163 Field-Programmable Address Decoder and the PLS168 FPLS.


B001900S

NOTE:
I, P, C, N, F and P/E are user-programmable connections.
Figure 1. FPLS

Table 1. PLD Product Family

| 20-PIN, SERIES 20 |  |  |
| :---: | :---: | :---: |
| PART NUMBER | TYPE | CONFIGURATION |
| PLS151 | FPGA | 18-Input/12-Output |
| PLS153/153A/PLHS153 | FPLA | 18-Input/10-Output - 42-Term |
| PLS155-159 | FPLS | 16-Input/12-Output - 45 -Term |
| PLS155 | FPLS | 4 Registered Outputs |
| PLS157 | FPLS | 6 Registered Outputs |
| PLS159 | FPLS | 8 Registered Outputs |
| PLHS18P8A | FPAA | 18-Input/10-Output-72-Term |
| 24-PIN, SERIES 24 |  |  |
| PLS161 | FPLA | 12-Input/8-Output - 48-Term |
| PLS162 | FPGA | 16-Input/5-Output |
| PLS163 | FPGA | 12-Input/9-Output |
| PLS167 | FPLS | 14-Input/6-Output-48-Term |
|  |  | 8 -Bit State Registers |
| PLS168 | FPLS | 12-Input/8-Output-48-Term |
|  |  | 10-Bit State Registers |
|  |  | 8-Output Registers |
| PLS173/PLUS173 | FPLA | 22-Input/10-Output - 42-Term |
| PLS179 | FPLS | 16-Input/12-Output - 42-Term |
|  |  | 8 -Bit State and Output Registers |
| PLHS473/PLC473 | FPLA | 20-Inputs/11-Output - 24 -Term |
| 28-PIN, SERIES 28 |  |  |
| PLS100/101 | FPLA | 16-Inputs/8-Output - 48-Term |
| PLS103 | FPGA | 16-Inputs/9-Output |
| PLS105/105A/PLC105 | FPLS | 16-Inputs/8-Output - 48-Term |
|  |  | 6 -Bit State Register |
|  |  | 8-Output Registers |
| PLUS405 | FPLS | 16-Inputs/8-Outputs -64 -Terms 8 -Bit State and Output Registers |



Figure 2. PLS153 20-Pin Functional Diagram


LD02410S
$74502 \times 2 \times 2$ Fixed Interconnections Dual, 2-Wide, 2-Input, AND/OR/INVERT


LD02420S
PLS100 $16 \times 48 \times 8$ Octal, 48-Wide, 16 -Input, AND/OR/INVERT
Table 2. Gate Replacement (All Terms Used)

|  | Gates | I.C.s |
| ---: | ---: | :---: |
| Each P-Term = 2 8-Input AND Gates \& 1 2-Input AND Gate $=$ | 144 | 108 |
| OR Matrix $=16$ 4-Input OR Gates $=$ | $\frac{128}{272}$ | $\frac{32}{140}$ |

Table 3. Typical Application

| 4 Variables/P-Term | 40 Gates |
| :--- | :--- |
| 4 P-Terms/Output | $15-20$ I.C.s |

## PRODUCT DESCRIPTION

While all PLD devices are architecturally similar, the Field-Programmable Logic Array is most representative of the concepts involved. The FPLA is an AND/OR/IINVERT device, with all internal interconnections programmable via fuse links. If we compare the PLS100 FPLS to the familiar 7450 AOI gate, the similarity of function becomes apparent.

## Package-Gate Replacement

## Potential

All Signetics PLD devices are capable of replacing multiple discrete logic devices. The number of packages is dependent on the application and the device used.

If all product terms and inputs on the PLS100 are utilized, a total of 272 gates and 140 I.C.s can theoreticaily be replaced. (See Tabie 2.) Since the PLS100 is made up of logic structures which are not available as commercial logic devices, such as 32 input AND gates and 48 input OR gates, these numbers are based on breakdowns of these high complexity logic structures into structures which are available as discrete logic.

The typical application does not fully utilize the FPLA, however. We can assume that the typical application is as defined in Table 3.

The replacement of 15-20 I.C.s with one PLS100 is not unusual.

## PLD ECONOMICS

The reason any product line exists is because it solves a problem in a cost-effective manner.

PLD is no different in this respect. Let's assume that one PLS100 is replacing only 10 TTL logic packages.

If we assume that the average selling price of an SSI level device is $\$ 0.25$, then we have a basis for comparison.

$$
\begin{aligned}
& 10 \text { I.C.s © } 0.35=\$ 3.50 \\
& 1 \text { PLS } 100 \text { FPLA }=\$ 7.00
\end{aligned}
$$

Considering piece-part cost alone does not fare well for the PLS100 FPLA. But, part cost is one of the smaller costs in systems manufacturing. Let's next consider PC board costs.

## PC BOARD

The purchase price of a PCB is calculated on a per square inch basis. Typical costs at the 5 K level are $\$ 0.23 / \mathrm{in}^{2}$, the cost for LS is $1.2 \mathrm{in}^{2}=\$ 0.23 / \mathrm{in}^{2}=\$ 0.28$. For a 28 -pin FPLA device, the packing density is

1-PLS100 per $2.5 \mathrm{in}^{2}$, giving a cost of $2.5 \mathrm{in}^{2} \times \$ 0.23 / \mathrm{in}^{2}=\$ 0.58$.

## PCB FABRICATION

Now let's consider the cost of building the board. The primary cost for PCB fabrication is parts preparation and stuffing.
Estimates by PCB manufacturers indicate a nominal cost of $\$ 0.14$ per device for LS TTL and $\$ 0.16$ for 28 -pin FPLA. There is also a basic cost of $\$ 0.02$ per in ${ }^{2}$ for handling, soldering, and inspecting.
The cost of incoming inspection and inventory/usage must also be considered in any fair comparison.

## INCOMING INSPECTION

The cost of incoming inspection can be calculated on a per-pin basis. Assuming an equal mix of 14- and 16-pin SSI parts and a testing cost of $\$ 0.01$ per pin, the LS TTL cost is $\$ 0.15$ per I.C. The corresponding cost for

Table 4. Cost Analysis

| IC COMPONENTS | LS TTL | FPLA |
| :--- | :---: | :---: |
| PCB MANUFACTURING | .35 | 7.00 |
| Incoming Inspection |  |  |
| Component Inventory/Usage | .15 | .28 |
| PC Board | .03 | .16 |
| Fabrication | .28 | .58 |
| Test | .14 | .16 |
| Rework | .18 | .45 |
| ASSEMBLY LABOR | .28 | .18 |
| COST PER COMPONENT | 1.50 | 10 |
| NUMBER OF COMPONENTS | 15.00 | 9.46 |
| TOTAL |  | 9.46 |
| CONCLUSION: |  |  |
| THE FPLA is a 37\% savings over the LS TTL DESIGN. |  |  |

the PLS100 would be $\$ 0.01 \times 28$ or $\$ 0.28$ total.

## COMPONENT INVENTORY/ USAGE

The inventory cost for LS TTL parts is dominated by inventory maintenance, while the LSI type parts, the piece price dominates. Assuming a $2 \%$ usage rate due to parts breakage, burnout, etc., in the manufacturing process, the parts cost for LS TTL is $2 \% \times \$ 0.25=\$ 0.005$. Adding $\$ 0.02$ per device for inventory maintenance, the total LS cost $\$ 0.03$. For FPLA, $2 \%=\$ 7.00 \pm$ $\$ 0.02=\$ 0.16$.

Consideration must also be given to testing the completed PCB and Rework costs.

## PCB TESTING

Testing costs are generally figured on a PCB basis and are usually go-no-go tests using a "bed of nails". For this comparison, assume a PCB of $5^{\prime \prime} \times 7^{\prime \prime}$. The cost for testing the completed PCB is estimated to be $\$ 3.60$ for 20 I.C.s. This breaks down as $\$ 0.18$ per LS TTL device or about $\$ 0.45$ per FPLA device.

## PCB REWORK

The main causes of rework are poorly plated holes, solder bridges, and parts inserted incorrectly. The "bed of nails" test can usually detect all of the faults. Rework costs about $50 \%$ of test costs. The result is $\$ 1.80$ per PCB, or $\$ 0.09$ per device for LS TLL and $\$ 0.18$ for the 28 -pin FPLA.

System manufacturing costs are harder to define. For this comparison we estimated $\$ 0.28$ for each LS device and about $\$ 0.65$ for the FPLA. These costs include backplane wiring, final system assembly and test costs.

Now using these figures, the comparison in Table 4 can be made.

Signetics Programmable Logic

## PLD LOGIC SYNTHESIS

28-PIN
PLD is capable of Logic Synthesis. No intermediate step is required to implement Bool-
ean Logic Equations with PLD. Each term in each equation simply becomes a direct entry into the Logic Program Table. The following example illustrates this straightforward concept:
$X_{0}=A B+\bar{C} D+B \bar{D}$
$\bar{X}_{1}=\bar{A} B+\bar{C} D+E F G$


Figure 3. Field-Programmabie Logic Array $(16 \times 48 \times 8)$ PLS100/PLS101


Figure 4. Equivalent Fixed Logic Diagram

In the previous example, the two Boolean Logic equations were broken into Product terms. Each P-term was then programmed into the P-term section of the PLS100 FPLA

Program Table. This was accomplished in the following manner:
Step 1
Select which input pins $I_{0}-I_{15}$ will correspond to the input variables. In this case

A - $G$ are the input variable names. $I_{6}$ through $I_{0}$ were selected to accept inputs $A-G$ respectively.


Figure 5

## Step 2

Transfer the Boolean Terms to the FPLA Program Table. This is done simply by defining each term and entering it on the Program Table.

This P-term translates to the Program Table by selecting $A=I_{6}=H$ and $B=I_{5}=H$ and entering the information in the appropriate column.

$$
P_{1}=\bar{C} D
$$

This term is defined by selecting $\mathrm{C}=\mathrm{I}_{4}=\mathrm{L}$ and $D=I_{3}=H$, and entering the data into the Program Table. Continue this operation until all P-terms are entered into the Program Table.
e.g., $P_{0}=A B$


Figure 6

## Step 3

Select which output pins correspond to
each output function. In this case $\mathrm{F}_{0}=\mathrm{Pin}$
$18=X_{0}$, and $F_{1}=\operatorname{Pin} 17=X_{1}$.


Figure 7

Step 4
Select the Output Active Level desired for each Output Function. For $X_{0}$ the active
level is high for a positive logic expression of this equation. Therefore, it is only necessary to place an $(\mathrm{H})$ in the Active Level box above Output Function 0, ( $\mathrm{F}_{0}$ ). Conversely, $\mathrm{X}_{1}$ can
be expressed as $\bar{X}_{1}$ by placing an (L) in the Active Level box above Output Function 1, ( $\mathrm{F}_{1}$ ).

T8018825


Figure 8

## Step 5

Select the P-Terms you wish to make active for each Output Function. In this case $X_{0}=P_{0}+P_{1}+P_{2}$, so an $A$ has been placed in the intersection box for $P_{0}$ and $X_{0}$, $P_{1}$ and $X_{0}$ and $P_{2}$ and $X_{0}$.

Terms which are not active for a given output are made inactive by placing a ( $\odot$ ) in the box under that P-term. Leave all unused P-terms unprogrammed.
Continue this operation until all outputs have been defined in the Program Table.

## Step 6

Enter the data into a Signetics approved programmer. The input format is identical to the Signetics Program Table. You specify the P-terms, Output Active Level, and which Pterms are active for each output exactly the way it appears on the Program Table.


TB01861S
Figure 9

## PLD LOGIC SYNTHESIS

## 20-PIN

When fewer inputs and outputs are required in a logic design and low cost is most imporianti, the Signetics 20 -pin PLD shouid be
considered first choice. The PLS153 is an FPLA with 8 inputs, $10 \mathrm{I} / 0$ pins, and 42 product terms. The user can configure the device by defining the direction of the $/ / O$ pins. This is easily accomplished by using the direction control terms $D_{0}-D_{9}$ to establish
the direction of pins $B_{0}-B_{g}$. The D-terms control the Tri-state buffers found on the outputs of the EX-OR gates. Figures 10 and 11 show how the $D$-term configures each $B_{x}$ pin.


Figure 10. PLS153 Functional Diagram


Figure 11

To control each D-term, it is necessary to understand that each control gate is a 36input AND gate. To make the Tri-state buffer active ( $B_{x}$ pin an output), the output of the control gate must be at logic HIGH (1). This can be accomplished in one of two ways. A

HIGH can be forced on all control gate input nodes, or fuses can be programmed. When a fuse is programmed, that control gate input node is internally pulled up to HIGH (1). See Figure 12 and Figure 13.

Programming the fuse permanently places a HIGH (1) on the input to the control gate. The input pin no longer has any effect on that state.


Figure 12. Input Effect On Control Gates (Fuse Intact)


Figure 13. Effect On Control Gate If Fuse Is Programmed

## DEDICATING BX PIN DIRECTION

Since each input to the D-terms is true and complement buffered (see Figure 11), when the device is shipped with a!! fuses intact, a!! control gates have half of the 36 input lines at logic low ( 0 ). The result of this is all Control Gate outputs are low (0) and the Tri-state buffers are inactive. This results in all $\mathrm{B}_{\mathrm{x}}$ pins being in the input condition. The resultant
device is, therefore, an 18 -input, 0 -output FPLA. While useful as a bit bucket or Write-Only-Memory (WOM), most applications require at least one output. Clearly, the first task is to determine which of the $B_{x}$ pins are to be outputs. The next step is to condition the control gate to make the Tri-state buffer for those gates active. To dedicate $B_{0}$ and $B_{1}$ as outputs, it is necessary to program all fuses to the inputs to Control Gates $D_{0}$ and $D_{1}$. This internally pulls all inputs to those gates to

HIGH (1) permanently. Since all inputs to the Control Gates are HIGH (1), the output is HIGH (1) and the Tri-state buffers for $\mathrm{B}_{0}$ and $B_{1}$ are active. This permanently enables $B_{0}$ and $B_{1}$ as outputs. Note that even though $B_{0}$ and $B_{1}$ are outputs, the output data is available to the AND array via the internal feedback (see Figure 11a).
To program this data, the PLS153 Program Table is used as shown in Figure 14.


T801830S
Figure 14. Dedicating $B_{0}$ And $B_{1}$ As Outputs And $B_{2}$ Through $B_{9}$ As Inputs

By placing a (一) Don't Care in each input box you are specifying that the True and Complement fuses are programmed on each Control Gate, thus permanently dedicating the $\mathrm{B}_{0}$ and $\mathrm{B}_{1}$ pins as outputs. By placing a ( 0 ) in all input boxes for $B_{2}-B_{9}$, you are specifying that both True and Complement fuses are intact. This causes a low (0) to be forced on half of the Control Gate inputs, guaranteeing the output of the Control Gate will be low (0). When the Control Gate outputs are low (0), the Tri-state buffer is inactive
and the $B_{2}-B_{9}$ pins are enabled as inputs. All $B_{x}$ pin directions can be controlled in this manner.

## ACTIVE DIRECTION CONTROL

Sometimes it is necessary to be able to actively change the direction of the $\mathrm{B}_{\mathrm{x}}$ pins without permanently dedicating them. Some applications which require this include Tristate bus enable, multi-function decoding, etc. This can easily be done by programming
the Control Gate to respond to one or more input pins. It is only necessary to select which $I_{x}$ and $B_{x}$ pins will control the pin directions and the active level HIGH (H) or LOW (L) that will be used. The PLS153 Program Table in Figure 15 shows the method of controlling $\mathrm{B}_{0}-\mathrm{B}_{9}$ with $\mathrm{I}_{7}$. When $\mathrm{I}_{7}$ is LOW (L), pins $B_{0}-B_{9}$ are outputs when $I_{7}$ is HIGH (H), pins $\mathrm{B}_{0}-\mathrm{B}_{9}$ are inputs. Note that by programming all other $I_{x}$ and $B_{x}$ pins as DON'T CARE (一), they are permanently disconnected from control of $\mathrm{B}_{\mathrm{X}}$ pin direction.


TB01840S
Figure 15. Active Control of $\mathrm{B}_{0}-\mathrm{B}_{9}$ Using $\mathrm{I}_{7}$ Active Low (L)

The previous 28 -pin logic synthesis example (Page 2-5) could be done on the PLS153 as follows:

$$
\begin{aligned}
& X_{0}=A B+\bar{C} D+B \bar{D} \\
& \bar{X}_{1}=\bar{A} B+\bar{C} \bar{D}+E F G
\end{aligned}
$$

Note that $B_{0}$ was used as a CHANGE input. When $B_{0}$ is $\mathrm{HIGH}(\mathrm{H})$ the outputs appear on $\mathrm{B}_{8}$ and $\mathrm{B}_{9}$. When $\mathrm{B}_{0}$ is LOW ( L ), the outputs appear on $B_{6}$ and $B_{7} . B_{1}$ through $B_{5}$ are not used and therefore left unprogrammed.

THE ROLE OF AMAZE (AUTOMATIC MAP AND ZAP ENTRY) IN LOGIC

## DEVELOPMENT

AMAZE is a software development package which provides the logic designer with a multimode data input capability. This software package, which has been developed for both mainframe and microcomputer environments, allows data entry in the program table format previousty described, or on one of two equation formats. Both Boolean Logic Equations and State Variable Equations are supported on AMAZE. In addition to the flexible input formats offered, AMAZE also provides full
device documentation, and a functional simulator. The simulator features manual and automatic modes. In the automatic mode, the software generates a set of input vectors which can be used as functional test vectors. The manual mode is an interactive procedure which allows the designer to input vectors to the simulator. The AMAZE simulator then responds with the appropriate output vector. In both modes, the simulator uses the functional model generated by the user's input data.

For more information on AMAZE refer to Section 8 of the 1987 Signetics Programmable Logic Data Manual.


## SEQUENTIAL LOGIC CONSIDERATIONS

The PLS105 and PLS155-PLS159 represent significant increases in complexity when compared to the combinatorial logic devices pre-
viously discussed. By combining the AND/OR combinatorial logic with clocked output flipflops and appropriate feedback, Signetics has created the first family of totally flexible sequential logic machines.


80018905
Figure 17. Basic Architecture Of PLS105 FPLS. I, P, N, And F Are Multi-line Paths Denoting Groups Of Binary Variables Programmed By The User.


AFO2:BOS
Figure 18. Typical State Diagram. $I_{1-3}$ Are Jump Conditions Which Must Be Satisfied Before Any Transitions Take Place. $\mathrm{F}_{\mathrm{f}}$ Are Changes In Output Triggered By Im, And Stored In The Output Register. State Transitions $\mathbf{a} \rightarrow \mathbf{b}$ and $\mathbf{c} \rightarrow \mathbf{d}$ Involve No Output Change.


A502190s
Figure 19. Typical State Transition Between Any Two States Of Figure 18. The Arrow Connecting The Two States Gives Rise To A Transition Term $\mathbf{T}_{\mathrm{n}}$. I Is The Jump Condition.

The PLS105 FPLS (Field-Programmable Logic Sequencer) is an example of a high-order machine whose applications are manifold. Application areas for this device include highspeed data controllers, microprocessor and minicomputer bus arbitration, industrial controls, timing generation, multi-function counters and shift registers, and microprocessordriven microcontrollers. The PLS105 is fully capable of performing fast sequential operations in relatively low-speed processor systems. By placing repetitive sequential operations on the PLS105, processor overhead is reduced. Each PLS105 can be viewed as a high-speed, 48 -state subroutine.

The following pages summarize the PLS105 architecture and features.

## FPLS Architecture

The PLS105 Logic Sequencer is a programmable state machine of the Mealy type, in which the output is a function of the present state and the present input.

With the FPLS a user can program any logic sequence expressed as a series of jumps between stable states, triggered by a valid input condition (I) at clock time (t). All stable states are arbitrarily assigned and stored in the State Register. The logic output of the machine is also programmable, and is stored in the Output Register.

## Clocked Sequence

A synchronous logic sequence can be represented as a group of circles interconnected with arrows. The circles represent stable states, labeled with an arbitrary numerical code (binary, hex, etc.) corresponding to discrete states of a suitable register. The arrows represent state transitions, labeled with symbols denoting the jump condition and the required change in output. The number of states in the sequence depends on the length and complexity of the desired algorithm.


LDO2390S
Figure 20. Typical State Jump From State (0) To State (1), If Inputs $A=B=11$ '. The Jump Also Forces $F=' 1 "$, As Required.


LD02360S
Figure 21. Simplified Logic Diagram Of PLS105 FPLS

## State Jumps

The state from which a jump originates is referred to as the Present state (P), and the state to which a jump terminates is defined as the Next state ( N ). A state jump always causes a change in state, but may or may not cause a change in machine output (F).
State jumps can occur oniy via 'transition terms" $\mathrm{T}_{\mathrm{n}}$. These are logical AND functions of the clock ( t ), the Present state ( P ), and a valid input (l). Since the clock is actually applied to the State Register, $\mathrm{T}_{\mathrm{n}}=1 \bullet \mathrm{P}$. When $T_{n}$ is 'true', a control signal is generated and used at clock time ( t ) to force the contents of the State Register from ( P ) to ( N ), and to change the contents of the Output Register (if necessary). The simple state jump in Figure 20 , involving 2 inputs, 1 state bit, and 1 output bit, illustrates the equivalence of discrete and programmable logic implementations.

## FPLS Logic Structure

The FPLS consists of programmable AND and OR gate arrays which control the Set and Reset inputs of a State Register, as well as monitor its output via an internal feedback path. The arrays also control an independent Output Register, added to store output commands gencrated during state transitions, and to hold the output constant during state sequences involving no output changes. If desired, any number of bits of the Output Register can be used to extend the width of the State Register, via external feedback.


Figure 22. Typical AND Gate Coupled To (I) And (P) Inputs.
If At Least One Link Pair Remains Intact, $T_{n}$ is Unconditionally Forced Low.


Figure 23. Choice Of Input Polarity Coupling To A Typical AND Gate. With Both Links Open, (I) Is Logically Don't Care.


Figure 24. Typical Transition Terms Involving Arbitrary Inputs And State Variables. All Remaining Gate Inputs Are Programmed Don't Care. Note That $T_{2}$ Output Is State Independent.

## Input Buffers

16 external inputs ( 1 m ) and 6 internal inputs $\left(P_{s}\right)$, fed back from the State Register, are combined in the AND array through two sets of True/Complement (T/C) buffers. There are a total of 22 T/C buffers, all connected to multi-input AND gates via fusible links which are initially intact.

Selective fusing of these links allows coupling either True, Complement, or Don't Care values of $\left(I_{m}\right)$ and $\left(P_{s}\right)$.
"AND" Array
State jumps and output changes are triggered at clock time by valid transition terms $T_{n}$. These are logical AND functions of the present state ( P ) and the present input (I).

The FPLS AND Array contains a total of 48 AND gates. Each gate has 45 inputs - 44 connected to 22 T/C input buffers, and 1 dedicated to the Complement Array. The outputs of all AND gates are propagated through the OR Array, and used at clock time (t) to force the contents of the State Register from $(\mathrm{P})$ to $(\mathrm{N})$. They are also used to control the Output Register, so that the FPLS 8-bit output $F_{r}$ is a function of the inputs and present state.


Figure 25. Typical OR Array Gating Of Transition Terms $\mathrm{T}_{1,2,3}$ Controlling Arbitrary State And Output Register Stages.


LD02380S
Figure 26. The COMPLEMENT Array Is Logically Constructed From A 48-Input Programmable OR Gate Followed By An Inverter. All AND Terms Coupled To The OR Gate Are Complemented At The Inverter Output, And Can Be Fed Back As Inputs To The AND Array.
"OR' Array
In general, a clocked sequence will consist of several stable states and transitions, as determined by the complexity of the desired algorithm. All state and output changes in the state diagram imply changes in the contents of State and Output Registers.

Thus, each flip-flop in both registers may need to be conditionally set or reset several times with $T_{n}$ commands. This is accomplished by selectively ORing through a programmable OR Array all AND gate outputs $T_{n}$ necessary to activate the proper flip-flop control inputs.
The FPLS OR Array consists of 14 pairs of OR gates, controlling the S/R inputs of 14 State and Output Register stages, and a single OR gate for the Complement Array. All gates have 48 inputs for connecting to all 48 AND gates.

## Complement Array

The COMPLEMENT Array provides an asynchronous feedback path from the OR Array back to the AND Array.
This structure enabies the FPLS to perform both direct and complement sequential state jumps with a minimum of transition (AND) terms.
Typically direct jumps, such as $T_{1}$ and $T_{2}$ in Figure 27 require only a single AND gate each.

But a complement jump such as $T_{3}$ generally requires many AND gates if implemented as a direct jump. However, by using the Complement Array, the logic requirements for this type of jump can be handled with just one more gate from the AND Array.


TRANSITION TERMS
AF02160S

DIRECT $\left\{\begin{array}{l}T_{1}=P_{0} X \\ T_{2}=P_{0} Y\end{array}\right.$

COMPLEMENT $\quad\left\{\quad T_{3}=P_{0}(\bar{X} \cdot \bar{Y})=P_{0}\left(\overline{T_{1}+T_{2}}\right)\right.$
a. Typical State Sequence


$$
T_{3}=P_{0}\left(\overline{P_{0} X+P_{0} Y}\right)
$$

$$
T_{3}=P_{0}\left[P_{0}(X+Y)\right]
$$

$$
T_{3}=P_{0}\left[\bar{P}_{0}+\overline{(X+Y)}\right]
$$

$$
T_{3}=0+P_{0}(\overline{X+Y})
$$

$$
T_{3}=P_{0}(\bar{X} \cdot \bar{Y})
$$

b. Complement Jump

Figure 27. a. $X$ And $Y$ Specify The Conditional Logic For Direct Jump Transition Terms $\mathbf{T}_{1}$ And $\mathbf{T}_{2}$. The Complement Jump Term $\mathbf{T}_{\mathbf{3}}$ Is True Only When Both $T_{1}$ and $T_{2}$ Are False. b. Note That The Complementary Logic Expression For $T_{3}, T_{1}+T_{2}$, Corresponds Exactly To The Logic Structure Of The Complement Array.

As indicated in Figure 28, the single Complement Array gate may be used for many states of the state diagram. This happens because all transition terms linked to the OR gate include the present state as a part of their conditional logic. In any particular state, only those transition terms which are a function of that state are enabled; all other terms coupled to different states are disabled and do not influence the output of the Complement Array. As a general rule of thumb, the Complement Array can be used as many times as there are states.

a. State Diagram


LOOZ3205
c. State Logic Without Using The Complement Array

$$
\begin{aligned}
& T_{d 1}=I_{0} I_{1} P_{0} \\
& T_{d 2}=I_{2} P_{0} \\
& T_{c 3}=\left(T_{d 1}+T_{d 2}\right) P_{0}=\left(\overline{I_{0} I_{1}+I_{2}}\right) P_{0} \\
& T_{d 4}=I_{2} P_{3} \\
& T_{d 6}=I_{0} I_{1} P_{3} \\
& T_{c 5}=\left(T_{d 4}+T_{d 6}\right) P_{3}=\left(\overline{I_{0} I_{1}+I_{2}}\right) P_{3}
\end{aligned}
$$

$T_{\text {en }}=$ COMPLEMENT STATE TRANSITION TERM
$T_{d n}=$ DIRECT STATE TRANSITION TERM $P_{s}=$ PRESENT STATE

## b. Logic Definition


d. State Logic Using The Complement Array

Figure 28. Logic Reduction With The Complement Array. The Logic State Diagram In (a) Includes Complement Jumps Tc3 And TC5 Defined In (b). When Using The Complement Array, A Savings Of 2 Transition Terms Results, As Shown In (c) And (d).

Table 5. 20-Pin PLD Sequential Family Summary

| DEVICE | REGISTERED OUTPUTS | OUTPUT TYPE |
| :---: | :---: | :---: |
| PLS155 | 4-Bit Register | T.S. |
| PLS157 | 6-Bit Register | T.S. |
| PLS159 | 8-Bit Register | T.S. |

## PLD-20 SEQUENTIAL DEVICES

The 20-pin PLD family also includes sequential devices. These devices are all similar in architecture. The major difference consists of the number of outputs which are registered.

## FEATURES

The PLD-20 sequencers have been designed with a maximum of flexibility in mind. Each element of the architecture contributes to the ease of use the PLD-20 family provides. Each part has the features listed:

- J/K flip-flop Output Register
- Dynamic control of flip-fiop type (J/K or D)
- Parallel bus load
- Asynchronous preset and reset capability
- Combinational I/O pins
- Programmabie enable pins
- Output feedback to AND Array available


## OUTPUT REGISTER

The Output Register of the PLD-20 sequential devices are comprised of fully implemented $\mathrm{J} / \mathrm{K}$ flip-flops. Each flip-flop is positive edgetriggered from a common clock.

In addition, a dynamically controllable "foldback' buffer between the J and K inputs to the flip-flop allows the designer to change the function of the flip-flop from $\mathrm{J} / \mathrm{K}$ to D-type under the control of the flip-flop control term (F). A fuse allows the designer to dedicate the flip-flop as a permanent D-type by programming the fuse.

By leaving the fuse intact, the flip-flop control line ( $F$ ) is maintained as the active mode control. If the output of $F$ is logic Low (0), then the flip-flop is configured as a D-type. If the output of $F$ is a logic High ( 1 ), then the flipflop is configured as a $J / K$ type. Term $F$ is programmed in the same manner as the 32 logic transition terms (T). It is well to note at this time that when the flip-flop is configured as a D-type, the OR-term driving the K input of the flip-flop must not be active.
During all modes of operation, the output register data is fed back to the AND Array. This feedback is used to establish presentstate to next-state jumps.


Figure 29

PARALLEL BUS LOADING
The Output Register may be loaded from the bus via the load control term (L). This feature
forces the data contained on the $F_{0}$ pin into the $\mathrm{J} / \mathrm{K}$ flip-flop. It operates synchronously with the rising edge of the clock. This feature
can be used to preload a state into the machine, or to latch input data into the AND Array.


Figure 30

PRESET AND RESET
Asynchronous preset and reset capability has been provided on the PLD-20 sequential
devices. This feature is controlled in the ANDArray on the PLS159. However, the preset and reset function on the PLS155 is controlled via the OR Array. The PLS157 preset
and reset controls are split between the two arrays. See the individual data sheets for details.


COMBINATIONAL I/O PINS
Each PLD-20 sequential device has a number of combinational pins ( $B_{n}$ ) which can be
programmed and used exactly as the B pins on the PLS153 FPLA. The direction control term (D) establishes the data flow on these
pins. The individual data sheet should be consulted for the quantity and pin number assignment for each device.


LD02440S
Figure 32

## Signetics Programmable Logic

## PLA vs. PAL ${ }^{\circledR}$ ARRAYS

The PLA architecture provides the most efficient means of implementing logic. The 28 pin devices, PLS100/101 and PLS103 are unique in their ability to directly implement logic.

They offer the mc highest number of it most straightforwar ic device in the in grams illustrate the ming the flexible $F$ fixed OR Array of


## NOTES:

1. Unused P-terms lost to designer.
2. Common P-term to 2 or more outputs requires 2 or more P-terms; one on eacl
3. External inverter required to change active level of output.
4. 10 P-terms used.

Figure 33. Applicatio


## NOTES:

1. All P-terms usable.
2. Common P-terms available to all outputs.
3. Programmable outputs eliminate need for external component.
4. 6 P-terms used.

Figure 34.

Signetics Programmable Logic

## FPGA LOGIC DIAGRAM



## NOTES:

1. All gate inputs when a blown link float to a logic " 1 ".


COMBINATIONAL I/O PINS
Each PLD-20 sequential device has a number of combinational pins ( $\mathrm{B}_{\mathrm{n}}$ ) which can be
programmed and used exactly as the $B$ pins on the PLS153 FPLA. The direction control term (D) establishes the data flow on these
pins. The individual data sheet should be consulted for the quantity and pin number assignment for each device.


Figure 32

PLA vs. PAL ${ }^{\circledR}$ ARRAYS
The PLA architecture provides the most efficient means of implementing logic. The 28 pin devices, PLS100/101 and PLS103 are unique in their ability to directly implement logic.

They offer the most useable P-terms, the highest number of inputs and outputs, and the most straightforward programming of any logic device in the industry. The following diagrams illustrate the relative ease of programming the flexible PLA structure against the fixed OR Array of the PAL.

The Signetics approach to programmable logic gives the designer the flexibility he needs where he needs it - in the device itself. The combination of totally flexible architecture, more useable product terms, and ease of logic implementation make Signetics Programmable Logic Family the obvious choice.



LD02481S

## NOTES:

1. All P-terms usable.
2. Common P-terms avaifable to all outputs.
3. Programmable outputs eliminate need for external component.
4. 6 P-terms used.

Figure 34. PLD Approach
*PAL is a registered trademark of Monolithic Memories. Inc.

```
FPLA PLS153/153A COMPATIBLE WITH PAL* LOW/MEDIUM COMPLEXITY PRODUCT, i.e., 14H/L4 16H/L2 16LS 10H/LS 16C1, 12H/LS
ADDITIONAL FEATURES:
1. PROGRAMMABLE OUTPUT POLARITY
2. PFOGRAMMABELE OT ARRAY
3. 10 OUTPUTS vs. 8 FOR PAL
4. 32 PRODUCT TERMS vs. 16 FOR LOW AND MEDIUM PALs
FPLS PLS155/157/159 COMPATIBLE WITH PAL REGISTERED TYPES 16R3, 16R5, 16R4, etc.
ADDITIONAL FEATURES:
1. PROGRAMMABLE AND/OR, ALSO CONTROLLABLE FLIP FLOPS; AS D, TOGGLE, OR JK
```

*PAL is a trademark of Monolithic Memorles, Inc.
Figure 35. PLD-20 Product Comparison

## PLD FAMILY SUMMARY

| Fieid-Programmable Gate Arrays |  |  |  |
| :---: | :---: | :---: | :---: |
| PLS103 | $16 \times 9$ | 28-Pin | Tri-state (Combinatorial) |
| PLS151 | $18 \times 12$ | 20-Pin | Tri-state (Combinatorial) |
| Field-Programmable Address Decoders |  |  |  |
| PLS162 | $16 \times 5$ | 24-Pin | Tri-state (Combinatorial) |
| PLS163 | $12 \times 9$ | 24-Pin | Tri-state (Combinatorial) |
| Field-Programmable Logic Arrays |  |  |  |
| PLS100 | $16 \times 48 \times 8$ | 28-Pin | Tri-state (Combinatorial) |
| PLS101 | $16 \times 48 \times 8$ | 28-Pin | Open Collector (Combinatorial) |
| PLS153/153A/PLHS153 | $18 \times 45 \times 10$ | $20-\mathrm{Pin}$ | Tri-state (Combinatorial) |
| PLS161 | $12 \times 48 \times 8$ | 24-Pin | Tri-state (Combinatorial) |
| PLS173/PLUS173 | $22 \times 45 \times 10$ | 24-Pin | Tri-state (Combinatorial) |
| PLHS473 | $20 \times 24 \times 11$ | 24-Pin | Tri-state and Open Collector |
| PLC473 | $20 \times 24 \times 11$ | 24-Pin | Tri-state and Open Collector (CMOS) |
| PLHS18P8A | $18 \times 72 \times 8$ | 20-Pin | Tri-state (Combinatorial); Fixed OR Array |
| Field-Programmabie Logic Sequencers |  |  |  |
| PLS105/105A | $16 \times 48 \times 8$ | 28-Pin | Tri-state Mealy State Machine |
| PLS155 | $16 \times 42 \times 12$ | 20-Pin | Tri-state 4-Bit Sequencer |
| PLS157 | $16 \times 42 \times 12$ | 20-Pin | Tri-state 6-Bit Sequencer |
| PLS159/159A | $16 \times 42 \times 12$ | 20-Pin | Tri-state 8-Bit Sequencer |
| PLS167/167A | $14 \times 48 \times 6$ | 24-Pin | Tri-state Mealy State Machine |
| PLS168/168A | $12 \times 48 \times 8$ | 24-Pin | Tri-state Mealy State Machine |
| PLS179 | $20 \times 42 \times 8$ | 24-Pin | Tri-state 8-Bit Sequencer |
| PLUS405A | $16 \times 64 \times 8$ | 28-Pin | Tri-state Mealy State Machine |
| Field-Programmable Macro Logic |  |  |  |
| PLHS501 | $32 \times 72 \times 24$ | 52-Pin | Random Logic Unit |
| PLHS502 | $32 \times 64 \times 24$ | 52-Pin | Registered Logic Unit |

## Signetics Programmable Logic



NOTES:

1. All gate inputs when a blown link float to a logic " 1 ".


[^0]NOTES:
2. A 步


LDO 1240 S


## NOTES:

1. All gate inputs with a blown link float to a logic "1".


## Signetics Programmable Logic



[^1]

[^2]FPLA LOGIC DIAGRAM


NOTES:

1. All AND/EX-OR gate inputs with a blown link float to a logic " 1 "
2. All $O$ g gate inputs with a blown link float to a logic " 0 "



[^3]

## NOTES:

1. All unprogrammed or virgin 'AND' gate locations are pulled to a logic ' 1 '.
2. All unprogrammed or virgin 'OR' gate locations are pulled to a logic ' 0 '.


## FPLA LOGIC DIAGRAM



DOEFうつS
NOTES:

1. All programmed 'AND' gate locations are pulled to a logic ' 1
2. All programmed 'OR' gate locations are pulled to a logic ' $O$ '.


Signetics Programmable Logic


Signetics Programmable Logic


LD022405

[^4]

LDO1702S
NOTES:

1. All OR gate inputs with a blown link float to a logic ' 0 '.
2. All other gates and control inputs with a blown link float to a logic '1.
3. $\oplus$ denotes WIRE-OR.



LD01693s
NOTES:

1. All OR gate inputs with a biown link fioat to a :ogic ' 0 '
2. All other gates and control inputs with a blown link float to a logic
3. ". Frogrammatele commections:

Signetics Programmable Logic


## NOTES:

1. All OR gate inputs with a blown link float to a logic " 0 ".
2. All other gates and control inputs with a blown link float to a logic "1"
3. $\oplus$ denotes WIRE-OR.
4. Arbistinabie connection

. 0022815
NOTES:
5. All AND gate inputs with a blown link fioat to a togic
6. All OR gate inputs with a blown link float to a logic



## NOTES:

1. All programmed "AND" gate locations are pulled to a logic "1".
2. All programmed "OR" gate locations are pulled to a logic " 0 '.
3. Whate

Signetics Programmable Logic

FPLS LOGIC DIAGRAM
PLS179


## Signetics Programmable Logic

LDO6972S

```
1. All OR gate inputs with a blown link float to a logic \({ }^{\prime} 0\) '
2. All other gates and control inputs with a blown link float to a logic ' 1 '.
3. \(\oplus\) denotes WIRE-OR
```



## PLD PROGRAMMING

The current Signetics family of Programmable Logic (PLD) products are high-performance bipolar and CMOS devices which use various fusing elements to provide the many benefits of field programming. Programming is accomplished by application of voltages above those used for normal operation; therefore, no special pins are required for programming. The programming voltages and timing requirements make unintentional programming virtually impossible.

## PROGRAMMING INFORMATION

Complete programming system specifications for PLD 20-, 24-, and 28-pin and 52-pin PML products are available upon request from Application Specific Product Marketing.

Signetics encourages the purchase of programming equipment from a manufacturer who has a full-line of programming products to offer. Signetics also encourages the manufacturers of PLD programming equipment to submit their equipment for verification of electrical parameters and programming procedures. Information on manufacturers offering equipment certified by Signetics is available on request from Application Specific Product Marketing.

## SIGNETICS DISCOURAGES THE CONSTRUCTION AND USE OF "HOMEMADE" PROGRAMMING

 EQUIPMENTIn order to consistently achieve excellent programming yields, periodic calibration of the programming equipment is required. Consult the equipment manufacturer for the recommended calibration interval. Records of programming yield, by device type, should be kept and any downward trend or sudden change should be considered as an indication of a need to recalibrate the programming equipment.

Application Specific Products

## INDEX

Section 3 - Advanced Product Preview
PLMC153 Mask-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 3-3
PLUS153 Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ..... 3-5
PLUS173 Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ..... 3-7
PLHS501 Programmable Macro Logic Random Logic Unit ( $32 \times 72 \times 24$ ) ..... 3-9
PLHS502 Programmable Macro Logic Synchronous/Asynchronous RegisterMacro Unit ( $32 \times 64 \times 24$ ).3-19

## Signetics

## Application Specific Products - Series 20

## DESCRIPTION

The PLMC153 is a CMOS, mask-programmable functional equivalent of the PLS153 and PLS153A FPLAs. Custom logic patterns can be generated directly from working bipolar PLS153/153A devices. This enables the user to prototype and debug a device in a system prior to committing the pattern to a mask set. The programmed PLMC153 provides maximum production economy, while the CMOS process technology reduces the power consumption of the PLMC153 to less than one third of its bipolar counterparts.
Identical to the PLS153 and 153A, the PLMC153 is a two-level logic element, consisting of 42 AND gates and 10 OR gates, featuring programmable I/O polarity and direction.
All AND gates are iinked to 8 inputs (1) and 10 bidirectional I/O lines (B). These yield variable I/O gate configurations via 10 direction control gates (D), ranging from 18 inputs to 10 outputs.

On chip T/C buffers couple either True (I, B) or Complement ( $\overline{\bar{l}}, \bar{B}$ ) input polarities to all AND gates, whose outputs can

## PLMC153

Mask-Programmable Logic Array ( $18 \times 42 \times 10$ )

Signetics Programmable Logic Objective Specification

be optionally linked to all OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.

## FEATURES

- Single Mask-Programmable
- Functionally identical to PLS153 and PLS153A
- 8 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or LLow outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- I/O propagation delay: 35ns (max.)
- Power dissipation: (tipp.)
- DC: 1mA
- AC: $1 \mathrm{~mA} / \mathrm{MHz}$
- Input Loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Tri-state outputs
- TTL compatible

FUNCTIONAL DIAGRAM


PIN CONFIGURATIONS


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing


## LOGIC FUNCTION

TYPICAL PRODUCT TERM:
$P_{n}=A \cdot B \cdot C \cdot D \cdot .$.
TYPICAL LOGIC FUNCTION: AT OUTPUT POLARITY $=\mathrm{H}$ $\mathbf{Z}=\mathbf{P O}+\mathbf{P} 1+\mathrm{P} 2 \ldots$

AT OUTPUT POLARITY $=\mathrm{L}$ $\mathrm{Z}=\overline{\mathrm{P} 0+\mathrm{P} 1+\mathrm{P} 2+} \ldots$ $\mathbf{Z}=\overline{\mathbf{P} \mathbf{0}} \cdot \overline{\mathbf{P} 1} \cdot \overline{\mathbf{P} \mathbf{2}} \ldots$

NOTES:

1. For each of the 10 outputs, either function $Z$ (Active-High) or $\overline{\bar{Z}}$ (Active-Low) is available. but not both. The desired output polarity is programmed via the EX-OR gates.
2. $Z, A, B, C$, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

## NOTE:

All points are mask-programmable

## FPLS LOGIC DIAGRAM



## Signetics

## Application Specific Products

## - Series 20

## DESCRIPTION

The PLUS153 is a two-level logic element, consisting of 42 AND gates and 10 OR gates with fusible link connections for programming 1/O polarity and direction.

All AND gates are linked to 8 inputs (l) and 10 bidirectional I/O lines (B). These yield variable I/O gate configurations via 10 direction control gates (D), ranging from 18 inputs to 10 outputs.
On chip T/C buffers couple either True (I, B) or Complement ( $\overline{\mathrm{I}}, \overline{\mathrm{B}}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.
The PLUS153 is field programmable, enabling the user to quickly generate cusiom paiterns using siandard programming equipment.

Order codes are contained on the pages following.

## PLUS153

## Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

## Signetics Programmable Logic Objective Specification

## FEATURES

- Field-Programmable (Ti-W links)
- Functionally identical to PLS153/ 153A and PLHS153
- 8 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or -Low outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- I/O propagation delay: 12ns (max.)
- Input loading: $\mathbf{- 1 0 0 \mu A}$ (max.)
- Power dissipation: 700mW (typ.)
- Tri-state outputs
- TTL compatible


## APPLICATIONS

- Randiom iogic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing

FIUNCTIONAL DIAGRAM


PIN CONFIGURATIONS


A $=$ Ptastic Leaded Chip Carrier

## LOGIC FUNCTION

TYPICAL PRODUCT TERM:
$P n=A \cdot B \cdot C \cdot D \cdot \ldots$
TYPICAL LOGIC FUNCTION:
AT OUTPUT POLARITY $=\mathrm{H}$ $Z=P 0+P 1+P 2 \ldots$

AT OUTPUT POLARITY $=L$ $\mathrm{Z}=\overline{\mathbf{P} 0+\bar{P} 1+\mathbf{P} 2+} \ldots$
$\mathrm{Z}=\overline{\mathbf{P} 0} \cdot \overline{\mathrm{P} 1} \cdot \mathbf{\mathbf { P } ^ { 2 }} \cdot \ldots$

NOTES:

1. For each of the 10 outputs, either function $Z$ (Active-High) or $\overline{\mathrm{Z}}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $Z, A, B, C$, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

## FPLA LOGIC DIAGRAM



## Signetics

## Application Specific Products

## - Series 24

## DESCRIPTION

The PLUS173 is a high-speed version of the PLS173 FPLA. The Signetics state-of-the-art Oxide Isolated Bipolar fabrication process is employed to produce performance levels not yet achieved in devices of this complexity.

The PLUS173 is a two-level logic element consisting of 42 AND gates and 10 OR gates with fusible link connections for programming I/O polarity and direction.

All AND gates are linked to 12 inputs (I) and 10 bidirectional I/O lines (B). These yield variable $1 / O$ gate configurations via 10 direction control gates (D), ranging from 22 inputs to 10 outputs.

On chip T/C buffers couple either True ( $\mathrm{I}, \mathrm{B}$ ) or Complement ( $(\overline{\mathrm{I}}, \overline{\mathrm{B}}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.

The PLUS173 is field-programmable, enabling the user to quickly generate custom patterns using standard programming equipment.

## FUNCTIONAL DIAGRAM



PIN CONFIGURATIONS


## A Package


$A=$ Piastic Leaded Chip Carrier
LOGIC FUNCTION

TYPICAL PRODUCT TERM:
Pn=A.B•C•D • . .
TYPICAL LOGIC FUNCTION: AT OUTPUT POLARITY = H $\mathbf{Z}=\mathbf{P 0}+\mathbf{P} 1+\mathbf{P 2} \ldots$

AT OUTPUT POLARITY $=\mathbf{L}$ $Z=\overline{P_{0}+P 1+P 2+} \ldots$ $Z=\overline{P_{0}} \cdot \overline{\mathbf{P}_{1}} \cdot \overline{\mathbf{P}^{2}} \cdot \ldots$

NOTES:

1. For each of the 10 outputs, either function $\mathbf{Z}$ (Active-High) or $\bar{Z}$ (Actfve-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $Z, A, B, C$, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

FPLA LOGIC DIAGRAM


## Signetics

## Application Specific Products - Piñil Series 52

## DESCRIPTION

The PLHS501 is a member of the Signetics Programmable Macro Logic family. PML is unique in its capability of performing other than two level logic functions without incurring 1/O buffer delays. This allows the logic or system designer to imbed logical operations or macro structures within the framework of the I/O pins. Since the imbedded functions are independent of the delays created by the I/O buffers, they can be performed at speeds lesser architectures cannot reproduce.

The technique used to perform this operation is a NAND foldback network which allows the direct interconnection of any number of logic nodes within the single fuse matrix. Macros can be formed and then interconnected to the I/O structure. In addition, single-level and multi-level logic can be performed at speeds which reflect only the logic path utilized. Therefore, a single-level logic function has a very short path through the device. Additional levels incur only one NAND foldback delay per level. This delay is less than the combined delay created by previous generations of devices which stipulate that the logic signal must pass through I/O buffers after one or two levels of logic are performed.

The PLHS501 is fabricated with Signetics, ZA Oxide-Isolated Bipolar Process. ZA utilizes Vertical Avalanche Migration Programmed (VAMP ${ }^{\text {TM }}$ ) Fuses as programming elements. These fuses provide high programming yield and reliability. Proprietary onboard test circuitry allows the PLHS501 to be thoroughly tested prior to programming.

## Preliminary Specification

## FEATURES

- Signetics NAND foldback architecture
- Field-Programmable
- 24 dedicated inputs
- Fixed and programmable output buffers
- 8 I/O buffers
- 8 EX-OR buffers
- 4 Active-Low buffers
- 4 Active-High buffers
- 72 internal NAND foldback terms
- Supported by AMAZE

Development System

- Testable in unprogrammed state
- Verify Lock Fuse
- TTL compatible
- Power dissipation: 1.25w (typ.)
- Logic delay times
- Single-level = 18ns (max.)
- Two-level = 26ns (max.)
- Internal NAND delay $=8 \mathrm{~ns}$ (max.)


## ARCHITECTURE

- 24 dedicated Inputs; $\mathrm{I}_{0}-\mathrm{I}_{23}$
- 4 Active-High I/Os with individual enable: $\mathrm{B}_{4}-\mathrm{B}_{7}$
- 4 Active-Low I/Os with individual fused enable: $\bar{B}_{0}-\bar{B}_{3}$
- 2 Active-High output pairs; each pair with common enable: $\mathrm{O}_{0}-\mathrm{O}_{3}$
- 2 Active-Low output pairs; each pair with common enabie: $\overline{\mathrm{O}}_{4}-\overline{\mathrm{O}}_{7}$
- 4 EX-OR output pairs; each pair with common enable: $X_{0}-X_{7}$
- 72 internal NAND foldback terms


## PIN CONFIGURATION



## Programmable Macro Logic

## Random Logic Unit* ( $32 \times 72 \times 24$ )

## FUNCTIONAL DIAGRAM



L00e73ts

ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 52-Pin Plastic Leaded Chip Carrier | PLHS501A |

ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\text {cc }}$ | Supply voltage |  | + 7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

LOGIC DIAGRAM



## Programmable Macro Logic Random Logic Unit* ( $32 \times 72 \times 24$ )

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{\text {IL }} \\ & V_{I H} \\ & V_{I C} \end{aligned}$ | Low <br> High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=M a x \\ V_{C C}=\text { Min, } \mathbb{I}_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} \hline 0.8 \\ -1.2 \\ \hline \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | $\begin{aligned} & \text { Low }^{3,5} \\ & \text { High }^{3,6} \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{I}_{\mathrm{OL}} & =10 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OH}} & =-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{H}} \end{aligned}$ | Low High | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state $^{10}$ <br> Short circuit ${ }^{4,6,7}$ | $\begin{gathered} V_{\text {CC }}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| lcc | $V_{C C}$ supply current ${ }^{8}$ | $V_{C C}=M a x$ |  | 250 | 325 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{N}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{gathered} V_{C C}=5 \mathrm{~V} \\ V_{\text {IN }}=2.0 \mathrm{~V} \\ V_{\text {OUT }}=2.0 \mathrm{~V} \end{gathered}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, 4.75<\mathrm{V}_{\mathrm{CC}}<5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1000 \Omega$

| SYMBOL | PARAMETER |  | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | T0 | FROM |  | Min | Typ | Max |  |
| $t_{\text {PD1 }}$ | Ouiputi | inpuit | $C_{L}=30 \mathrm{pF}$ |  |  | 20 | ns |
| $t_{\text {PD2 }}$ | Output $\pm$ | Input $\pm$ |  |  |  | 18 | ns |
| tpD3 | Output $\pm$ | Input $\pm$ |  |  |  | 18 | ns |
| $t_{\text {PD4 }}{ }^{11}$ | Output $\pm$ | Input $\pm$ |  |  |  | 28 | ns |
| ${ }_{\text {PDD5 }}{ }_{11}^{11}$ | Output $\pm$ | Input $\pm$ |  |  |  | 26 | ns |
| $\mathrm{tPD6}^{11}$ | Output $\pm$ | Input $\pm$ |  |  |  | 26 | ns |
| tPD7 $^{11}$ | Internal |  |  |  |  | 8 | ns |
| toe | Output- | Input $\pm$ |  |  |  | 20 | ns |
| tob ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  |  | 20 | ns |

NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. For Pins $15-19,21-27$ and $37-40, V_{O L}$ is measured with Pins 5 and $41=8.75 \mathrm{~V}$, Pin $43=0 \mathrm{~V}$ and Pins 42 and $44=4.5 \mathrm{~V}$.

For Pins $28-33$ and $35-36, V_{\mathrm{OL}}$ is measured under same conditions EXCEPT Pin $44=0 \mathrm{~V}$.
6. $\mathrm{V}_{\mathrm{OH}}$ is measured with Pins 5 and $41=8.75 \mathrm{~V}$, Pins 42 and $43=4.5 \mathrm{~V}$ and Pin $44=0 \mathrm{~V}$.
7. Duration of short circuit should not exceed 1 second.
8. $\mathrm{I}_{\mathrm{Cl}}$ is measured with all dedicated inputs at OV and bidirectional and output pins open.
9. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.
11. Limits are guaranteed with 10 terms maximum connected to each internal feedback line.

Programmable Macro Logic
Random Logic Unit* ( $32 \times 72 \times 24$ )

## PLHS501

## TEST LOAD CIRCUIT



TIMING DIAGRAM


## VOLTAGE WAVEFORM



## MEASUREMENTS:

All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified.

Input Pulses

## TIMING DEFINITIONS

$t_{\text {PD1 }}$
Input to Output delay, one pass, with EX-OR buffer
tpD2 Input to Output delay, one pass, with NAND buffer
tpD3 Input to Output delay, one pass, with AND buffer
Input to Output delay, two passes, with EX-OR buffer
$t_{\text {PD5 }}$

Input to Output delay, two passes, with AND buffer
tpD7 Feedback delay per internal NAND function performed
toD Delay between output change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High)
$t_{O E}$ Delay between input change and when the output reflects specified output level

## VIRGIN STATE

A factory shipped virgin device contains all fusible links open, such that:

1. All product terms are enabled.
2. All bidirectional (B) pins are outputs.
3. All outputs are enabled.
4. All outputs are Active-High except $\overline{\mathrm{B}}_{0}-\overline{\mathrm{B}}_{3}$ (fusable $1 / \mathrm{O}$ ) and $/ \mathrm{O}_{4}-/ \mathrm{O}_{7}$ which are Active-Low.

# Programmable Macro Logic Random Logic Unit* $(32 \times 72 \times 24)$ 

## PROGRAMMABLE MACRO LOGIC

The architectures of current Programmable Logic Devices (PLDs) generally employ programmabie AND-OR gate strings to permit implementing logic functions directly in Sum-of-Products form (SOP). Often, that becomes a bottleneck which interferes with the efficient allocation of the on-chip logic resources. This becomes very apparent when considering very dense PLDs in high pin-count packages.
PML is a novel architecture which breaks the AND-OR bottleneck by relying instead on a single NAND-gate array to implement SOP logic functions, and to provide a central programmable 'interconnect" site supporting a periphery of multi-level macros on a chip.

## INTRODUCTION

Today, system designers in a rush to bring their products to market are turning more than ever toward Programmable Logic Devices, lured by their blend of design elegance and efficiency with instant custom flexibility despite limitations in density and architecture.

To be sure, dramatic advances in Bipolar and CMOS processing technologies over the last decade have spawned denser and faster elements, with an occasional twist in architecture. Nevertheless, the structure of most current PLDs is still anchored on a fixed ANDOR gate chain linking primitive input, output, and function macros on a chip. Recently, to enhance the flexibility and design adaptability of early product offerings, denser devices have been introduced featuring logic macros with loca! programmable options and bypass circuitry.

However, as densities continue to increase, this approach is sure to breed devices with an overwhelming architectural maze which is altogether difficult to design, comprehend, and logically manipulate, complicating rather than simplifying their application.
PML, however, consists of various logic "access" and 'process' macros coupled via a primitive, central programmable structure in the on-chip 'interconnect' system (see Figure 1). Macros can have various local intelligence which, in turn, may be fixed or variable by means of programmable options also embedded in the central programmable core.

## AND-OR PLD ARCHITECTURE

Froit a fundamental theorem of Boclean algebra, any combinational logic function can be expressed in Sum-of-Products form involving only two levels of logic transformation. Such functions can be implemented in hard-


Figure 1. General PML Architecture Based on a Central Programmable "Interconnect" System Interlocking Peripheral Macros

$F=X+Y=A * B+C * D$
LD06760S
Figure 2. Typical SOP Function With Elementary AND-OR Gates


Figure 3. Basic Architecture of Current PLDs
ware by chaining two primitive logic macros as indicated in Figure 2.

The outputs of an AND-OR gate chains can be interlaced with higher level macros, such as flip-flops, to form sequential logic functions. These may be further combined into standard or custom super-macros which, in
turn, are interwoven into final system configurations. Presently, a number of PLDs are available which contain fixed sets of logic macros with programmable connections. Invariably, their architectures are anchored on a pair of concatenated AND-OR gate arrays, as diagrammed in Figure 3, to permit implementing logic functions directly in SOP form.

## Programmable Macro Logic Random Logic Unit* ( $32 \times 72 \times 24$ )

Virtually all PLDs fall in three main categories: PROM, Fixed OR, and PLA. As illustrated in Figure 4, these differ primarily in the programmability of the AND-OR gate chain which, by being irrevocably interposed as a two-level logic link between on-chip macros and I/O paths, often can turn into a design liability.
For example, in PROMs the exponential increase in AND array size with number of inputs is a severe drawback which limits their contention in the logic application arena.

In fixed OR devices, the fixed inputs to the OR array confine their architectures to essentially a composite of AND-OR, AND-OR-register logic slices defining independent $1 / 0$ paths through the chip. This causes duplication of common product terms, and waste of unused AND gates in each slice. Also, since each slice is dedicated to an output pin, devices with registered, programmable 1/O pins entail an even greater waste of on-chip logic resources when configured in registerbypass or fixed input modes. Moreover, no single level logic functions can be constructed, except dedicated on-chip control functions.
Finally, even as the twin programmability of the AND-OR arrays in current PLA-type devices lends greater flexibility, and may circumvent some of the above problems, it does pose difficult process, design and performance compromises in migrating toward more dense structures.
Thus, on the whole, the AND-OR gate chain forms a bottleneck which can impair the fragmentation and reallocation of the on-chip logic resources, curtailing the adaptability and efficiency of current PLDs in applications involving unstructured algorithms and scattered logic functions.

a. PROM: Programmable OR


LDOB780S
b. PAL*: Programmable AND


L006790s

## c. PLA: Programmable AND-OR

Figure 4. Programmable AND-OR Chain of Current PLDs

[^5]
## Programmable Macro Logic

## Random Logic Unit* (32 $\times 72 \times 24$ )

## NAND-NAND GATE EQUIVALENCE

One way of relieving the burden placed on PLDs' architecture by the AND-OR gate string is to do away with it altogether, and replace it with a new programmable structure forged out of a new compromise on silicon between 'interconnect' redundancy and ease of design and application. The approach adopted for PML is based on the fundamental equivalence between two-level AND-OR and NAND-NAND gate constructs in expressing combinatorial logic functions in SOP form, as illustrated in Figure 5.
Since programmable NAND-NAND logic chains can be formed by coupling identical NAND gates with programmable inputs, the NAND-array string in Figure 6 can be implemented as a single global array with feedback.

A basic NAND-array core linking a periphery of primitive macros is shown in Figure 7. When the feedback path is just a simple wire, the NAND-array can be fragmented into sin-gle-level or double-level true/complement iogic functions by programming respectively single ( $a-c-d$ ). or double ( $a-b-c-d$ ), interconnecting paths through the array from inputs I to output F .

More complex functions can be implemented by programming multi-level logic loops through the array.


LDO6800S
Figure 5. Equivalent NAND-NAND SOP Expression

LD06810S


Figure 7. Elementary NAND Array Linking Primitive Macros.
Note That No Programmable Connection is Implied at a Cross of a Solid Line With a Dotted Line

## Programmable Macro Logic Random Logic Unit* ( $32 \times 72 \times 24$ )

## BASIC PML ARCHITECTURE

The primitive NAND core can be expanded to support at its periphery a structure of logic macros of growing size and complexity, including various types of flip-flops, EX-OR gates, buffers, counters, shift registers, multiplexers, decoders, arithmetic/logic units, memories, etc. As illustrated in the general structure of Figure 8, 1/O macros would provide off-chip paths to the outside world, while FUNCTION macros looped about the array would provide the necessary logic processing capability.

In deference to trade-offs in functionality and speed imposed by the array size and loading, Type-1 Output (or Function) macros may be driven directly from NAND gates, while Type2 macros may be driven by gates first looped through the array. There are virtually no limits to the number, size, and functionality of the on-chip macros surrounding the central core, other than those imposed by processing and packaging capabilities.
The main design advantage of PML is that it relies upon a single array to interconnect all macros. This reduces the design task to that of building essentially a PROM-like programmable structure more forgiving than the double array in PLA-type devices, and more flexible than that in fixed OR devices. Also, the ability to forge the NAND core into multilevel logic paths at will increases the usage efficiency of the on-chip logic resources, and greatly enhances the versatility of PML in most applications.

## THE FIRST PML OFFERING

The first PML device, designated PLHS501, is primarily a combinational logic device including only primitive macros. It is a 'gate bucket' whose deceptively simple structure can implement virtually all logic functions provided by existing combinational PAL/PLA-type devices. Also, it is the first to provide true EXOR output functions (in addition to output polarity inversion), as well as multi-level gate constructs and cross-coupled latches on-chip without involving output pins. These are shown in Figure 9.


Figure 8. General PML Structure


Built with Signetics' proprietary ZA oxide isolation process, and vertical fuses, the PLHS501 has a NAND matrix about the size of a 16 k -bit PROM. With a typical Icc of 250 mA , it features maximum input to output delays of $18 / 26$ ns over the commercial temperature range, reflecting respectively single and double passes through the NAND array. Assuming a conservative 'interconnect' factor of $20 \%$, the PLHS501 has a density
roughly equivalent to 1,500 2-input NAND gates.

The PLHS501 is the first member of a growing family of devices slated for future introduction. Built with either Bipolar or Erasable CMOS technologies, these will incorporate sets of higher level macros, leading to devices with greater logic power and a more efficient utilization of the on-chip interconnect system.

## Signetics

Application Specific Products<br>- PMiL Series 52

## DESCRIPTION

The PLHS502 is a member of the Signetics Programmabie Macro Logic family. PML is unique in its capability of performing other than two level logic functions without incurring 1/O buffer delays. This allows the logic or system designer to imbed logical operations or macro structures such as registers within the framework of the I/O pins. Since the imbedded functions are independent of the delays created by the $1 / O$ buffers, they can be performed at speeds lesser architectures cannot reproduce.
The PLHS502 features a unique clock matrix that allows the user to individually connect each of the 16 buried registers to any of 8 different clock sources. The output $\bar{Q}$ of the 8 D type and 8 S-R type registers is internally feedback to the NAND array. in addition the output $Q$ of each register is internally feedback to both the NAND array and the clock array. Thus the PML architecture eliminates the requirement of utilizing external I/O pins for register feedback paths. The PLHS502 is therefore ideally suited for both Synchronous and Asynchronous State Machines as well as event driven controller functions.
The technique used to perform this operation is a NAND foldback network which allows the direct interconnection of any number of logic nodes within the single fuse matrix. Macros can be formed and then interconnected to the I/O structure. In addition, single level and multiple level logic can be performed at speeds which reflect only the logic path utilized. Therefore, a single-level logic function has a very short path through the device. Additional levels incur only one NAND foldback delay per level. This delay is less than the combined delay created by previous generations of devices which stipulate that the logic signal must pass through I/O buffers after one or two levels of logic are performed.
The PLHS502 is fabricated in Signetics ZA Oxide-Isolated Bipolar Process which utilizes Vertical Avalanche Migration Programmed (VAMP ${ }^{\text {TM }}$ ) Fuses as programming elements. These fuses provide high programming yield and reli-

# Programmable Macro Logic Sync/Async Register Macro Unit ( $32 \times 64 \times 24$ ) 

Objective Specification

ability. Proprietary onboard test circuitry allows the PLHS502 to be thoroughly tested prior to programming.

## FEATURES

- Signetics NAND foldback architecture
- Field-Programmable
- 20 dedicated inputs
- 4 input/clock pins
- 16 buried registers
- 8 D type
- 8 S-R type
- 8 individual clocks
- 4 from dedicated input/clock pins
- 4 from NAND array
- 8 bidirectional I/O
- 16 dedicated outputs
- 8 Active-High outputs
- 4 outputs with polarity control
- 4 Tri-statable outputs with polarity control
- 64 internal NAND foldback terms
- Logic delay times:
- Single level $=\mathbf{2 2 n s}$ (max.)
- Two logic levels = 30ns (max.)
- Each additional internal NAND dieiay $=$ oñ's (max.)
- Maximum operating frequency $\mathbf{f}_{\text {MAX }}=35 \mathrm{MHz}$
- Supported by AMAZE

Development System

- Testable in unprogrammed state
- Verify Lock Fuse
- TTL compatible
- Power dissipation: 1.25W (typ.)


## APPLICATIONS

- Any digital function requiring more than 2 levels of logic
- Systems requiring state/controller functions in conjunction with random logic
- Asynchronous state machines
- Event-driven state machines
- Logic sequencers
- Ripple counters


## PIN CONFIGURATION



## Programmable Macro Logic Sync/Async Register <br> Macro Unit $(32 \times 64 \times 24)$

FUNCTIONAL DIAGRAM


## Programmable Macro Logic Sync/Async Register Macro Unit $(32 \times 64 \times 24)$



## PROGRAMMABLE MACRO LOGIC

The architectures of current Programmable Logic Devices (PLDs) generally employ programmable AND-OR gate strings to permit implementing logic functions directly in Sum-of-Products form (SOP). Often, that becomes a bottleneck which interferes with the efficient allocation of the on-chip logic resources. This becomes very apparent when considering very dense PLDs in high pin-count packages.
PML is a novel architecture which breaks the AND-OR bottleneck by relying instead on a single NAND-gate array to implement SOP logic functions, and to provide a central programmable "interconnect' site supporting a periphery of multi-level macros on a chip.

## INTRODUCTION

Today, system designers in a rush to bring their products to market are turning more than ever toward Programmable Logic Devices, lured by their blend of design elegance and efficiency with instant custom flexibility despite limitations in density and architecture.
To be sure, dramatic advances in Bipolar and CMOS processing technologies over the last decade have spawned denser and faster elements, with an occasional twist in architecture. Nevertheless, the structure of most current PLDs is still anchored on a fixed ANDOR gate chain linking primitive input, output, and function macros on a chip. Recently, to enhance the flexibility and design adaptability of early product offerings, denser devices have been introduced featuring logic macros with local programmable options and bypass circuitry.

However, as densities continue to increase, this approach is sure to breed devices with an overwhelming architectural maze which is altogether difficult to design, comprehend, and logically manipulate, complicating rather than simplifying their application.

PML, however, consists of various logic 'access' and 'process'" macros coupled via a


3


DF06440S
Figure 1. General PML Architecture Based on a Central Programmable 'Interconnect" System Interlocking Peripheral Macros


Figure 2. Typical SOP Function With Elementary AND-OR Gates
primitive, central programmable structure in the on-chip "interconnect" system (see Figure 1). Macros can have various local intelli-
gence which, in turn, may be fixed or variable by means of programmable options also embedded in the central programmable core.

# Programmable Macro Logic Sync/Async Register Macro Unit ( $32 \times 64 \times 24$ ) 

## AND-OR PLD ARCHITECTURE

From a fundamental theorem of Boolean algebra, any combinational logic function can be expressed in Sum-of-Products form involving only two levels of logic transformation. Such functions can be implemented in hardware by chaining two primitive logic macros as indicated in Figure 2.

The outputs of an AND-OR gate chains can be interlaced with higher level macros, such as flip-flops, to form sequential logic functions. These may be futher combined into standard or custom super-macros which, in turn, are interwoven into final system configurations. Presently, a number of PLDs are available which contain fixed sets of logic macros with programmable connections. Invariably, their architectures are anchored on a pair of concatenated AND-OR gate arrays, as diagrammed in Figure 3, to permit implementing logic functions directly in SOP form.
Virtually all PLDs fall in three main categories: PROM, Fixed OR, and PLA. As illustrated in Figure 4, these differ primarily in the programmability of the AND-OR gate chain which, by being irrevocably interposed as a two-level logic link between on-chip macros and 1/O paths, often can turn into a design liability.

For example, in PROMs the exponential increase in AND array size with number of inputs is a severe drawback which limits their contention in the logic application arena.

In fixed OR devices, the fixed inputs to the OR array confine their architectures to essentially a composite of AND-OR, AND-OR-register logic slices defining independent 1/O paths through the chip. This causes duplication of common product terms, and waste of unused AND gates in each slice. Also, since each slice is dedicated to an output pin, devices with registered, programmable 1/O pins entail an even greater waste of on-chip logic resources when configured in registerbypass or fixed input modes. Moreover, no single level logic functions can be constructed, except dedicated on-chip control funetions.
Finally, even as the twin programmability of the AND-OR arrays in current PLA-type devices fends greater flexibility, and may circumvent some of the above problems, it does pose difficult process, design and performance compromises in migrating toward more dense structures.

Thus, on the whole, the AND-OR gate chain forms a bottleneck which can impair the fragmentation and reallocation of the on-chip logic resources, curtailing the adaptability and efficiency of current PLDs in applications involving unstructured algorithms and scattered logic functions.


DFO6450S
Figure 3. Basic Architecture of Current PLDs

a. PROM: Programmable OR

b. PAL*: Programmable AND


Do6790S
c. PLA: Programmable AND-OR

Figure 4. Programmable AND-OR Chain of Current PLDs

## NAND-NAND GATE

## EQUIVALENCE

One way of relieving the burden placed on PLDs' architecture by the AND-OR gate string is to do away with it aliogether, and replace it with a new programmable structure forged out of a new compromise on silicon between 'interconnect' redundancy and ease of design and application. The approach adopted for PML is based on the fundamental equivalence between two-level AND-OR and NAND-NAND gate constructs in expressing combinatorial logic functions in SOP form, as illustrated in Figure 5.

Since programmable NAND-NAND logic chains can be formed by coupling identical NAND gates with programmable inputs, the NAND-array string in Figure 6 can be implemented as a single global array with feedback.
A basic NAND-array core linking a periphery of primitive macros is shown in Figure 7. When the feedback path is just a simple wire, the NAND-array can be fragmented into sin-gle-level or double-level true/complement logic functions by programming respectively single ( $a-c-d$ ), or double ( $a-b-c-d$ ), interconnecting paths thiough the array from inputs $i$ to output $F$.

More complex functions can be implemented by programming multi-level logic loops through the array.


Figure 5. Equivalent NAND-NAND SOP Expression


Figure 6. NAND-NAND Gate Chain Compressed Into a Single Array With Feedback


LD08810S
Figure 7. Elementary NAND Array Linking Primitive Macros. Note That No Programmable Connection is Implied at a Cross of a Solid Line With a Dotted Line

## BASIC PML ARCHITECTURE

The primitive NAND core can be expanded to support at its periphery a structure of logic macros of growing size and complexity, including various types of flip-flops, EX-OR gates, buffers, counters, shift registers, multiplexers, decoders, arithmetic/logic units, memories, etc. As illustrated in the general structure of Figure 8, I/O macros would provide off-chip paths to the outside world, while FUNCTION macros looped about the array would provide the necessary logic processing capability.
In deference to trade-offs in functionality and speed imposed by the array size and loading, Type-1 Output (or Function) macros may be driven directly from NAND gates, while Type2 macros may be driven by gates first looped through the array. There are virtually no limits to the number, size, and functionality of the on-chip macros surrounding the central core, other than those imposed by processing and packaging capabilities.

The main design advantage of PML is that it relies upon a single array to interconnect all macros. This reduces the design task to that of building essentially a PROM-like programmable structure more forgiving than the double array in PLA-type devices, and more flexible than that in fixed OR devices. Also, the ability to forge the NAND core into multilevel logic paths at will increases the usage efficiency of the on-chip logic resources, and greatly enhances the versatility of PML in most applications.

## THE FIRST PML OFFERING

The first PML device, designated PLHS501, is primarily a combinational logic device including only primitive macros. It is a "gate bucket" whose deceptively simple structure can implement virtually alf logic functions provided by existing combinational PAL/PLA-type devices. Also, it is the first to provide true EXOR output functions (in addition to output polarity inversion), as well as multi-level gate
constructs and cross-coupled latches on-chip without involving output pins. These are shown in Figure 9.
Built with Signetics' proprietary ZA oxide isolation process, and vertical fuses, the PLHS501 has a NAND matrix about the size of a 16 k -bit PROM. With a typical ICc of 250 mA , it features maximum input to output delays of $18 / 26$ ns over the commercial temperature range, reflecting respectively single and double passes through the NAND array. Assuming a conservative "interconnect" factor of $20 \%$, the PLHS501 has a density roughly equivalent to 1,5002 -input NAND gates.
The PLHS501 is the first member of a growing family of devices slated for future introduction. Built with either Bipolar or Erasable CMOS technologies, these will incorporate sets of higher level macros, leading to devices with greater logic power and a more efficient utilization of the on-chip interconnect system.

## Section 4 PLD Data Sheets

## INDEX

## Section 4 - PLD Data Sheets

Series 20
PLS151 Field-Programmable Gate Array $(18 \times 15 \times 12) \ldots \ldots .$. 4-3
PLS153 Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) ........ $4-9$
PLS153A Field-Programmable Logic Array $(18 \times 42 \times 10) \ldots . . .$. 4-15
PLHS153 Field-Programmable Logic Array $(18 \times 42 \times 10) \ldots \ldots$. 4-21
PLS155 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ).. 4 -27
PLS157 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ).. 4 -37
PLS159 Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ).. 4 4-47
PLS159A
Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ).. $4-57$
PLHS18P8A Programmable AND Array Logic $(18 \times 72 \times 8) \ldots \ldots .$. ...... 4-67

## Signetics

## Application Specific Products

- Series 20


## DESCRIPTION

The PLS151 is a single level logic element, consisting of 15 AND gates with fusible link connections for programming I/O polarity, 1/O direction and output enable control.
All gates are linked to 6 inputs (I) and 12 bidirectional I/O lines (B). These yield variable I/O gate configurations via 3 direction controi gates (D), ranging from 18 inputs to 12 outputs.

On chip T/C buffers couple either True (I, B) or Complement ( $\bar{I}, \bar{B}$ ) input polarities to each AND gate. The polarity of all gate outputs is individually programmable through a set of EX-OR gates for implementing AND/NAND logic functions. Alternately, if desired, OR/NOR logic functions can also be realized by programming for each gate the complement of its inputs and outputs (DeMorgan's Theorem).
The PLS151 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.

Order codes are contained on the pages following.

## FUNCTIONAL DIAGRAM



Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr link)
- 6 inputs
- 15 product terms:
- 12 logic terms
- 3 control terms
- 12 bidirectional I/O lines
- Active-High or -Low outputs
- Programmable output enable
- Power dissipation: 575 mW (typ.)
- I/O propagation delay: 25ns (max.)
- Input loading: $-100 \mu \mathrm{~A}$ (max.)
- TTL compatible
- Tri-state outputs


## APPLICATIONS

- Random gating functions
- Address decoding
- Code detectors
- Memory mapped I/O
- Fault monitors
- I/O port decoders


# PLS151 <br> Field-Programmable Gate Array ( $18 \times 15 \times 12$ ) 

PIN CONFIGURATIONS


## LOGIC FUNCTION

TYPICAL OUTPUT FUNCTIONS: ACTIVE-HIGH

$$
X=A \cdot \bar{B} \cdot C \cdot \ldots
$$

ACTIVE-LOW

$$
\begin{aligned}
& X=\overline{A \cdot \bar{B} \cdot C \cdot} \bar{A} \\
& X=\bar{A}+B+\bar{C}+\ldots
\end{aligned}
$$

## NOTES:

1. For each of the 12 outputs, either function $X$ (Active-High) or $\bar{X}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $X, A, B, C$, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

## Field-Programmable Gate

Array ( $18 \times 15 \times 12$ )

FPGA LOGIC DIAGRAM


Field-Programmable Gate
Array ( $18 \times 15 \times 12$ )

ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS151N |
| 20-pin Piastic Leaded Chip Carrier | PLSi51A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING ${ }^{1}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| Iout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \\ \hline \end{gathered}$ | $\begin{gathered} +75 \\ +150 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | Low High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=M a x \\ V_{C C}=M_{i n}, \operatorname{l}_{\mathbb{N}}=-12 m A \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} \hline 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $v_{O L}$ $\mathrm{V}_{\mathrm{OH}}$ | Low High | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{l}_{\mathrm{OL}}=10 \mathrm{~mA} \\ & \mathrm{IOH}^{2}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current ${ }^{7}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{iH}} \end{aligned}$ | Low High | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Max} \\ & \mathrm{~V}_{\mathrm{IN}}=0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{iN}}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> ios | $\mathrm{Hi}-\mathrm{Z}$ state <br> Short circuit ${ }^{4,5}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & 0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ mA |
| Icc | $V_{\text {CC }}$ supply current | $V_{C C}=$ Max |  | 115 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{C}_{\mathrm{IN}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & V_{\mathrm{IN}}=2.0 \mathrm{~V} \\ & V_{B}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

[^6]Field-Programmable Gate

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 16 | 25 | ns |
| toe | Output enable | Output - | Input $\pm$ |  |  | 17 | 25 | ns |
| tod | Output disable ${ }^{6}$ | Ouput + | Input $\pm$ | $C_{L}=5 \mathrm{pF}$ |  | 17 | 25 | ns |

NOTES:

1. Stresses above those listed under 'Absolute Maximum Ratings' may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All typica! values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one pin at a time.
5. Duration of short circuit should not exceed 1 second.
6. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
7. $I_{\text {IL }}$ and $I_{H H}$ limits are for dedicated inputs only ( $\mathrm{I}_{\mathrm{O}}-\mathrm{I}_{\mathrm{S}}$ ).

## TEST LOAD CIRCUIT



## TIMING DEFINITIONS

tpD Propagation delay between input and output.
toD Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toe
Delay between input change and when output reflects specified output level.

TIMING DIAGRAM


VOLTAGE WAVEFORM


MEASUREMENTS:
All circuit delays are measured at the +1.5 V levei of inputs and outputs, unless otherwise specified.

Input Pulses

## Field-Programmable Gate <br> Array ( $18 \times 15 \times 12$ )

## LOGIC PROGRAMMING

In a virgin device all Ni-Cr links are intact.
The FPGA can be programmed by means of Logic programming equipment.

With Logic programming, the AND/EX-OR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.

In this Table the logic state of variables I and $B$ associated with each gate $G_{n}, D_{n}$ is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at ' H ' polarity.
2. All $P_{n}$ terms are disabled.
3. All $P_{n}$ terms are active on all outputs.
4. All $B$ terms are I/O unless otherwise programmed.

## I/O DIRECTION - (B)



## OUTPUT POLARITY - (B)





NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $P_{n}$ will be unconditionally inhibited if both the true and complement of an input (either $\mid$ or $B$ ) are left intact.

Field-Programmable Gate
Array ( $18 \times 15 \times 12$ )

FPGA PROGRAM TABLE


## Signetics

## Application Specific Products

 - Series 20
## DESCRIPTION

The PLS153 is a two-level logic element, consisting of 42 AND gates and 10 OR gates with fusible link connections for programming I/O polarity and direction.
All AND gates are linked to 8 inputs (I) and 10 bidirectional I/O lines ( $B$ ). These yield variable I/O gate configurations via 10 direction control gates (D), ranging from 18 inputs to 10 outputs.
On chip T/C buffers couple either True (I, B) or Compiement ( $(\bar{i}, \bar{B})$ input poiarities to all AND gates, whose outputs can be optionally linked to all OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.
The PLS153 is field programmable, enabling the user to quickly generate custom patierns using standard programming equipment.
Order codes are contained on the pages following.

## PLS153

# Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) 

Signetics Programmable Logic<br>Product Specification

## FEATURES

- Field-Programmable (Ni-Cr links)
- 8 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or -Low outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- 1/O propagation delay: 40ns (max.)
- Input loading: - $100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 650mW (typ.)
- Tri-state outputs
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing

FUNCTIONAL DIAGRAM


PIN CONFIGURATION


## LOGIC FUNCTION

TYPical fnocuct tenan:
$\mathrm{Pn}_{\mathrm{n}}=\mathrm{A} \cdot \mathrm{B} \cdot \mathrm{C} \cdot \mathrm{D} \cdot \ldots$
TYPICAL LOGIC FUNCTION:
AT OUTPUT POLARITY $=\mathrm{H}$ $Z=P 0+P 1+P 2 \ldots$

AT OUTPUT POLARITY $=\mathrm{L}$ $\mathbf{Z}=\overline{\mathbf{P} 0+\mathbf{P} 1+\mathbf{P 2} \mathbf{+} \ldots}$ $\mathbf{Z}=\overline{\mathbf{P 0}} \cdot \overline{\mathrm{P} 1} \cdot \overline{\mathrm{P} 2} \cdot \ldots$

## NOTES:

1. For each of the 10 outputs, either function $Z$ (Active-High) or $\bar{Z}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $Z, A, B, C$, etc. are 1 ser defined connections to fixed inputs ( 1 ) and bidirectional pins (B).

## Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

FPLA LOGIC DIAGRAM


## Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS153N |

## ABSOLUTE MAXIMUM RATINGS ${ }^{\star}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :--- | :--- | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $V_{I N}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{IN}}$ | Input currents | -30 | +30 | mA |
| $\mathrm{I}_{\text {OUT }}$ | Output currents |  | +100 | mA |
| $\mathrm{~T}_{\text {A }}$ | Temperature range <br> Operating <br> Storage | 0 <br> $\mathrm{~T}_{\text {STG }}$ | +75 | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

The PLS153 device is also processed to military requirements for operation over the military temperature range. For specifications and ordering information consult the Signetics Military Data Book.

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{LI}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | Low High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\text { Min } \\ V_{C C}=M a x \\ V_{C C}=M i n^{2}, \mathbb{I}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | $\begin{aligned} & \text { Low }^{3,5} \\ & \mathrm{High}^{3,6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{l}_{\mathrm{OL}}=15 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current ${ }^{11}$ |  |  |  |  |  |  |
| $\begin{aligned} & i_{\mathrm{IL}} \\ & i_{\mathrm{IH}} \\ & \hline \end{aligned}$ | Low Hign | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{\text {IN }}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{10}$ Short circuit ${ }^{4,6,7}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{\text {CC }}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 130 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{C}_{\mathbb{N}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & V_{I N}=2.0 \mathrm{~V} \\ & V_{B}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

[^7]AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 30 | 40 | ns |
| toe | Output enable | Output- | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 25 | 35 | ns |
| $\mathrm{t}_{\mathrm{OD}}$ | Output disable ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 25 | 35 | ns |

NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with +10 V applied to $\mathrm{I}_{7}$.
6. Measured with +10 V applied to $\mathrm{I}_{0-7}$. Output sink current is supplied through a resistor to $\mathrm{V}_{\mathrm{CC}}$.
7. Duration of short circuit should not exceed 1 second.
8. $\mathrm{I}_{\mathrm{CC}}$ is measured with $\mathrm{I}_{0}, \mathrm{I}_{1}$ at $0 \mathrm{~V}, \mathrm{I}_{2}-\mathrm{I}_{7}$ and $\mathrm{B}_{0-9}$ at 4.5 V .
9. Measured at $\mathrm{V}_{T}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.
11. $\mathrm{I}_{\mathrm{IL}}$ and $\mathrm{I}_{\mathrm{IH}}$ limits are for dedicated inputs only $\left(!_{0}-I_{7}\right)$.

## TEST LOAD CIRCUIT


tpD Propagation delay between input and output.
toD Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toe Delay between input change and when output reflects specified output level.

## TIMING DIAGRAM



## VOLTAGE WAVEFORM



## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.

In this Table the logic state of variables I, $P$, and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

OUTPUT POLARITY - (B)

"AND" ARRAY - (I, B)


OR ARRAY - (B)

|  |  |  |
| :---: | :---: | :---: | :---: |
| $P_{n}$ STATUS | CODE |  |
| ACTIVE $^{1}$ | $A$ |  |

## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $P_{n}$ will be unconditionally inhibited if both the true and complement of an input (either I or B) are left intact.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at " H ' potarity.
2. All $P_{n}$ terms are disabled.
3. All $P_{n}$ terms are active on all outputs.

Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

## FPLA PROGRAM TABLE



## Signetics

## Application Specific Products

- Series 20


## DESCRIPTION

The PLS153A is a two-level logic elements, consisting of 42 AND gates and 10 OR gates with fusible link connections for programming I/O polarity and direction.
All AND gates are linked to 8 inputs (1) and 10 bidirectional I/O lines (B). These yield variable $1 / O$ gate configurations via 10 direction control gates (D), ranging from 18 inputs to 10 outputs.

On chip T/C buffers coupie either True (I, B) or Complement ( $\overline{\mathrm{I}}, \overline{\mathrm{B}}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.
The PLS153A is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.
Order codes are contained on the pages following.

# PLS153A <br> Field-Programmable Logic Array ( $18 \times 42 \times 10$ ) 

Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr links)
- 8 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or -Low outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- 1/O propagation delay: 3ûns (max.)
- Input loading: $-100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 650mW (typ.)
- Tri-state outputs
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing


## FUNCTIONAL DIAGRAM



## Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

FPLA LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS153AN |
| 20-pin Piastic Leaded Chip Carrier | PLS153AA |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{l}_{\mathrm{iN}}$ | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{\text {IL }} \\ & V_{\text {IH }} \\ & V_{I C} \end{aligned}$ | Low <br> High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=\operatorname{Max} \\ V_{C C}=\operatorname{Min},!_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \\ & \hline \end{aligned}$ | $\begin{gathered} \text { Low }^{3,5} \\ \text { High }^{3,6} \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA} \\ & \mathrm{O}_{\mathrm{OH}}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current ${ }^{11}$ |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{H}} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Low } \\ & \text { High } \end{aligned}$ | $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{10}$ <br> Short circuit ${ }^{4,6,7}$ | $\begin{gathered} V_{\text {CC }}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{\text {CC }}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 130 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{C}_{\mathbb{N}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & V_{I N}=2.0 \mathrm{~V} \\ & V_{B}=2.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

[^8]AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| toe | Output enable | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| tod | Output disable ${ }^{9}$ | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 | ns |

NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with +10 V applied to $\mathrm{I}_{7}$.
6. Measured with +10 V applied to $\mathrm{I}_{0-7}$. Output sink current is supplied through a resistor to $\mathrm{V}_{\mathrm{CC}}$.
7. Duration of short circuit should not exceed 1 second.
8. $\mathrm{I}_{\mathrm{CC}}$ is measured with $\mathrm{I}_{0,1}$ at 0 V and $\mathrm{I}_{2-7}$ and $\mathrm{B}_{0-9}$ at 4.5 V .
9. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.
11. $I_{I H}$ and $I_{I L}$ limits are for dedicated inputs only ( $l_{0-1} I_{9}$.

TEST LOAD CIRCUIT


## TIMING DEFINITIONS

tpD Propagation delay between input and output.
toD Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toE Delay between input change and when output reflects specified output level.

TIMING DIAGRAM


VOLTAGE WAVEFORM


## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.

With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this Table the logic state of variables I, P, and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding links, defined as follows:

OUTPUT POLARITY - (B)

"AND' ARRAY - ( $1, B$ )


## OR ARRAY - (B)



## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $P_{n}$ will be unconditionally inhibited if both the true and complement of an input (either $I$ or $B$ ) are left intact.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at " H " polarity.
2. All $P_{n}$ terms are disabled.
3. All $P_{n}$ terms are active on all outputs.

## CAUTION: PLS153A TEST

## COLUUNNS

The PLS153A incorporates two columns not shown in the logic block diagram. These columns are used for in-house testing of the device in the unprogrammed state. These columns must be disabled prior to using the PLS153A in your application. If you are using a Signetics-approved programmer the disabling is accomplished during the device programming sequence. If these columns are not disabled, abnormal operation is possible.

Furthermore, because of these test columns, the PLS153A cannot be programmed using the programmer algorithm for the PLS153.

Field-Programmable Logic Array $(18 \times 42 \times 10) \quad$ PLS153A

FPLA PROGRAM TABLE


## Signetics

## Application Specific Products

- Series 20


## DESCRIPTION

The PLHS153 is a high-speed version of the PLS153 and PLS153A FPLAs. The Signetics state-of-the-art Oxide Isolated Bipolar fabrication process is employed to produce performance levels not yet achieved in devices of this complexity.
The PLHS153 is a two-level logic elements, consisting of 42 AND gates and 10 OR gates with fusible link connections for programming I/O polarity and direction.

All AND gates are linked to 8 inputs (1) and 10 bidirectional I/O lines (B). These yield variable I/O gate configurations via 10 direction control gates (D), ranging from 18 inputs to 10 outputs.

On chip T/C buffers couple either True (I, B) or Complement $(\bar{I}, \bar{B})$ input polarities to all AND gates, whose outputs can be optionaily linked io ail OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing. AND/OR or AND/NOR logic functions.
The PLHS153 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.

PLHS153
Field-Programmable Logic
Array $(18 \times 42 \times 10)$

Signetics Programmable Logic<br>Preliminary Specification

## FEATURES

- Field-Programmable
- Functionally idientical to PLS153/ 153A
- 8 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or -Low outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- I/O propagation delay: $20 n s$ (max.)
- Input loading: $-100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 650mW (typ.)
- Tri-state outputs
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing

FUNCTIONAL DIAGRAM


## PIN CONFIGURATIONS



LOGIC FUNCTION

TYPICAL PRODUCT TERM:
$P n=A \cdot B \cdot C \cdot D \cdot \ldots$
TYPICAL LOGIC FUNCTION: AT OUTPUT POLARITY $=\mathrm{H}$ $\mathbf{Z}=\mathbf{P 0}+\mathbf{P 1}+\mathbf{P 2} \ldots$

AT OUTPUT POLARITY $=\mathrm{L}$ $Z=\bar{P} 0+P 1+P 2+\ldots$ $\mathbf{Z}=\overline{\mathbf{P} 0} \cdot \overline{\mathbf{P} 1} \cdot \overline{\mathbf{P} 2} \ldots$

## NOTES:

1. For each of the 10 outputs, either function $Z$ (Active-High) or $\bar{Z}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. Z, A, B, C, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

## Field-Programmable Logic Array ( $18 \times 42 \times 10$ )

FPLA LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 20-pin Plastic DIP 300mil-wide | PLHS153N |
| 20 -pin Plastic Leaded Chip Carrier | PLHS153A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voliage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voitage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \\ \hline \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

The PLHS153 device is also processed to military requirements for operation over the military temperature range. For specifications and ordering information consult the Signetics Military Data Book.

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | Low <br> High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\text { Min } \\ V_{C C}=M_{C O} \\ V_{C C}=M_{\text {in }}, I_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | $\begin{aligned} & \text { Low }^{3,5} \\ & \text { High }^{3,6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOL}^{\mathrm{OL}}=15 \mathrm{~mA} \\ & \mathrm{IOH}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current ${ }^{11}$ |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{LL}} \\ & I_{\mathrm{IH}} \\ & \hline \end{aligned}$ | Low High | $\begin{aligned} & V_{\mathrm{CC}}=M a x \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{10}$ <br> Short circuit ${ }^{4,6,7}$ | $\begin{aligned} V_{\text {CC }} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| $\mathrm{I}_{\mathrm{C}}$ | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{8}$ | $\mathrm{V}_{\text {CC }}=\mathrm{Max}$ |  | 130 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{C}_{\mathrm{IN}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{aligned} & V_{\mathrm{CC}}=5 \mathrm{~V} \\ & V_{\mathrm{iN}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{B}}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

[^9]AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | то | FROM | TEST CONDITIONS | LImits |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 14 | 20 | ns |
| toe | Output enable | Output- | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 16 | 20 | ns |
| tod | Output disable ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 14 | 20 | ns |

NOTES:

1. Stresses above those listed under 'Absolute Maximum Ratings' may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with +10 V applied to $\mathrm{I}_{5}$.
6. Output sink current is supplied through a resistor to $\mathrm{V}_{\mathrm{CC}}$.
7. Duration of short circuit should not exceed 1 second.
8. ICC is measured with all pins $=$ open or 4.5 V .
9. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.
11. I $I_{L}$ and $I_{I_{H}}$ limits are for dedicated inputs only $\left(I_{0-17}\right)$.

## TEST LOAD CIRCUIT



## TIMING DEFINITIONS

$t_{P D} \quad$ Propagation delay between input and output.
toD Delay between input change and when output is off (Hi-Z or High).
toE Delay between input change and when output reflects specified output level.

## TIMING DIAGRAM



## VOLTAGE WAVEFORM



## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to imiplement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this Table the logic state of variables I, P, and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

OUTPUT POLARITY - (B)

"AND" ARRAY - (I, B)


## OR ARRAY - (B)

|  <br> L502010S |  |  |  |
| :---: | :---: | :---: | :---: |
| $P_{\mathrm{n}}$ STATUS | CODE | $\mathrm{P}_{\mathrm{n}}$ STATUS | CODE |
| ACTIVE | A | INACTIVE ${ }^{1}$ | - |

## NOTES:

1. This is the initial unprogrammed state of all links. It is normally associated with all unused (inactive) AND gates $P_{n}, D_{n}$
2. Any gate $P_{n}$ will be unconditionally inhibited if both the true and complement of an input (either $I$ or $B$ ) are programmed for a connection.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at "L" polarity.
2. All $P_{n}$ terms are enabled.
3. All $P_{n}$ terms are inactive on all outputs.

FPLA PROGRAM TABLE


## Signetics

## Application Specific Products

- Series 20


## DESCRIPTION

The PLS155 is a Tri-state output, registered logic element combining AND/OR gate arrays with clocked J-K flip-flops. These J-K flip-flops are dynamically convertible to D-type via a "fold-back" inverting buffer and control gate $\mathrm{F}_{\mathrm{C}}$. It features 4 registered I/O outputs ( $F$ ) in conjunction with 8 bidirectional I/O lines (B). These yield variable I/O gate and register configurations via control gates (D, L) ranging from 16 inputs to 12 outputs.

The AND/OR arrays consist of 32 logic AND gates, 13 control AND gates, and 21 OR gates with fusible link connections for programming I/O polarity and direction. All AND gates are linked to 4 inputs (I), bidirectional I/O lines (B), internal flip-flop outputs $(Q)$, and Complement Array output ( $\overline{\mathrm{C}}$ ). The Complement Array consists of a NOR gate optionalily linked to aii AND gates for generating and propagating complementary AND terms.

PLS155
Field-Programmable Logic
Sequencer $(16 \times 45 \times 12)$
Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr link)
- 4 dedicated inputs
- 13 control gates
- 32 AND gates
- 21 OR gates
- 45 product terms:
- 32 logic terms
- 13 control terms
- 8 bidirectional I/O lines
- 4 bidirectional registers
- J-K, T, or D-type flip-flops
- Asynchronous Preset/Reset
- Complement Array
- Active-High or -Low outputs
- Programmable $\overline{O E}$ control
- Positive edge-triggered clock
- Clock frequency: 15 MHz (max.)
- input loading: $=100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 750mW (typ.)
- TTL compatible
- Tri-state outputs

FUNCTIONAL DIAGRAM


On-chip T/C buffers couple either True (I, B, Q) or Complement ( $\overline{\mathrm{I}}, \overline{\mathrm{B}}, \overline{\mathrm{Q}}, \overline{\mathrm{C}}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. One group of AND gates drives bidirectional I/O lines (B), whose output polarity is individually programmable through a set of EX-OR gates for implementing AND-OR or AND-NOR logic functions. Another group drives the J-K inputs of all flip-flops. The Asynchronous Preset and Reset lines ( $\mathrm{P}, \mathrm{R}$ ), are driven from the OR matrix.
All flip-flops are positive edge-triggered and can be used as input, output or I/O (for interfacing with a bidirectional data bus) in conjunction with load control gates (L), steering inputs ( I , ( B ), ( Q ) and programmable output select lines (E).

The PLS155 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.
Order codes are contained on the pages following.

## VIRGIN STATE

The factory shipped virgin device contains all fusible links intact, such that:

1. $\overline{O E}$ is always enabled.
2. Preset and Reset are always disabled.
3. All transition terms are disabled.
4. All flip-flops are in D-mode unless otherwise programmed to $\mathrm{J} / \mathrm{K}$ only or $\mathrm{J} / \mathrm{K}$ or D (controlled).
5. All $B$ pins, are inputs and all $F$ pins are outputs unless otherwise programmed.

## LOGIC FUNCTION



## NOTES:

Similar logic functions are applicable for $D$ and $T$ mode flip-flops.

## FLIP-FLOP TRUTH TABLE

| $\overline{O E}$ | L CK P R J K | Q | F |
| :---: | :---: | :---: | :---: |
| H |  |  | Hi-Z |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{llllll} X & X & H & L & X & X \\ X & X & L & H & X & X \end{array}$ | H | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{array}{llllll} L & \uparrow & L & L & L & L \\ L & \uparrow & L & L & L & H \\ L & \uparrow & L & L & H & L \\ L & \uparrow & L & L & H & H \end{array}$ | Q <br>  <br>  | $\begin{aligned} & \bar{Q} \\ & H \\ & L \\ & Q \end{aligned}$ |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{llllll} \hline H & \uparrow & L & L & L & H \\ H & \uparrow & L & L & H & L \end{array}$ | L | $\begin{aligned} & \mathrm{H}^{*} \\ & \mathrm{~L}^{*} \end{aligned}$ |
| +10V | $\begin{array}{llllll} \hline X & \uparrow & X & X & L & H \\ X & \uparrow & X & X & H & L \end{array}$ | L | $\begin{aligned} & \mathrm{H}^{* *} \\ & \mathrm{~L}^{* *} \end{aligned}$ |

NOTES:

1. Positive Logic:

$$
J / K=T_{0}+T_{1}+T_{2} \quad \ldots \ldots \ldots \ldots \ldots T_{31}
$$

$$
T_{n}=\bar{C} \cdot\left(I_{0} \cdot 1_{1} \cdot 1_{2} \ldots\right) \cdot\left(Q_{0} \cdot Q_{1} \ldots\right) \cdot\left(B_{0} \cdot B_{1} \cdot \ldots\right)
$$

2. Idenotes transition from Low to High level.
3. $X=$ Don't care
4. ${ }^{*}=$ Forced at $F_{n}$ pin for loading $J / K$ flip-flop in $1 / O$ mode. L must be enabled; and other active $\mathrm{T}_{\mathrm{n}}$ disabled via steering input(s) I, B, or Q.
5. At $P=R=H, Q=H$. The final state of $Q$ depends on which is released first.
6.     *         * = Forced at $\mathrm{F}_{\mathrm{n}}$ pin to load J/K flip-flop independent of program code (Diagnostic mode), Tri-state B outputs.

FPLS LOGIC DIAGRAM


ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS155N |
| 20-pin Plastic Leaded Chip Carrier | PLS155A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{\text {cc }}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| lout | Output currents |  | + 100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{H}} \\ & \mathrm{~V}_{\mathrm{II}} \\ & \mathrm{~V}_{\mathrm{I}} \end{aligned}$ | High <br> Low <br> Clamp | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\operatorname{Min} \\ V_{C C}=\text { Min, }_{\mathrm{I}_{\mathbb{N}}}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | 0.8 -1.2 | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | High Low | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =10 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.5 | V |
| Input current ${ }^{\text {8 }}$ |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 80 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| 10 (OFF) los | Hi-Z state ${ }^{8}$ <br> Short circuit ${ }^{4}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 -1 | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{C C}$ supply current ${ }^{7}$ | $\mathrm{V}_{C C}=\mathrm{Max}$ |  | 150 | 190 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ \mathrm{~V}_{\text {IN }} & =2.0 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | 8 <br> 15 |  | pF |

## NOTES:

1. Stresses above those listed under 'Absolute Maximum Ratings' may cause malfunction or permanent damage to the device. This is a stress rating only.

Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I H}$ applied to $\overline{O E}$.
6. Duration of short circuit should not exceed 1 second.
7. $\mathrm{I}_{\mathrm{CC}}$ is measured with the $\overline{\mathrm{OE}}$ input grounded, all other inputs at 4.5 V , and the outputs open.
8. Leakage values are a combination of input and output leakage.

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | то | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min ${ }^{5}$ | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {CKH }}$ | Clock ${ }^{2}$ high | CK - | CK + |  | 25 | 20 |  |  |
| $t_{\text {ckL }}$ | Clock low | CK + | CK - | $C_{L}=30 \mathrm{pF}$ | 30 | 20 |  | ns |
| $\mathrm{t}_{\text {cKP }}$ | Period | CK + | CK + |  | 70 | 50 |  |  |
| tpri | Preset/Reset pulse | $(1, B)+$ | ( $1, \mathrm{~B}$ ) - |  | 40 | 30 |  |  |
| Setup time |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {IS }}{ }_{\text {c }}$ | Input | CK + | $(1, B) \pm$ |  | 40 | 30 |  |  |
| $\mathrm{t}_{1 / 2}$ | Input (through $\mathrm{F}_{\mathrm{n}}$ ) | CK + | $\mathrm{F} \pm$ | $C_{L}=30 \mathrm{pF}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{1} 3$ | Input (through Complement Array) ${ }^{4}$ |  | $(1, B) \pm$ |  |  |  |  |  |
| Hold time |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {H1 }}$ | Input | CK + | ( $1, \mathrm{~B}) \pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ | 0 | -10 |  | ns |
| $\mathrm{t}_{\mathrm{H} 2}$ |  | CK + | F $\pm$ |  | 15 | 10 |  |  |
| Propagation delays |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CKO}}$ | Clock | $\mathrm{F} \pm$ | CK + | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 25 | 30 | ns |
| toel | Output enable | F - | OE - | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 |  |
| todi | Output disable ${ }^{3}$ | F + | $\overline{\mathrm{O}}+$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 |  |
| $t_{\text {PD }}$ | Output | B $\pm$ | $(1, B) \pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 40 | 50 |  |
| toe2 | Output enable | B $\pm$ | $(1, B)+$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 | 55 |  |
| tooz | Output disable ${ }^{3}$ | B + | $(1,8)-$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 30 | 35 |  |
| tpRo | Preset/Reset | F $\pm$ | $(1, B)+$ | $C_{L}=30 \mathrm{pF}$ |  | 50 | 55 |  |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 10 \mathrm{~ns}$
3. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
4. When using the Complement Array $\mathrm{T}_{\mathrm{CKP}}=95 \mathrm{~ns}$ (min).
5. Limits are guaranteed with 12 product terms maximum connected to each sum term line.
6. For test circuits, waveforms and timing diagrams see the following pages.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

## TEST LOAD CIRCUIT



## TIMING DIAGRAMS



## VOLTAGE WAVEFORM



## TIMING DEFINITIONS

$\mathrm{t}_{\mathrm{CKH}} \quad$ Width of input clock pulse. $t_{\text {CKL }} \quad$ Interval between clock pulses.
$t_{\text {CKP }} \quad$ Clock period.
$t_{\text {PRH }} \quad$ Width of preset input pulse.
$t_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of clock.
$t_{I S 2} \quad$ Required delay between beginning of valid input forced at flip-flop output pins, and positive transition of clock.
$t_{\mid+1} \quad$ Required delay between positive transition of clock and end of valid input data.
$\mathrm{t}_{1+\mathrm{H} 2} \quad$ Required delay between positive transition of clock and end of valid input data forced at flip-flop output pins.
tcko Delay between positive transition of clock and when Outputs become valid (with $\overline{\mathrm{OE}}$ low).
toE1 Delay between beginning of Output Enable Low and when Outputs become valid.
toD1 Delay between beginning of Output Enable High and when Outputs are in the off state.
$t_{P D} \quad$ Propagation delay between combinational inputs and outputs.
toe2 Delay between predefined Output Enable High, and when combinational Outputs become valid.
toD2 Delay between predefined Output Enable Low, and when combinational Outputs are in the off state.
tpro Delay between positive transition of predefined Preset/Reset input, and when flip-flop outputs become valid.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

TIMING DIAGRAMS (Continued)



The FPLS can be programmed by means of Logic Programming equipment.
With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these tables, the logic state or action of all I/O, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links, defined as follows:
"AND"' ARRAY - (I), (B), ( $\mathbf{Q}_{\mathrm{p}}$ )

"COMPLEMENT" ARRAY - (C)

"OR" ARRAY - (MODE)


Notes on following page.
"OR" ARRAY - ( $\mathrm{Q}_{\mathrm{n}}=\mathrm{D}$-Type $)$

"OR" ARRAY - $\left(Q_{n}=\mathrm{J}-\mathrm{K}\right.$ Type $)$

"OR" ARRAY - (S or B), (P), (R)
"EX-OR' ARRAY - (B)

" $\overline{O E}$ " ARRAY - (E)


NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate ( $\left.T, \mathrm{~F}_{\mathrm{C}}, \mathrm{L}, \mathrm{P}, \mathrm{R}, \mathrm{D}\right)_{\mathrm{n}}$ will be unconditionally inhibited if both of the $\mathrm{I}, \mathrm{B}$, or Q links are left intact.
3. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}, F_{C}$.
4. $E_{n}=O$ and $E_{n}=\cdot$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates ( $L, P, R, D)_{n}$ due to their lack of "OR" array links.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )
PLS155

FPLS PROGRAM TABLE


## Signetics

## Application Specific Products - Series 20

## DESCRIPTION

The PLS157 is a Tri-state output, registered logic element combining AND/OR gate arrays with clocked J-K flip-flops. These J-K flip-flops are dynamically convertible to D-type via a "fold-back" inverting buffer and control gate $\mathrm{F}_{\mathrm{C}}$. It features 6 registered I/O outputs ( $F$ ) in conjunction with 6 bidirectional I/O lines (B). These yield variable I/O gate and register configurations via control gates (D, L) ranging from 16 inputs to 12 outputs.
The AND/OR arrays consist of 32 logic AND gates, 13 control AND gates, and 21 OR gates with fusible link connections for programming I/O polarity and direction. All AND gates are linked to 4 inputs (I), bidirectional $1 / O$ lines ( $B$ ), internal flip-flop outputs ( Q ), and Complement Array output ( $\overline{\mathrm{C}}$ ). The Complement Array consists of a NOR gate optionally linked to all AND gates for generating and propagating complementary AND terms.

# PLS157 <br> Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ ) 

## Signetics Programmable Logic <br> Product Specification

## FEATURES

- Field-Programmable (Ni-Cr link)
- 4 dedicated inputs
- 13 control gates
- 32 AND gates
- 21 OR gates
- 45 product terms:
- 32 logic terms
- 13 control terms
- 6 bidirectional I/O lines
- 6 bidirectional registers
- J-K, T, or D-type flip-flops
- Tri-state outputs
- Asynchronous Preset/Reset
- Complement Array
- Active-High or -Low outputs
- Programmable $\overline{0 E}$ control
- Positive edge-triggered clock
- Clock frequency: 15 MHz (max.)
- Input loading: $-100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 750mW (typ.)
- TTL compatible


## FUNCTION DIAGRAM



On-chip T/C buffers couple either True (I, B, Q) or Complement ( $\bar{I}, \overline{\mathrm{~B}}, \overline{\mathrm{Q}}, \overline{\mathrm{C}}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. One group of AND gates drives bidirectional I/O lines (B), whose output polarity is individually programmable through a set of EX-OR gates for implementing AND-OR or AND-NOR logic functions. Another group drives the J-K inputs of all flip-flops. The Asynchronous Preset and Reset lines ( $\mathrm{P}, \mathrm{R}$ ), for two of the registers are driven from the AND matrix. The Preset and Reset lines ( $P, R$ ) controlling the lower four registers are driven from the OR matrix.
All flip-flops are positive edge-triggered and can be used as input, output or I/O (for interfacing with a bidirectional data bus) in conjunction with load control gates (L), steering inputs ( 1 ), ( $B$ ), $(Q)$ and programmable output select lines (E).

The PLS157 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.
Order codes are contained on the pages following.

## VIRGIN STATE

The factory shipped virgin device contains all fusible links intact, such that:

1. $\overline{O E}$ is always enabled.
2. Preset and Reset are always disabled.
3. All transition terms are disabled.
4. All flip-flops are in D-mode unless otherwise programmed to $\mathrm{J} / \mathrm{K}$ only or $\mathrm{J} / \mathrm{K}$ or D (controlled).
5. All $B$ pins are inputs and all $F$ pins are outputs unless otherwise programmed.

## LOGIC FUNCTION



NOTES:
Similar logic functions are applicable for $D$ and $T$ mode flip-flops.

## FLIP-FLOP TRUTH TABLE

| $\overline{O E}$ | L CK P R J K | Q | F |
| :---: | :---: | :---: | :---: |
| H |  |  | Hi-Z |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{llllll} X & X & H & L & X & X \\ X & X & L & H & X & X \end{array}$ | $\begin{aligned} & H \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{array}{llllll} \hline L & \uparrow & L & L & L & L \\ L & \uparrow & L & L & L & H \\ L & \uparrow & L & L & H & L \\ L & \uparrow & L & L & H & H \end{array}$ | $\begin{aligned} & \mathrm{Q} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \bar{Q} \end{aligned}$ | $\begin{aligned} & \bar{Q} \\ & H \\ & L \\ & Q \end{aligned}$ |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{llllll} H & \uparrow & L & L & L & H \\ H & \uparrow & L & L & H & L \end{array}$ | L | $\mathrm{H}^{*}{ }^{\text {* }}$ |
| +10V | $\begin{array}{llllll} \hline X & \uparrow & X & X & L & H \\ X & \uparrow & X & X & H & L \end{array}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H}^{* *} \\ & \mathrm{~L}^{* *} \end{aligned}$ |

NOTES:

1. Positive Logic:

$$
J / K=T_{0}+T_{1}+T_{2} \ldots \ldots \ldots \ldots . . T_{31}
$$

$T_{n}=\bar{C} \cdot\left(I_{0} \cdot 1_{1} \cdot I_{2} \ldots\right) \cdot\left(Q_{0} \cdot Q_{1} \ldots\right) \cdot\left(B_{0} \cdot B_{1} \cdot \ldots\right)$
2. $\uparrow$ denotes transition from Low to High level.
3. $X=$ Don't care
4. * $=$ Forced at $F_{n}$ pin for loading $\mathrm{J} / \mathrm{K}$ flip-flop in $1 / \mathrm{O}$ mode. $L$ must be enabled, and other active $T_{n}$ disabled via steering input(s) I, B, or Q.
5. At $P=R=H, Q=H$. The final state of $Q$ depends on which is released first.
6. * * $=$ Forced at $F_{n}$ pin to load J/K flip-flop independent of program code (Diagnostic mode), Tri-state 8 outputs.

## Field-Programmable Logic Sequencer $(16 \times 45 \times 12) \quad$ PLS157

## FPLS LOGIC DIAGRAM



## NOTES:

1. All OR gate inputs with a blown link fioat to logic "o
2. All other gates and control inputs with a blown link float to logic " 1 ".
3. $\oplus$ denotes WIRE-OR.
4. Pabraimabla cominction.

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS157N |
| 20-pin Plastic Leaded Chip Carrier | PLS157A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voitage |  | +5.5 | $V_{D C}$ |
| 1 IN | Input currents | -30 | $+30$ | mA |
| Iout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \\ \hline \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{I H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High <br> Low <br> Clamp | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=\text { Min, } \mathbb{I}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | High | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =10 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{LL}} \end{aligned}$ | High Low | $\begin{gathered} V_{I N}=5.5 \mathrm{~V} \\ V_{I N}=0.45 \mathrm{~V} \end{gathered}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 80 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| 10 (OFF) los | $\mathrm{Hi}-\mathrm{Z}$ state $^{8}$ <br> Short circuit ${ }^{4}$ | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Max} \\ & V_{\text {OUT }}=5.5 \mathrm{~V} \\ & V_{\text {OUT }}=0.45 \mathrm{~V} \\ & V_{\text {OUT }}=0 \mathrm{~V} \end{aligned}$ | $\cdots$ | 1 -1 | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu A$ <br> mA |
| Icc | $\mathrm{V}_{\mathrm{CC}}$ supply current ${ }^{7}$ | $V_{C C}=$ Max |  | 150 | 190 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal
4. Test one at a time.
5. Measured with $\mathrm{V}_{1 \mathrm{H}}$ applied to $\overline{\mathrm{OE}}$.
6. Duration of short circuit should not exceed 1 second.
7. $I_{C C}$ is measured with the $\overline{O E}$ input grounded, all other inputs at 4.5 V , and the outputs open.
8. Leakage values are a combination of input and output leakage.

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant V_{C C} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min ${ }^{5}$ | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {CKH }}$ | Clock ${ }^{2}$ high | CK - | CK + |  | 25 | 20 |  |  |
| $\mathrm{t}_{\text {cKL }}$ | Clock low | CK + | CK - | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ | 30 | 20 |  | ns |
| $\mathrm{t}_{\text {ckP }}$ | Period | CK + | CK + |  | 70 | 50 |  |  |
| $\mathrm{t}_{\text {PRH }}$ | Preset/Reset pulse | $(1, B)+$ | ( $1, \mathrm{~B}$ ) - |  | 40 | 30 |  |  |
| Setup time |  |  |  |  |  |  |  |  |
| $t_{\text {IS } 1}$ | Input | CK + | $(1, B) \pm$ |  | 40 | 30 |  |  |
| $\mathrm{t}_{\text {IS } 2}$ | Input (through $\mathrm{F}_{\mathrm{n}}$ ) | CK + | $F \pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\mathbf{1} \times 3}$ | Input (through Complement Array) ${ }^{4}$ | CK + | $(I, B) \pm$ |  | $65$ | $40$ |  |  |
| Hold time |  |  |  |  |  |  |  |  |
| $t_{t H 1}$ | Input | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{CK}+ \end{aligned}$ | $\stackrel{(i, B)}{\text { F }} \pm$ | $C_{L}=30 p F$ | $\begin{gathered} 0 \\ 15 \end{gathered}$ | $\begin{gathered} -10 \\ 10 \end{gathered}$ |  | ns |
| Propagation delays |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {cко }}$ | Clock | $F \pm$ | CK + | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 25 | 30 | ns |
| toen | Output enable | F - | $\overline{\mathrm{OE}}$ - | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 |  |
| $\mathrm{t}_{\mathrm{OD1}}$ | Output disable ${ }^{3}$ | F + | $\overline{\mathrm{OE}}+$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 |  |
| $t_{\text {PD }}$ | Output | $\mathrm{B} \pm$ | $(1, B) \pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 40 | 50 |  |
| toe2 | Output enable | $B \pm$ | $(1, B)+$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 | 55 |  |
| tod2 | Output disable ${ }^{3}$ | B + | (1,B) - | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 30 | 35 |  |
| $\mathrm{t}_{\text {PRO }}$ | Preset/Reset | $\mathrm{F} \pm$ | $(1, B)+$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 50 | 55 |  |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 10 \mathrm{~ns}$.
3. Measured at $\mathrm{V}_{T}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
4. When using the Complement Array $\mathrm{T}_{\mathrm{CKP}}=95 \mathrm{~ns}$ (min).
5. Limits are guaranteed with 12 product terms maximum connected to each sum term line.
6. For test circuits, waveforms and timing diagrams see the following pages.

## TEST LOAD CIRCUIT



## TIMING DIAGRAMS



## VOLTAGE WAVEFORM

(3.0V

TIMING DEFINITIONS
$\left.\begin{array}{ll}\mathrm{t}_{\mathrm{CKH}} & \begin{array}{l}\text { Width of input clock pulse. } \\ \mathrm{t}_{\mathrm{CKL}} \\ \mathrm{I}_{\mathrm{CKP}}\end{array} \\ \begin{array}{l}\text { Clorval between clock pulses. }\end{array} \\ \mathrm{t}_{\text {PRH }} & \text { Width of preset input pulse. } \\ \mathrm{t}_{\mathrm{IS} 1} & \begin{array}{l}\text { Required delay between beginning } \\ \text { of valid input and positive transition }\end{array} \\ & \begin{array}{l}\text { of clock. }\end{array} \\ \mathrm{t}_{\mathrm{IS} 2} & \begin{array}{l}\text { Required delay between beginning } \\ \text { of valid input forced at flip-flop }\end{array} \\ \text { output pins, and positive transition }\end{array}\right]$
$\mathrm{t}_{\mathrm{H} 2} \quad$ Required delay between positive transition of clock and end of valid input data forced at flip-flop output pins.
tcko Delay between positive transition of clock and when Outputs become valid (with $\overline{O E}$ low).
Delay between beginning of Output Enable Low and when Outputs become valid.
toD1 Delay between beginning of Output Enable High and when Outputs are in the off state.
$t_{\text {PD }} \quad$ Propagation delay between combinational inputs and outputs.
tOE2 Delay between predefined Output Enable High, and when combinational Outputs become valid.
toD2 Delay between predefined Output Enable Low, and when combinational Outputs are in the off state.
$t_{\text {PRO }}$ Delay between positive transition of predefined Preset/Reset input, and when flip-flop outputs become valid.

TIMING DIAGRAMS (Continued)


* The leading edge of preset/reset must occur only when the input clock is 'low', and must remain "high' as long as required to override clock. The falling edge of preset/reset can never go "low' when the input clock is 'high"'.

Asynchronous Preset/Reset


The FPLS can be programmed by means of Logic Programming equipment.

With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these tables, the logic state or action of all I/O, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:
'AND' ARRAY - (I), (B), ( $\mathbf{Q}_{\mathrm{p}}$ )

"COMPLEMENT" ARRAY-(C)


Notes on following page.
"OR" ARRAY-( $\mathrm{Q}_{\mathrm{n}}=\mathrm{D}-$ Type $)$

"OR" ARRAY - $\left(Q_{n}=\mathrm{J}-\mathrm{K}\right.$ Type $)$

"OR" ARRAY - (S or B), (P), (R)

'EX-OR" ARRAY - (B)


## '"OE' ARRAY - (E)



## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate $\left(T, F_{C}, L, P, R, D\right)_{n}$ will be unconditionally innibited if both of the $i, B$, or $Q$ links are leit intact.
3. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$. $F_{C}$.
4. $E_{n}=O$ and $E_{n}=\cdot$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates (L, P, R, D) ${ }_{n}$ due to their lack of "OR" array links.

## Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

## FPLS PROGRAM TABLE



## Signetics

## Application Specific Products - Series 20

## DESCRIPTION

The PLS159 is a Tri-state output, registered logic element combining AND/OR gate arrays with clocked J-K flip-flops. These J-K flip-flops are dynamically convertible to D-type via a "fold-back" inverting buffer and control gate $\mathrm{F}_{\mathrm{C}}$. It features 8 registered I/O outputs ( $F$ ) in conjunction with 4 bidirectional I/O lines (B). These yield variable I/O gate and register configurations via control gates ( $\mathrm{D}, \mathrm{L}$ ) ranging from 16 inputs to 12 outputs.
The AND/OR arrays consist of 32 logic AND gates, 13 control AND gates, and 21 OR gates with fusible link connections for programming I/O polarity and direction. All AND gates are linked to 4 inputs (I), bidirectional I/O lines (B), internal flip-flop outputs (Q), and Complement Array output ( $\overline{\mathrm{C}}$ ). The Complement Array consists of a NOR gate optionally linked to all AND gates for generating and propagating complementary AND terms.

## PLS159

## Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

Signetics Programmable Logic<br>Product Specification

## FEATURES

- Field-Programmable (Ni-Cr link)
- 4 dedicated inputs
- 13 control gates
- 32 AND gates
- 21 OR gates
- 45 product terms:
- 32 logic terms
- 13 control terms
- 4 bidirectional !/O lines
- 8 bidirectional registers
- J/K, T, or D-type flip-flops
- Asynchronous Preset/Reset
- Complement Array
- Active-High or -Low outputs
- Programmable $\overline{O E}$ control
- Positive edge-triggered clock
- Clock frequency: 15MHz (max.)
- Input loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Power dissipation: 750mW (typ.)
- TTL compatible
- Tri-state outputs


## FUNCTIONAL DIAGRAM



## APPLICATIONS

- Random sequential logic
- Synchronous up/down counters
- Shift registers
- Bidirectional data buffers
- Timing function generators
- System conṫroiiers/synchronizers
- Priority encoder/registers

On-chip T/C buffers couple either True (I, B, Q) or Complement ( $\overline{1}, \bar{B}, \bar{Q}, \bar{C}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. One group of AND gates drives bidirectional I/O lines (B), whose output polarity is individually programmable through a set of EX-OR gates for implementing AND-OR or AND-NOR logic functions. Another group drives the J-K inputs of all flip-flops, as well as asynchronous Preset and Reset lines (P, R).

All flip-flops are positive edge-triggered and can be used as input, output or I/O (for interfacing with a bidirectional data bus) in conjunction with load control gates (L), steering inputs (I), (B), (Q) and programmable output select lines ( E ).
The PLS159 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.
Order codes are contained on the pages following.

## VIRGIN STATE

The factory shipped virgin device contains all fusible links intact, such that:

1. $\overline{O E}$ is always enabled.
2. Preset and Reset are always disabled.
3. All transition terms are disabled.
4. All flip-flops are in D-mode unless otherwise programmed to $\mathrm{J} / \mathrm{K}$ only or $\mathrm{J} / \mathrm{K}$ or D (controiled).
5. All $B$ pins are inputs and all $F$ pins are outputs unless otherwise programmed.

## LOGIC FUNCTION



## NOTE:

Similar logic functions are applicable for D and T mode flip-flops.

FLIP-FLOP TRUTH TABLE

| $\overline{\mathbf{O E}}$ | L CK P R J K | Q | F |
| :---: | :---: | :---: | :---: |
| H |  |  | Hi-Z |
| L | X X L X X X | L | H |
| $L$ | $\begin{array}{llllll} X & X & H & L & X & X \\ X & X & L & H & X & X \end{array}$ | $\begin{aligned} & H \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ |
| L L L L | $\begin{array}{llllll} L & \uparrow & L & L & L & L \\ L & \uparrow & L & L & L & H \\ L & \uparrow & L & L & H & L \\ L & \uparrow & L & L & H & H \end{array}$ | $\begin{aligned} & Q \\ & L \\ & H \\ & \hline \mathbf{Q} \end{aligned}$ | $\begin{aligned} & \bar{Q} \\ & H \\ & L \\ & Q \end{aligned}$ |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{llllll} \hline H & \uparrow & L & L & L & H \\ H & \uparrow & L & L & H & L \end{array}$ | L | $\begin{aligned} & \mathrm{H}^{*} \\ & \mathrm{~L}^{*} \end{aligned}$ |
| +10V | $\begin{array}{llllll} \hline X & \uparrow & X & \times & L & H \\ X & \uparrow & X & X & H & L \end{array}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H}^{* *} \\ & \mathrm{~L}^{* *} \end{aligned}$ |

NOTES:

1. Positive Logic:

$$
\mathrm{J} / \mathrm{K}=\mathrm{T}_{0}+\mathrm{T}_{1}+\mathrm{T}_{2} \ldots \ldots \ldots \ldots \ldots \mathrm{~T}_{31}
$$

$T_{n}=\bar{C} \cdot\left(l_{0} \cdot 1_{1} \cdot I_{2} \ldots\right) \cdot\left(Q_{0} \cdot Q_{1} \ldots\right) \cdot\left(B_{0} \bullet B_{1} \bullet \ldots\right)$
2. †denotes transition from Low to High level.
3. $X=$ Don't care
4. ${ }^{*}=$ Forced at $F_{\Pi}$ pin for loading $\mathrm{J} / \mathrm{K}$ flip-flop in $1 / \mathrm{O}$ mode. $L$ must be enabled, and other active $T_{n}$ disabled via steering input(s) I, B, or Q.
5. At $P=R=H, Q=H$. The final state of $Q$ depends on which is released first.
6. * * = Forced at $\mathrm{F}_{\mathrm{n}}$ pin to load J/K flip-flop independent of program code (Diagnostic mode), Tri-state B outputs.

## Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

FPLS LOGIC DIAGRAM


ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS159N |
| 20-pin Plastic Leaded Chip Carrier | PLS159A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C S}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| Iout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{I H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High Low Clamp | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=M i n \\ V_{C C}=\text { Min, } \operatorname{liN}_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | 0.8 -1.2 | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | High Low | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =10 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.5 | V |
| Input current ${ }^{8}$ |  |  |  |  |  |  |
| $\begin{aligned} & I_{H} \\ & I_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{C C}=M a x \\ & V_{\mathbb{I N}}=5.5 \mathrm{~V} \\ & V_{\mathbb{N}}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 80 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| IO (OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state $^{8}$ <br> Short circuit ${ }^{4}$ | $\begin{aligned} V_{\text {CG }} & =M a x \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 -1 | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| ICC | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{7}$ | $V_{C C}=M a x$ |  | 150 | 190 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | 8 15 |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I H}$ applied to $\overline{O E}$.
6. Duration of short circuit should not exceed 1 second.
7. $\mathrm{I}_{\mathrm{CC}}$ is measured with the $\overline{\mathrm{OE}}$ input grounded, all other inputs at 4.5 V , and the outputs open.
8. Leakage values are a combination of input and output leakage.

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min ${ }^{5}$ | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {ckh }}$ | Clock $^{2}$ high | CK - | CK + |  | 25 | 20 |  |  |
| $\mathrm{t}_{\mathrm{CKL}}$ | Clock low | CK + | CK - | $C_{L}=30 \mathrm{pF}$ | 30 | 20 |  | ns |
| $\mathrm{t}_{\text {CKP }}$ | Period | CK + | CK + |  | 70 | 50 |  |  |
| tpR ${ }^{\text {d }}$ | Preset/Reset pulse | $(1, B)+$ | $(1, B)-$ |  | 40 | 30 |  |  |
| Setup time |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{1} 1$ | Input | CK + | $(1, B) \pm$ |  | 40 | 30 |  |  |
| $\mathrm{t}_{15}{ }^{2}$ | Input (through $\mathrm{F}_{\mathrm{n}}$ ) | CK + | F $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{153}$ | Input (through Complement Array) ${ }^{4}$ | CK + | $(1, B) \pm$ |  | $65$ | $40$ |  |  |
| Hold time |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{t}_{1 \mathrm{H} 1} \\ & \mathrm{t}_{1 \mathrm{H} 2} \end{aligned}$ | Input | $\begin{aligned} & \text { CK + } \\ & \text { CK + } \end{aligned}$ | $\stackrel{(\mathrm{I}, \mathrm{~B})}{\mathrm{F} \pm}$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ | $\begin{gathered} 0 \\ 15 \end{gathered}$ | $\begin{gathered} -10 \\ 10 \end{gathered}$ |  | ns |
| Propagation delays |  |  |  |  |  |  |  |  |
| tско | Clock | F $\pm$ | CK + | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 25 | 30 | ns |
| toex | Output enable | F- | $\overline{\mathrm{OE}}$ - | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 |  |
| tod1 | Output disable ${ }^{3}$ | F + | $\overline{O E}+$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 35 |  |
| tpD | Output | B $\pm$ | $(1, B) \pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 40 | 50 |  |
| toe2 | Output enable | $\mathrm{B} \pm$ | $(1, B)+$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 | 55 |  |
| tod2 | Output disable ${ }^{3}$ | B + | $(1, B)-$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 30 | 35 |  |
| tpro | Preset/Reset | $\mathrm{F} \pm$ | (1,B) + | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 50 | 55 |  |

## NOTES:

1. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevents spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 10 \mathrm{~ns}$.
3. Measured at $\mathrm{V}_{T}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
4. When using the Complement Array $\mathrm{T}_{\text {CKP }}=95 \mathrm{~ns}$ (min).
5. Limits are guaranteed with 12 product terms maximum connected to each sum term line.

0 . For test circuits, waveforms and timing diagrams see the following pages.

## TEST LOAD CIRCUIT



## TIMING DIAGRAMS



WFOS471S
Flip-Flop Outputs


## VOLTAGE WAVEFORM



## TIMING DEFINITIONS

$\mathrm{t}_{\text {CKH }} \quad$ Width of input clock pulse.
$t_{\text {CKL }} \quad$ Interval between clock pulses.
$t_{\text {CKP }} \quad$ Clock period.
tpRH Width of preset input pulse.
$t_{l S 1} \quad$ Required delay between beginning of valid input and positive transition of clock.
$\mathrm{t}_{\text {IS2 }} \quad$ Required delay between beginning of valid input forced at flip-flop output pins, and positive transition of clock.
$t_{1 H 1} \quad$ Required delay between positive transition of clock and end of valid input data.
$t_{1 H 2} \quad$ Required delay between positive transition of clock and end of valid input data forced at flip-flop output pins.
$t_{\text {CKO }} \quad$ Delay between positive transition of clock and when Outputs become valid (with $\overline{O E}$ low).
toE1 Delay between beginning of Output Enable Low and when Outputs become valid.
toD1 Delay between beginning of Output Enable High and when Outputs are in the off state.
$t_{P D} \quad$ Propagation delay between combinational inputs and outputs.
toe2 Delay between predefined Output Enable High, and when combinational Outputs become valid.
toD2 Delay between predefined Output Enable Low, and when combinational Outputs are in the off state.
tPRO Delay between positive transition of predefined Preset/Reset input, and when flip-flop outputs become valid.

TIMING DIAGRAMS (Continued)



Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )
PLS159

The FPLS can be programmed by means of Logic Programming equipment.
With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these tables, the logic state or action of all I/O, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:
'AND' ARRAY - (I), (B), ( $\mathbf{Q}_{\mathrm{p}}$ )

'COMPLEMENT' ARRAY - (C)

$\left(T_{n}, F_{C}\right)$

| ACTION | CODE |
| :---: | :---: |
| INACTIVE |  |

$$
\begin{array}{|c|c|}
\hline \text { ACTION } & \text { CODE } \\
\hline \text { GENERATE }^{5} & \mathbf{A} \\
\hline & \text { LSO2000 } \\
\hline
\end{array}
$$

"OR" ARRAY - (MODE)



Notes on following page.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )
"OR" ARRAY - ( $\mathrm{Q}_{\mathrm{n}}=\mathrm{D}$-Type)

"OR" ARRAY - $\left(Q_{n}=\right.$ J-K Type $)$

"OR" ARRAY - (S or B), (P), (R)

'EX-OR' ARRAY - (B)

"OE" ARRAY - (E)


NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate ( $\left.T, F_{C}, L, P, R, D\right)_{n}$ will be unconditionally inhibited if both of the $1, B$, or $Q$ links are left intact.
3. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}, F_{C}$.
4. $E_{n}=O$ and $E_{n}=\cdot$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates ( $L, P, R, D)_{n}$ due to their lack of "OR" array links.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )
PLS159

FPLS PROGRAM TABLE


PLS159A
Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

Signetics Programmable Logic<br>Preliminary Specification

## Signetics

## Application Specific Products

## - Series 20

## DESCRIPTION

The PLS159A is a Tri-state output, registered logic element combining AND/OR gate arrays with clocked J-K flip-flops. These J-K flip-flops are dynamically convertible to D-type via a 'fold-back' inverting buffer and control gate $\mathrm{F}_{\mathrm{C}}$. It features 8 registered I/O outputs (F) in conjunction with 4 bidirectional I/O lines (B). These yield variable I/O gate and register configurations via control gates ( $\mathrm{D}, \mathrm{L}$ ) ranging from 16 inputs to 12 outputs.

The AND/OR arrays consist of 32 logic AND gates, 13 control AND gates, and 21 OR gates with fusible link connections for programming I/O polarity and direction. All AND gates are linked to 4 inputs ( 1 ), bidirectional $1 / O$ lines ( $B$ ), internal flip-fiop outputs $(Q)$, and Complement Array output ( $\overline{\mathrm{C}}$ ). The Complement Array consists of a NOR gate optionally linked to all AND gates for generating and propagating complementary AND terms.

## FEATURES

- High-speed version of PLS159
- Field-Programmable (Ni-Cr link)
- 4 dedicated inputs
- 13 control gates
- 32 AND gates
- 21 OR gates
- 45 product terms:
- 32 logic terms
- 13 control terms
- 4 bidirectional I/O lines
- 8 bidirectional registers
- J/K, T, or D-type flip-flops
- Power on reset feature on all flip-flops ( $F_{n}=1$ )
- Asynchronous Preset/Reset
- Complement Array
- Active-High or -Low outputs
- Programmable $\overline{\mathrm{OE}}$ control
- Positive edge-triggered clock
- Clock frequency: 18 MHz (max.)
- Input loading: $\mathbf{- 1 0 0 \mu A}$ (max.)
- Power dissipation: 750mW (typ.)
- TTL compatible
- Tri-state outputs

FUNCTIONAL DIAGRAM


## PIN CONFIGURATIONS



## APPLICATIONS

- Random sequential logic
- Synchronous up/down counters
- Shift registers
- Bidirectional data buffers
- Timing function generators
- System conitroilers/synchronizers
- Priority encoder/registers

On-chip T/C buffers couple either True (I, B, Q) or Complement ( $\overline{1}, \bar{B}, \bar{Q}, \bar{C}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. One group of AND gates drives bidirectional I/O lines (B), whose output polarity is individually programmable through a set of EX-OR gates for implementing AND-OR or AND-NOR logic functions. Another group drives the J-K inputs of all flip-flops, as well as asynchronous Preset and Reset lines (P, R).

All flip-flops are positive edge-triggered and can be used as input, output or I/O (for interfacing with a bidirectional data bus) in conjunction with load control gates (L), steering inputs (I), (B), ( Q ) and programmabie output select lines (E).
The PLS159A is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.

## VIRGIN STATE

The factory shipped virgin device contains all fusible links intact, such that:

1. $\overline{O E}$ is always enabled.
2. Preset and Reset are always disabled.
3. All transition terms are disabled.
4. All flip-flops are in D-mode unless otherwise programmed to $\mathrm{J} / \mathrm{K}$ only or $\mathrm{J} / \mathrm{K}$ or D (controlied).
5. All $B$ pins are inputs and all $F$ pins are outputs uniess otherwise programmed.

## LOGIC FUNCTION



NOTE:
Similar logic functions are applicable for D and T mode flip-flops.

## FLIP-FLOP TRUTH TABLE

| $\overline{\mathrm{OE}}$ | LCK P R J K | Q | F |
| :---: | :---: | :---: | :---: |
| H |  |  | Hi-Z |
| L | $\times \times \mathrm{L} \times \mathrm{X} \times$ | L | H |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{llllll} X & X & H & L & X & X \\ X & X & L & H & X & X \end{array}$ | H L | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $L \uparrow L L L L$ <br> L $\uparrow$ L L L H <br> L $\uparrow$ L L H L <br> L $\uparrow \mathrm{L}$ L H H | Q <br> L <br> H <br> Q | $\begin{aligned} & \overline{\mathrm{Q}} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{Q} \end{aligned}$ |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{llllll} \hline H & \uparrow & L & L & L & H \\ H & \uparrow & L & L & H & L \end{array}$ | L | $\begin{aligned} & \mathrm{H}^{*} \\ & \mathrm{~L}^{*} \end{aligned}$ |
| $+10 \mathrm{~V}$ | $\begin{array}{llllll} \hline X & \uparrow & X & X & L & H \\ X & \uparrow & X & X & H & L \end{array}$ | L | $\begin{aligned} & \mathrm{H}^{* *} \\ & \mathrm{~L}^{* *} \end{aligned}$ |

## NOTES:

1. Positive Logic:

$$
J / K=T_{0}+T_{1}+T_{2} \ldots \ldots \ldots \ldots . . T_{31}
$$

$T_{n}=\bar{C} \cdot\left(I_{0} \cdot I_{1} \cdot I_{2} \ldots\right) \cdot\left(Q_{0} \cdot Q_{1} \ldots\right) \cdot\left(B_{0} \cdot B_{1} \bullet \ldots\right)$
2. §denotes transition from Low to High level.
3. $X=$ Don't Gare
4. * $=$ Forced at $F_{n}$ pin for loading $\mathrm{J} / \mathrm{K}$ flip-flop in $\mathrm{I} / \mathrm{O}$ mode. L must be enabled, and other active $\mathrm{T}_{\mathrm{n}}$ disabled via steering input(s) I, B, or Q.
5. At $P=R=H, Q=H$. The final state of $Q$ depends on which is released first.
6. * * = Forced at $F_{n}$ pin to load J/K flip-flop independent of program code (Diagnostic mode), Tri-state B outputs.

Field-Programmable Logic Sequencer ( $16 \times 45 \times 12$ )

## FPLS LOGIC DIAGRAM



## notes:

1. All OR gate inputs with a blown link float to logic " 0 "
2. All other gates and control inputs with a blown link float to logic " 1 ".
3. $\oplus$ denotes WIRE-OR.


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 20-pin Plastic DIP 300mil-wide | PLS159AN |
| 20-pin Plastic Leaded Chip Carrier | PLS159AA |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | + 7 | $V_{D C}$ |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{N}}$ | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{\text {3 }}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{1 H} \\ & V_{\mathrm{IL}} \\ & V_{\mathrm{IC}} \end{aligned}$ | High Low Clamp | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\operatorname{Min} \\ V_{C C}=\text { Min, }_{\text {IN }}=-12 m A \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| V OH <br> $V_{\mathrm{OL}}$ | High Low | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{gathered}$ | 2.4 | 0.35 | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{LL}} \\ & \hline \end{aligned}$ | High Low | $\begin{gathered} V_{C C}=M a x, V_{I N}=5.5 \mathrm{~V} \\ V_{I N}=0.45 \mathrm{~V} \end{gathered}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 40 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> los | Hi-Z state ${ }^{5,8}$ <br> Short circuit ${ }^{4,6}$ | $\begin{gathered} V_{\mathrm{CC}}=\text { Max, } V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 80 \\ -140 \\ -70 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{\text {CC }}$ supply current ${ }^{7}$ | $V_{C C}=$ Max |  | 150 | 190 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{iN}}$ Cout | Input Output | $\begin{gathered} V_{C C}=5.0 \mathrm{~V}, V_{I N}=2.0 \mathrm{~V} \\ V_{\text {OUT }}=2.0 \mathrm{~V} \end{gathered}$ |  | $\begin{gathered} 8 \\ 15 \\ \hline \end{gathered}$ |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only.

Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{\mid H}$ applied to $\overline{O E}$.
6. Duration of short circuit should not exceed 1 second.
7. I ICC is measured with the $\overline{O E}$ input grounded, all other inputs at 4.5 V , and the outputs open.
8. Leakage values are a combination of input and output leakage.

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega$, NPLS $179: 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min ${ }^{5}$ | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  |  |  |  |
| tekh <br> ${ }^{\text {tckL }}$ <br> tekp $^{\text {CR }}$ <br> tpR | Clock ${ }^{2}$ high <br> Clock low <br> Period <br> Preset/Reset pulse | $\begin{aligned} & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & (1, B)+ \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK - } \\ & \text { CK + } \\ & (\mathrm{i}, \mathrm{~B})- \end{aligned}$ |  | 20 20 55 35 | $\begin{aligned} & 15 \\ & 15 \\ & 45 \\ & 30 \\ & \hline \end{aligned}$ |  | ns |
| Setup time |  |  |  |  |  |  |  |  |
| $\begin{aligned} & t_{l S 1} \\ & t_{1 S 2} \\ & t_{1 S 3} \end{aligned}$ | Input <br> input (through $\mathrm{F}_{\mathrm{n}}$ ) <br> Input (through <br> Complement Array) ${ }^{4}$ | $\begin{aligned} & \text { CK + } \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \end{aligned}$ | $\begin{gathered} (\mathrm{I}, \mathrm{~B}) \pm \\ \mathrm{F} \pm \\ (\mathrm{I}, \mathrm{~B}) \pm \end{gathered}$ |  | $\begin{aligned} & 35 \\ & 15 \\ & \\ & 55 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & 45 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{t}_{\mathrm{H} 1} \\ & \mathrm{t}_{\mathrm{H} 2} \\ & \hline \end{aligned}$ | input <br> Input (through $\mathrm{F}_{\mathrm{n}}$ ) | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{CK}+ \end{aligned}$ | $\begin{gathered} (\mathrm{I}, \mathrm{~B}) \pm \\ \mathrm{F} \pm \end{gathered}$ |  | 0 15 | -5 10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |  |
| tско <br> toE1 | Clock Output enable | $\begin{aligned} & \mathrm{F} \pm \\ & \mathrm{F}- \end{aligned}$ | $\overline{C K} \pm$ |  |  | 15 20 | 20 30 | ns |
| todi | Output disable ${ }^{3}$ | F + | $\overline{O E}+$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 |  |
| $\begin{aligned} & \mathrm{t}_{\mathrm{PD}} \\ & \text { toE }_{2} \end{aligned}$ | Output Output enable | $\begin{aligned} & \mathrm{B} \pm \\ & \mathrm{B} \pm \end{aligned}$ | $\begin{aligned} & (1, B) \pm \\ & (1, B)+ \end{aligned}$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | $\begin{aligned} & 25 \\ & 20 \end{aligned}$ | 35 30 |  |
| tod2 | Output disable ${ }^{3}$ | B+ | $(1, B)-$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 |  |
| tpRo <br> tppR | Preset/Reset <br> Power-on preset | $\begin{aligned} & \mathrm{F} \pm \\ & \mathrm{F}- \end{aligned}$ | $\begin{aligned} & (1, B)+ \\ & \mathrm{V}_{\mathrm{CC}}+ \end{aligned}$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 0 | 45 10 |  |

NOTES:

1. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 10$ ns.
3. Measured at $\mathrm{V}_{\mathrm{T}}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
4. When using the Complement Array $\mathrm{T}_{\mathrm{CKP}}=75 \mathrm{~ns}$ (min).
5. Limits are guaranteed with 12 product terms maximum connected to each sum term line.

## TEST LOAD CIRCUIT

(

VOLTAGE WĀVEFORMi


## TIMING DIAGRAMS



## TIMING DEFINITIONS

## $t_{\text {CKH }}$

Nidth of input clock pulse.
tCKL Interval between clock pulses
tekp Clock period.
tpRH Width of preset input pulse.
$t_{\text {IS } 1} \quad$ Required delay between beginning of valid input and positive transition of clock.
$t_{1 S 2} \quad$ Required delay between beginning of valid input forced at flip-flop output pins, and positive transition of clock.
$\mathrm{t}_{\mathrm{IH} 1} \quad$ Required delay between positive transition of clock and end of valid input data.
$t_{1 \mathrm{H} 2} \quad$ Required delay between positive transition of clock and end of valid input data forced at flip-flop output pins.
$t_{\text {CKO }} \quad$ Delay between positive transition of clock and when Outputs become valid (with $\overline{O E}$ low).
toE1 Delay between beginning of Output Enable Low and when Outputs become valid.
toD1 Delay between beginning of Output Enable High and when Outputs are in the off state.
tPPR Delay between $V_{C C}$ (after poweron) and when flip-flop outputs become preset at " 1 " (internal $Q$ outputs at " 0 ').
tpD Propagation delay between combinational inputs and outputs.
Delay between predefined Output Enable High, and when combinational Outputs become valid.
Delay between predefined Output Enable Low and when combinational Outputs are in the off state. Delay between positive transition of predefined Preset/Reset input, and when flip-flop outputs become valid.

TIMING DIAGRAMS (Continued)

*Preset and Reset functions override Clock. However, F outputs may glitch with the first positive Clock Edge if $\mathrm{T}_{\text {IS }}$ cannot be guaranteed by the user.

Asynchronous Preset/Reset


The FPLS can be programmed by means of Logic Programming equipment.
With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these Tables, the logic state or action of all $\mathrm{I} / \mathrm{O}$, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:
"AND" ARRAY - (I), (B), (Qp)

|  |  |  |  |
| :---: | :---: | :---: | :---: |
| STATE ${ }^{\text {a }}$ ( CODE | STATE ${ }^{\text {S }}$ CODE | STATE ${ }^{\text {S }}$ CODE | STATE CODE |
| InACTIVE ${ }^{1,2}$ O | $1, B, Q$ $H$ | $\overline{\mathbf{l}, \overline{\mathrm{B}}, \overline{\mathrm{Q}}} \mathrm{L}$ | DON'T CARE |
| LSo2030s | 1502000s | sozosos | LS02050S |

'COMPLEMENT" ARRAY - (C)




| ACTION | CODE |
| :---: | :---: |
| INACTIVE |  |


| ACTION | CODE |
| :---: | :---: |
| GENERATE $^{5}$ | $\mathbf{A}$ |


"OR" ARRAY - (MODE)


| ACFHON | CODE |
| :---: | :---: |
| TRANSPARENT | - |



Notes on following page.
'OR" ARRAY - ( $\mathbf{Q}_{\mathrm{N}}=\mathrm{D}-$ Type $)$


CAUTION:
The PLS159A Programming Algorithm is different from the PLS159.
"AND" ARRAY - ( $\mathbf{Q}_{\mathrm{N}}=\mathrm{J}-\mathrm{K}$ Type)

"OR" ARRAY - (S or B),(P),(R)

'EX-OR' ARRAY - (B)

"OE " ARRAY - (E)


## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate ( $\left.T, F_{C}, L, P, R, D\right)_{n}$ will be unconditionally inhibited if both of the $1, B$, or $Q$ links are left intact.
3. To prevent oscillations, this state is not allowed for $C$ link, pairs coupled to active gates $T_{n}, F_{C}$.
4. $E_{n}=O$ and $E_{n}=*$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates (L, P, R, D) $)_{n}$ due to their lack of "OR" array links.

FPLS PROGRAM TABLE


## Signetics

## Application Specific Products <br> - Series 20

## DESCRIPTION

The PLHS18P8A is a two-level logic element consisting of 72 AND gates and 8 OR gates with fusible connections for programming $I / O$ polarity and direction.
All AND gates are linked to 10 inputs (I) and 8 bidirectional I/O lines (B). These yield variable I/O gate configurations via 8 direction control gates, ranging from 18 inputs to 8 outputs.

On-chip T/C buffers couple either True (I, B) or Complement $(\bar{I}, \bar{B})$ input polarities to all AND gates. The 72 AND gates are separated into 8 groups of 9 each. Each group of 9 is associated with one bidirectional pin. In each group, eight of the AND terms are ORed together, while the ninth is used to establish I/O direction. All outputs are individually programmable via an EX-OR gate to allow implementation of AND/OR or NAND/NOR logic functions.
In the virgin state, the AND array fuses are back-to-back CB-EB diode pairs which will act as open connections. Current is avalanched across individual diode pairs during fusing, which essentially short circuits the EB diode and provides the connection for the associated product term.

PLHS18P8A
Programmable AND Array Logic $(18 \times 72 \times 8)$

Signetics Programmable Logic Product Specification

The PLHS18P8A is field-programmable, allowing the user to quickly generate custom pattern using standard programming equipment.

Order codes are contained in the pages following.

## FEATURES

- 100\% functionally compatible with AmPAL18P8A
- Field-Programmable
- 10 inputs
- 8 bidirectional I/O lines
- 72 AND gates/product terms - configured into eight groups of nine
- Programmable output polarity (Tri-state output)
- 1/O propagation delay: 20ns (max.)
- Power dissipation: 750 mW (nominal)
- TTL compatible
- Verify Lock Fuse
- On-chip test features for extensive AC and DC parametric testing


## FUNCTIONAL DIAGRAM


*PAL is a registered trademark of Monolithic Memories, Inc.

PIN CONFIGURATIONS


## LOGIC FUNCTION

TYPICAL PRODUCT TERM: Pn=A•B•C •D•...
TYPICAL LOGIC FUNCTION: AT OUTPUT POLARITY = H $Z=P 0+P 1+P 2 \ldots$
AT OUTPUT POLARITY $=\mathrm{L}$ $Z=\overline{P_{0}+\mathbf{P 1 + P 2 +}}$. $\mathrm{Z}=\overline{\mathbf{P} 0} \cdot \overline{\mathbf{P}_{1}} \cdot \overline{\mathbf{P}_{2}} \cdot \ldots$

## NOTES:

1. For each of the 8 outputs, either function $Z$ (ActiveHigh) or $\bar{Z}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. Z, A, B, C, etc. are user defined connections to fixed inputs (I) and bidirectional pins (B).

## APPLICATIONS

- 100\% functional replacement for all 20-pin combinatorial PALs*
- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing


## Programmable AND Array Logic $(18 \times 72 \times 8)$

FPLA LOGIC DIAGRAM


NOTES:

1. All unprogrammed or virgin "AND" gate locations are pulled to logic "1"


ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 20-pin Plastic DIP 300mil-wide | PLHS18P8AN |
| 20-piri Plastic Leaded Chip Carrier | PLHS18P8AA |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## ABSOLUTE MAXIMUM RATINGS ${ }{ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage | -0.5 | + 7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage | -0.5 | +5.5 | $V_{D C}$ |
| Vout | Output voltage | -0.5 | $\mathrm{V}_{\text {CC }}$ Max | $\mathrm{V}_{\mathrm{DC}}$ |
| Voutpra | Output voitage (programming) |  | +21 | $V_{D C}$ |
| In | Input current | -30 | + 5 | mA |
| lout | Output current |  | + 100 | mA |
| loutprg | Output current (programming) |  | +170 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating temp Storage temp | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | $\begin{aligned} & { }^{\circ} \mathrm{C} \\ & { }^{\circ} \mathrm{C} \end{aligned}$ |

## Programmable AND Array Logic ( $18 \times 72 \times 8$ )

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{iL}} \\ & \mathrm{~V}_{\mathrm{iH}} \\ & \mathrm{~V}_{\mathrm{I}} \end{aligned}$ | Low <br> High Clamp | $\begin{gathered} V_{C C}=\text { Min } \\ V_{C C}=M a x \\ V_{C C}=\mathrm{Min}, \mathrm{I}_{\mathbb{N}}=-18 \mathrm{~mA} \end{gathered}$ | +2.0 | -0.9 | $\begin{aligned} & +0.8 \\ & -1.2 \end{aligned}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | Low High | $\begin{gathered} V_{C C}=\text { Min. } V_{I N}=V_{I H} \text { or } V_{I L} \\ I_{O L}=+24 \mathrm{~mA} \\ I_{O H}=-3.2 \end{gathered}$ | +2.4 | +3.5 | +0.50 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{I L} \\ & I_{H} \\ & i_{1} \end{aligned}$ | Low <br> High <br> High | $\begin{aligned} V_{C C} & =M a x \\ V_{I N} & =+0.40 \mathrm{~V} \\ V_{I N} & =+2.7 \mathrm{~V} \\ V_{I N} & =+5.5 \mathrm{~V} \end{aligned}$ |  | -20 | $\begin{aligned} & -100 \\ & +25 \\ & +1.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mathrm{~mA} \end{aligned}$ |
| Output current |  |  |  |  |  |  |
| $\begin{aligned} & \text { Iozh } \\ & \text { lozt } \\ & \text { Isc } \end{aligned}$ | Output leakage Output leakage Short circuit ${ }^{4}$ | $\begin{aligned} V_{\mathrm{CC}}=M a x, V_{\mathrm{IL}} & =0.8 \mathrm{~V}, V_{\text {IH }}=2.0 \mathrm{~V} \\ V_{\text {OUT }} & =+2.7 \mathrm{~V} \\ V_{\text {OUT }} & =+0.40 \mathrm{~V} \\ V_{\text {OUT }} & =+0.5 \mathrm{~V} \end{aligned}$ | -25 | -60 | $\begin{aligned} & +100 \\ & -250 \\ & -90 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA |
| ICC | $V_{\text {CC }}$ current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{All}$ inputs = GND |  | 100 | 155 | mA |
| Capacitance ${ }^{5}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input I/O | $\begin{gathered} V_{C C}=+5 \mathrm{~V} \\ V_{I N}=2.0 \mathrm{~V} @ f=1 \mathrm{MHz} \\ V_{\text {OUT }}=2.0 \mathrm{~V} @ f=1 \mathrm{MHz} \end{gathered}$ |  | 6 |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied. 2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=+25^{\circ} \mathrm{C}$.
2. These are absolute values with respect to device ground and all overshoots due to system or tester noise are included.
3. Not more than one output should be tested at a time. Duration of the short circuit should not be more than one second. Vout $=0.5 \mathrm{~V}$ has been chosen to avoid test problems caused by tester ground degradation.
4. These parameters are not $100 \%$ tested, but are periodically sampled.

AC ELECTRICAL CHARACTERISTICS $R_{1}=200 \Omega, R_{2}=390 \Omega, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Input $\pm$ | Output $\pm$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 14 | 20 | ns |
| tea | Output enable | Input $\pm$ | Output - | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 14 | 20 | ns |
| $t_{\text {ER }}$ | Output disable | Input $\pm$ | Output + | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 14 | 20 | ns |

## NOTES:

1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=+25^{\circ} \mathrm{C}$.
2. $T_{P D}$ is tested with switch $S_{1}$ closed and $C_{L}=50 \mathrm{pF}$.
3. For Tri-state output; output enable times are tested with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ to the 1.5 V level, and $\mathrm{S}_{1}$ is open for high-impedance to High tests and closed for high-impedance to Low tests. Output disable times are tested with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$. High-to-High impedance tests are made to an output voltage of $\mathrm{V}_{\mathrm{OH}}=-0.5 \mathrm{~V}$ with $\mathrm{S}_{1}$ open, and Low-to-High impedance tests are made to the $\mathrm{V}_{\mathrm{OL}}=+0.5 \mathrm{~V}$ level with $\mathrm{S}_{1}$ closed.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links open, such that:

1. All outputs are at ' $L$ "' polarity.
2. All outputs are enabled.
3. All p-terms are enabled.

## TIMING DEFINITIONS

$t_{\text {PD }}$
$t_{\text {ER }} \quad$ Input to output disable (Tri-state)
delay (Output Disable).
$t_{E A} \quad$ Input to Output Enable delay
(Output Enable).

## TIMING DIAGRAM <br> RAM



| WAVEFORM | INPUTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MUST BE <br> STEADY | WILL BE <br> STEADY | WAVEFORM | INPUTS |
| OUTPUTS |  |  |  |  |

## AC TEST LOAD CIRCUIT



## VOLTAGE WAVEFORM



## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/EX-OR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this Table the logic state of variables I, P, and $B$ associated with each Sum Term, $S$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

## OUTPUT POLARITY - (B)



## "AND" ARRAY - (I, B)



## NOTES:

1. This is the initial state of all link pairs.
2. All unused product terms must be programmed with all pairs of fuses in the INACTIVE state (all fuses on an unused p-term must be programmed).

PROGRAM TABLE


## Section 5 <br> PLD Data Sheets

Application Specific Products

## INDEX

Section 5-PLD Data Sheets

| Series 24 |  |  |
| :---: | :---: | :---: |
| PLS161 | Field-Programmable Logic Array ( $12 \times 48 \times 8$ ) | 5-3 |
| PLS162 | Field-Programmable Address Decoder (16 $\times 5$ ) ......... | 5-9 |
| PLS163 | Field-Programmable Address Decoder ( $12 \times 9$ ) | 5-15 |
| PLS167 | Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ ) | 5-21 |
| PLS167A | Field-Programmable Logic Sequencer; Enhanced Speed $(14 \times 48 \times 6)$ | 5-33 |
| PLS168 | Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ ) | 5-45 |
| PLS168A | Field-Programmable Logic Sequencer; Enhanced Speed $(12 \times 48 \times 8)$ | 5-57 |
| PLS173 | Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) ....... | 5-69 |
| PLS179 | Field-Programmabie Logic Sequencer ( $20 \times 45 \times 12$ )., | 5-75 |
| PLHS473 | Field-Programmable Logic Array ( $20 \times 24 \times 11$ ) | 5-85 |
| PLC473 | Erasable-Programmable Logic Array ( $20 \times 24 \times 11$ ) . | 5-91 |

## Signetics

## Application Specific Products

## - Series 24

## DESCRIPTION

The PLS161 is a bipolar, Field-Programmable Logic Array (FPLA). The device utilizes the standard AND/OR/Invert architecture to directly implement custom sum of product logic equations.
This device consists of 12 dedicated inputs and 8 dedicated outputs. Each output is capable of being actively controlled by any or all of the 48 product terms. The True, Complement, or Don't Care condition of each of the 12 inputs ANDed together comprise one P-term. All 48 P-terms are selectively ORed to each output. The user must then only select which P-terms will activate an output by disconnecting terms which do not affect the output. In addition each output can be fused as Active-High (H) or Active-Low (L).
The PLSio $\hat{1}$ is fuily TTL compatible, and includes a chip enable input for output inhibit control and expansion of input variables.
Order codes are contained on the pages following.

## PLS161

## Field-Programmable Logic Array ( $12 \times 48 \times 8$ )

Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr Link)
- Input variables: 12
- Output functions: 8
- Product terms: 48
- I/O propagation delay: 50ns (max.)
- Power dissipation: 600mW (typ.)
- Input loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Chip Enable input
- Output disable function
- Separate I/O architecture
- Tri-state outputs


## APPLICATIONS

- CRT display systems
- Random logic
- Code conversion
- Peripheral controllers
- Function generators
- Look-up and decision tables
- Microprogramming
- Address mapping
- Character generators
- Sequential controllers
- Data security encoders
- Fault detectors
- Frequency synthesizers


## FUNCTIONAL DIAGRAM



Field-Programmable Logic Array ( $12 \times 48 \times 8$ )

## FPLA LOGIC DIAGRAM



ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 24-pin Plastic DIP 300mil-wide | PLS161N |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \\ \hline \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | High Low Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=M a x \\ V_{C C}=M \operatorname{Min} \\ V_{C C}=M \operatorname{Min}, \operatorname{IIN}_{N}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOH}_{\mathrm{OH}}=-2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{C C}=M \mathrm{Max} \\ & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 40 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| logofa <br> los | Hi-Z state <br> Short circuit ${ }^{4,7}$ | $\begin{gathered} \overline{\mathrm{CE}}=\text { High, } V_{\mathrm{CC}}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ \overline{\mathrm{CE}}=\text { LOW, }, V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{8}$ | $\mathrm{V}_{\text {CC }}=$ Max |  | 120 | 170 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{gathered} \overline{\mathrm{CE}}=\text { High, } \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ \mathrm{~V}_{\text {IN }}=2 \mathrm{~V} \\ V_{\text {OUT }}=2 \mathrm{~V} \end{gathered}$ |  | $\begin{gathered} 8 \\ 17 \end{gathered}$ |  | pF |

[^10]AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Propagation delay |  |  |  |  |  |  |  |
| $t_{\text {PD }}$ | Input | Output | Input |  | 35 | 50 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | Chip enable | Output | Chip enable |  | 15 | 30 | ns |
| Disable time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CD}}$ | Chip disable | Output | Chip enable |  | 15 | 30 | ns |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings' may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one pin at a time.
5. Measured with $V_{1 L}$ applied to $\overline{C E}$ and a logic high stored.
6. Measured with a programmed logic condition for which the output test is at a low logic level. Output sink current is applied through a resistor to $V_{C C}$.
7. Duration of short circuit should not exceed 1 second.
8. $\mathrm{I}_{\mathrm{CC}}$ is measured with the chip enable input grounded, all other inputs at 4.5 V and the outputs open.

## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this Table the logic state or action of variables $I, P$, and $F$, associated with each Sum Term $S_{n}$, is assigned a symbol which resuits in the proper fusing pattern of corresponding link pairs, defined as follows:

EX-OR ARRAY - (F)

'AND' ARRAY - (I)

"OR" ARRAY - (F)

|  |  |
| :---: | :---: | :---: | :---: | :---: |
| $P_{n}$ STATUS | CODE |
| ACTIVE | $A$ |

## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $P_{n}$.
2. Any gate $P_{n}$ will be unconditionally inhibited if any one of its (I) link pairs is left intact.

## Signetics

## Application Specific Products - Series 24

## DESCRIPTION

The PLS161 is a bipolar, Field-Programmable Logic Array (FPLA). The device utilizes the standard AND/OR/Invert architecture to directly implement custom sum of product logic equations.

This device consists of 12 dedicated inputs and 8 dedicated outputs. Each output is capable of being actively controlled by any or all of the 48 product terms. The True, Complement, or Don't Care condition of each of the 12 inputs ANDed together comprise one P-term. All 48 P-terms are selectively ORed to each output. The user must then only select which P-terms will activate an output by disconnecting terms which do not affect the output. In addition each output can be fused as Active-High (H) or Active-Low (L).
The PLSte1 is fully TTL compatible, and includes a chip enable input for output inhibit control and expansion of input variables.

Order codes are contained on the pages following.

PLS161

# Field-Programmable Logic Array ( $12 \times 48 \times 8$ ) 

Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr Link)
- Input variables: 12
- Output functions: 8
- Product terms: 48
- I/O propagation delay: 50ns (max.)
- Power dissipation: 600 mW (typ.)
- Input loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Chip Enable input
- Output disable function
- Separate I/O architecture
- Tri-state outputs


## APPLICATIONS

- CRT display systems
- Random logic
- Code conversion
- Peripheral controllers
- Function generators
- Look-up and decision tables
- Microprogramming
- Address mapping
- Character generators
- Sequential controllers
- Data security encoders
- Fault detectors
- Frequency synthesizers


## FUNCTIONAL DIAGRAM



## Field-Programmable Logic Array ( $12 \times 48 \times 8$ )

FPLA LOGIC DIAGRAM


TEST LOAD CIRCUIT


TIMING DIAGRAMS


## VOLTAGE WAVEFORM



## TIMING DEFINITIONS

tce Delay between beginning of Chip Enable Low (with Input valid) and when Data Output becomes valid. Delay between when Chip Enable becomes High and Data Output is in off state (Hi-Z or High).
tpD Delay between beginning of valid Input (with Cinip Enabie Low) and when Data Output becomes valid.

## VIRGIN STATE

The PLS161 virgin device is factory shipped in an unprogrammed state, with all fuses intact, such that:

1. All $P_{\mathrm{n}}$ terms are disabled. (Inactive).
2. All $P_{n}$ terms are active on all outputs.
3. All outputs are Active-High.

FPLA PROGRAM TABLE



## Signetics

## Application Specific Products

## - Series 24

## DESCRIPTION

The PLS162 is a bipolar, Field-Programmable Address Decoder. The device consists of five AND/NAND gates which share 16 common inputs. The type of gate is selected by programming the output as Active-High ( H ) or Active-Low (L). Each of the 16 inputs $I_{0}-I_{15}$ can be programmed to provide the True (H), Complement (L), or Don't Care (一) state to each of the five AND/NAND gates. OR/NOR logic functions can also be implemented by complementing the inputs and outputs via on-chip inverting buffers.
The device is field programmable, which means that custom patterns are immediately available.
The PLS162 includes chip-enable control for output strobing and inhibit. It features Tri-state outputs for ease of expansion of input variables and application in bus-organized systems.
Order codes are contained on the following pages.

## FUNCTIONAL DIAGRAM



PIN CONFIGURATION


## LOGIC FUNCTION

```
TYPICAL OUTPUT FUNCTIONS:
    ACTIVE-HIGH
        X=A
    ACTIVE-LOW
        X=}\overline{A\cdot\overline{B}\cdotC\cdot}
        X}=\overline{A}+B+\overline{C}+
```


## NOTES:

1. For each of the 5 outputs, either function $X$ (ActiveHigh) or $\bar{X}$ (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $X, A, B, C$, etc. are user defined connections to fixed inputs (i) and output pins (F).

FPAD LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS162N |

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Supply voltage | +7 | $V_{D C}$ |
| $V_{I N}$ | Input voltage | +5.5 | $V_{D C}$ |
| $V_{\mathrm{O}}$ | Output voltage <br> Off-state | +5.5 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{I}_{\mathrm{N}}$ | Input current | $\pm 30$ | mA |
| IOUT | Output current | +100 | mA |
| $T_{\mathrm{A}}$ | Temperature range <br> Operating <br> Storage | 0 to +75 <br> $T_{\text {STG }}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{1}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ <br> $V_{\text {IL }}$ <br> $V_{\text {IC }}$ | High <br> Low <br> Clamp ${ }^{3}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=\text { Min, } I_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{1}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{4} \end{aligned}$ | $\begin{aligned} V_{C C} & =\mathrm{Min} \\ \mathrm{I}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =15 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{LL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{C C}=\text { inax } \\ & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 40 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo (OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{6}$ <br> Short circuit ${ }^{3,7}$ | $\begin{aligned} V_{\text {CC }} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{\text {CC }}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 100 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output ${ }^{6}$ | $\begin{aligned} V_{C C} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output | Input | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| $t_{\text {ce }}$ | Chip enable | Output | Chip enable | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| $t_{\text {c }}$ | Chip disable | Output | Chip enable | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 | ns |

## NOTES:

1. All voltage values are with respect to network ground terminal.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. Test each pin one at a time.
4. Measure with a programmed logic condition for which the output under test is at low logic level. Output sink current is supplied through a resistor to $V_{C C}$.
5. Measured with $V_{\mathrm{IL}}$ applied to $\overline{\mathrm{CE}}$ and logic high at the output.
6. Measured with $V_{I H}$ applied to $\overline{C E}$.
7. Duration of short circuit should not exceed 1 second
8. $\mathrm{I}_{\mathrm{CC}}$ is measured with the outputs open.

## TEST LOAD CIRCUIT



VOLTAGE WAVEFORM


## LOGIC PROGRAMMING

In a virgin device al! Ni-Cr links are intact. The FPAD can be programmed by means of Logic Programming equipment.

With Logic programming, the AND/EX-OR gate input connections necessary to implement the desired logic function are coded directly from the logic equations using the Program Table on the following page.

In this table, the logic state of variables I and $F$ associated with each gate $G_{n}$ is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

## OUTPUT POLARITY - (F)


"AND" ARRAY - (I)


NOTES:
i. This is the initial unprogrammed state of all links.
2. Any gate $\mathrm{G}_{\mathrm{n}}$ will be unconditionally inhibited if both the true and complement of any input (either I or B ) are left intact.

## VIRGIN DEVICE

The PLS162 is shipped in an unprogrammed state, characterized by:

1. All $P_{n}$ terms are disabled. (Inactive).
2. All $P_{n}$ terms are active on all outputs.
3. All outputs are Active-Low.

Field-Programmable Address Decoder ( $16 \times 5$ )

FPAD PROGRAM TABLE



7801281s

## PLS163

# Field-Programmable Address Decoder ( $12 \times 9$ ) 

## Signetics Programmable Logic

Product Specification

## Signetics

## Application Specific Products

## - Series 24

## DESCRIPTION

The PLS163 is a bipolar, Field-Programmable Address Decoder. The device consists of nine AND/NAND gates which share 12 common inputs. The type of gate is selected by programming the output as Active-High (H) or ActiveLow (L). Each of the 12 inputs $l_{0}-I_{11}$ can be programmed to provide the True $(\mathrm{H})$, Complement (L), or Don't Care ( - ) state to each of the nine AND/NAND gates. OR/NOR logic functions can aiso be implemented by complementing the inputs and outputs via on-chip inverting buffers.

The device is field programmable, which means that custom patterns are immediately available.
The PLS163 includes chip-enable control for output strobing and inhibit. It features Tri-state outputs for ease of expansion of input variables and application in bus-organized systems.

Order codes are contained on the following pages.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 12 input variables
- 9 output functions
- Chip Enable input
- I/O propagation delay: 30ns (max.)
- Power dissipation: 600mW (typ.)
- Input ioading: $\mathbf{- 1 0 0 \mu A}$ (max.)
- Tri-state outputs
- Output disable function: $\mathrm{Hi}-\mathrm{Z}$
- Fully TTL compatible


## APPLICATIONS

- Random logic
- Address decoders
- Code detectors
- Peripheral selectors
- Fault monitors
- Machine state decoders


## FUNCTIONAL DIAGRAM



Fusible $\mathrm{Ni}-\mathrm{Cr}$ links are initially intact at all array cross-points.

PIN CONFIGURATION


## LOGIC FUNCTION

```
TYPICAL OUTPUT FUNCTIONS:
    ACTIVE-HIGH
        X=A
    ACTIVE-LOW
        X=A\cdot\overline{B}\cdotC
        X=
```

    NOTES:
    1. For each of the 9 outputs, either function \(X\) (Active-
        High) or \(\bar{X}\) (Active-Low) is available, but not both.
        The desired output polarity is programmed via the
        Ex-OR gates.
    2. \(X, A, B, C\), etc. are user defined connections to
    fixed inputs (I) and output pins (F).
    
## Field-Programmable Address Decoder ( $12 \times 9$ )

FPAD LOGIC DIAGRAM
(

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS163N |

## absolute maximum ratings

| SYMBOL | PARAMETER | RATING | UNIT |
| :--- | :--- | :---: | :---: |
| $V_{C C}$ | Supply voltage | +7 | $V_{D C}$ |
| $\mathrm{~V}_{\mathbb{I}}$ | Input voltage | +5.5 | $\mathrm{~V}_{D C}$ |
| $\mathrm{~V}_{\mathrm{O}}$ | Output voltage <br> Off-state | +5.5 | $\mathrm{~V}_{\mathrm{DC}}$ |
| $\mathrm{I}_{\mathrm{I}}$ | Input current | $\pm 30$ | mA |
| $\mathrm{I}_{\text {OUT }}$ | Output current | +100 | mA |
| $\mathrm{~T}_{\text {A }}$ | Temperature range <br> Operating <br> Storage | 0 to +75 |  |
| $\mathrm{~T}_{\text {STG }}$ | ${ }^{\circ} \mathrm{C}$ |  |  |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| input volitage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | High ${ }^{1}$ <br> Low ${ }^{1}$ <br> Clamp ${ }^{1,3}$ | $\begin{gathered} V_{\mathrm{CC}}=\text { Max } \\ V_{\mathrm{CC}}=\operatorname{Min} \\ V_{\mathrm{CC}}=\text { Min, } \mathrm{I}_{\mathrm{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{1,5} \\ & \text { Low }^{1,4} \end{aligned}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =15 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{H}} \\ & \mathrm{I}_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} V_{C C} & =M a x \\ V_{I N} & =5.5 \mathrm{~V} \\ V_{I N} & =0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 40 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo (OfF) los | Hi-Z state ${ }^{6}$ Short circuit ${ }^{3,7}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| lcc | $\mathrm{V}_{\mathrm{CC}}$ supply current ${ }^{8}$ | $\mathrm{V}_{C C}=\mathrm{Max}$ |  | 120 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output ${ }^{6}$ | $\begin{aligned} & V_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\text {OUT }}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | то | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| tPD | Propagation delay | Output | Input | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| $\mathrm{t}_{\text {CE }}$ | Chip enable | Output | Chip enable | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| $\mathrm{t}_{\mathrm{CD}}$ | Chip disable | Output | Chip enable | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 | ns |

## NOTES:

1. All voltage values are with respect to network ground terminal.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. Test each pin one at a time.
4. Measure with a programmed logic condition for which the output under test is at low logic level. Output sink current is supplied through a resistor to VCc.
5. Measured with $V_{\text {IL }}$ applied to $\overline{C E}$ and logic high at the output.
6. Measured with $V_{\mathbb{H}}$ applied to $\overline{C E}$.
7. Duration of short circuit should not exceed 1 second.
8. Icc is measured with the outputs open.

## TEST LOAD CIRCUIT



VOLTAGE WAVEFORM


## LOGIC PROGRAMMING

In a virgin device al! Nif-Cr links are intact. The FPAD can be programmed by means of Logic Programming equipment.

With Logic programming, the AND/EX-OR gate input connections necessary to implement the desired logic function are coded directly from the logic equations using the Program Table on the following page.

In this table, the logic state of variables I and $F$ associated with each gate $G_{n}$ is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:
"AND' ARRAY - (I)


NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $G_{n}$ will be unconditionally inhibited if both the true and complement fuses of any input (I) are left intact.

## VIRGIN DEVICE <br> VIRGIN DEVICE

The PLS163 is shipped in an unprogrammed state, characterized by:

1. All $P_{n}$ terms are disabled. (Inactive).
2. All $P_{n}$ terms are active on all outputs.
3. All outputs are Active-Low.

OUTPUT POLARITY - (F)


## FPAD PROGRAM TABLE

| CUSTOMER NAME | THIS PORTION TO BE COMPLETED BY SIGNETICS |
| :---: | :---: |
| PURCHASE ORDER \# | $C F(X X X X)$ |
| SIGNETICS DEVICE \# | CUSTOMER SYMBOLIZED PART\# |
| TOTAL NUMBER OF PARTS ___ | DATE RECEIVED |
| PROGRAM TABLE \# | COMMENTS |


| $F_{0}(16)$ |  |
| ---: | :--- |
| $F_{1}(15)$ |  |
| $F_{2}(14)$ |  |
| $F_{3}(13)$ |  |
| $F_{4}(11)$ |  |
| $F_{5}(10)$ |  |
|  | $=$ |
| $F_{6}(9)$ |  |
| $F_{7}(8)$ |  |
| $F_{8}(7)$ |  |
|  | $=$ |
|  | $=$ |
|  | $=$ |


| GATE | INPUT |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| POLARITY | $\mathrm{I}_{11}$ | 150 | 19 | $\mathrm{I}_{8}$ | $\mathrm{I}_{7}$ | 16 | 15 | 14 | $1_{3}$ | $\mathrm{I}_{2}$ | , | 10 |
| $F_{0}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $F_{1}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{2}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{3}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{4}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{5}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{6}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{7}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathrm{F}_{8}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \text { PN } \\ & \text { NO. } \end{aligned}$ | 18 | 19 | 20 | 21 | 22 | 23 | 1 | 2 | 3 | 4 | 5 | 6 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |

## notes

1. The FPAD is shipped with ail finks inlact Thus a background of entries corresponding to states of virgin links exists in the table. shown BLANK for clarity
2. Unused I bits are normally programmed Donil Care (-)
3. Unused Gates can be lett blank.

PROGRAM TABLE ENTRIES


## Signetics

## Application Specific Products

 - Series 24
## DESCRIPTION

The PLS167 is a bipolar, programmable state machine of the Mealy type. The Field Programmable Logic Sequencer (FPLS) contains logic AND-OR gate arrays with user programmable connections which control the inputs of on-chip State and Output Registers. These consist respectively of $8 Q_{p}$, and $4 Q_{f}$ edgetriggered, clocked $S / R$ flip-flops, with an asynchronous preset option.

All flip-flops are unconditionally preset to " 1 " during power turn-on.
The AND Array combines 14 external inputs, $\mathrm{I}_{0-13}$, with 8 internal inputs, $\mathrm{P}_{0-7}$, fed back from the State Register to form up to 48 transition terms (AND terms). In addition, $P_{0}$ and $P_{1}$ of the internal State Register are brought off-chip to allow extending the Output Register to 6 bits, if so desired.

All transition terms can include True, False, or Don't Care states of the controlling variables, and are merged in the OR Array to issue next-state and nextoutput commands to their respective registers on the Low-to-High transition of the Clock pulse.
Both True and Complement transition terms can be generated by optional use of the internal variable ( $C$ ) from the Complement Array. Also, if desired, the Preset input can be converted to Output-

PLS167
Field-Programmable Logic
Sequencer $(14 \times 48 \times 6)$
Signetics Programmable Logic
Product Specification

Enable function, as an additional user programmable option.
Order codes are contained on the pages following.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 14 True/Complement buffered inputs
- 48 programmable AND gates
- 25 programmable OR gates
- 8-bit State Register
- 2-bit shared State/Output Register
- 4-bit Output Register
- Transition Complement Array
- Programmable Asynchronous Preset/Output Enable
- Positive edge-triggered clock
- Power-on preset to iogic " 1 " of all registers
- Automatic logic "HOLD" state via S/R flip-flops
- On-chip Test Array
- $f_{\text {MAX: }} 13.9 \mathrm{MHz}$
- Power: 600mW (typ.)
- TTL compatible
- Tri-state outputs
- Single +5 V supply
- 300mil-wide 24-pin DIP


## FUNCTIONAL DIAGRAM



## PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-7 \\ 17-23 \end{gathered}$ | $l_{1-13}$ | Logic Inputs: The 13 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 8 | 10 | Logic/Diagnostic Input: A 14th external logic input to the AND array, as above, when exercised with standard TTL levels. When $I_{0}$ is held at +10 V , device outputs $\mathrm{F}_{0-3}$ and $\mathrm{P}_{0-1}$ reflect the contents of State Register bits $\mathrm{P}_{2-7}$ (see Diagnostic Output Mode diagram). The contents of flip-flops $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ remain unaltered. | Active-High/Low |
| $\begin{gathered} 9-11 \\ 13 \end{gathered}$ | $\mathrm{F}_{0-3}$ | Logic/Diagnostic Outputs: Four device outputs which normally reflect the contents of Output Register bits $Q_{0-3}$, when enabled. When $I_{0}$ is held at $+10 \mathrm{~V}, \mathrm{~F}_{0-3}=\left(P_{2-5}\right)$. | Active-High |
| 14-15 | $\mathrm{P}_{0-1}$ | Logic/Diagnostic Outputs: Two register bits with shared function as least significant State Register bits, or most significant Output Register bits. When $I_{0}$ is held at +10 V , $\mathrm{P}_{0-1}=\left(\mathrm{P}_{6-7}\right)$. | Active-High |
| 16 | PR/ $\overline{O E}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an asynchronous preset to logic " 1 " of all State and Output Register bits. Preset overrides Clock, and when held High, clocking is inhibited and $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ are High. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes Low. <br> - Output Enable: Provides an Output Enable function to all output buffers. | Active-High (H) Active-Low (L) |

## LOGIC FUNCTION



## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. PR/ $\overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0).
3. All $\mathrm{S} / \mathrm{R}$ flip-flop inputs are disabled (0).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program. This is accomplished automatically by any Signetics qualified programming equipment.

## TRUTH TABLE 1, 2, 3, 4, 5, 6

| Vcc | OPTION |  | 10 | CK | S | R | $Q_{\text {P/F }}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | $\overline{\mathrm{OE}}$ |  |  |  |  |  |  |
|  | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \\ \mathrm{~L} \end{gathered}$ |  | $\begin{gathered} +10 \mathrm{~V} \\ \mathrm{X} \end{gathered}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & \hline \end{aligned}$ | $x$ <br> $\times$ <br> $\times$ <br> $\times$ | $\begin{aligned} & \hline x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & H \\ & Q_{n} \\ & Q_{n} \end{aligned}$ | $\begin{gathered} H \\ \left(Q_{P}\right)_{n} \\ \left(Q_{F}\right)_{n} \end{gathered}$ |
| +5V |  | $\begin{aligned} & H \\ & L \\ & L \end{aligned}$ | $+10 \mathrm{~V}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & Q_{n} \\ & Q_{n} \\ & Q_{n} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Hi}-\mathrm{Z} \\ & \left(\mathrm{Q}_{\mathrm{P}}\right)_{n} \\ & \left(\mathrm{Q}_{\mathrm{F}}\right)_{\mathrm{n}} \end{aligned}$ |
|  |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ | $\uparrow$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} Q_{n} \\ L \\ H \\ \text { IND. } \end{gathered}$ | $\begin{gathered} \left(Q_{F}\right)_{n} \\ L \\ H \\ \text { IND. } \end{gathered}$ |
| $\uparrow$ | X | X | X | X | X | X | H |  |

NOTES:

1. Positive Logic:

$$
\begin{aligned}
& S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47} \\
& T_{n}=C\left(T_{0} T_{1} I_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{7}\right)
\end{aligned}
$$

2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user programmable option.
3. $\uparrow$ denotes transition from Low to High level.
4. $R=S=$ High is an illegal input condition.
5. $*=H / L /+10 \mathrm{~V}$
6. $\mathrm{X}=$ Don't Care $(\leqslant 5.5 \mathrm{~V})$

$$
\text { Field-Programmable Logic Sequencer }(14 \times 48 \times 6)
$$

## FPLS LOGIC DIAGRAM



## NOTES:

[^11]ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300 mil-wide | PLS167N |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS167A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| 1 N | Input currents | -30 | + 30 | mA |
| lout | Output currents |  | $+100$ | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \\ \hline \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$


## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, T_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $\mathrm{V}_{\mathrm{IL}}$ applied to $\overline{\mathrm{OE}}$ and a logic high stored, or with $\mathrm{V}_{\mathrm{IH}}$ applied to PR.
6. Mieasured with a programmed logic condition for which the output is at a low logic lovel, and $V_{i L}$ applied to PR/DE Output sink current is supplied through a resistor to $V_{C C}$.
7. Measured with $\mathrm{V}_{\mathrm{IH}}$ applied to $\mathrm{PR} / \overline{\mathrm{OE}}$.
8. Duration of short circuit should not exceed 1 second.

9 . ICC is measured with the PR/ $\overline{O E}$ input grounded, all other inputs at 4.5 V and the outputs open.

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{PF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width ${ }^{3}$ |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CKH}}$ <br> $t_{\text {CKL }}$ <br> $\mathrm{t}_{\mathrm{CKP} 1} \mathrm{~B}$ <br> $\mathrm{t}_{\mathrm{CKP2}} \mathrm{~B}$ <br> $t_{\text {tph }}$ | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | CK - <br> CK + <br> CK + <br> CK + <br> PR- | $\begin{aligned} & \text { CK + } \\ & \text { CK }- \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{gathered} 25 \\ 25 \\ 80 \\ 120 \\ 25 \end{gathered}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 60 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{IS} 1} \mathrm{~A}$ <br> $t_{1 S 1} B$ <br> $\mathrm{t}_{\mathrm{IS} 1} \mathrm{C}$ <br> ${ }^{\mathrm{I}_{152}} \mathrm{~A}$ <br> ${ }_{4}{ }_{152} B$ <br> ${ }_{\mathrm{t}_{152} \mathrm{C}}$ <br> tvs <br> tprs | Input <br> Input <br> Input <br> Input (through Complement Array) <br> Input (through Complement Array) <br> Input (through Complement Array) <br> Power-on preset <br> Preset | CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK - <br> CK- | Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input <br> Input <br> $V_{C C}+$ <br> PR - | $\begin{gathered} 60 \\ 50 \\ 42 \\ 90 \\ 80 \\ 72 \\ 0 \\ 0 \end{gathered}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{H}}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tcko <br> toe <br> too <br> $t_{P R}$ <br> tPPR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output - <br> Output + <br> Output + <br> Output + | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{OE}- \\ & \mathrm{OE}+ \\ & \mathrm{PR}+ \\ & \mathrm{V}_{\mathrm{CC}}+ \end{aligned}$ |  | $\begin{gathered} 15 \\ 20 \\ 20 \\ 18 \\ 0 \end{gathered}$ | $\begin{aligned} & 30 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \end{aligned}$ | ns |
| Frequency of operation ${ }^{3}$ |  |  |  |  |  |  |  |
| $f_{\text {MAXC }}$ <br> $f_{\text {MAX }} C$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} 13.9 \\ 9.8 \end{gathered}$ | MHz |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time ( $10 \%-90 \%$ ) $\leqslant 30 \mathrm{~ns}$.
3. See "Speed vs. OR Loading" diagrams.

## TIMING DIAGRAMS



Power-On Preset

## TIMING DEFINITIONS

$t_{\text {CKH }}$ Width of input clock pulse.
$t_{\text {CKL }}$. Interval between clock pulses.
$t_{\text {tKF1 }}$ Clock period - when not using Complement array.
$\mathrm{t}_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of clock.
$\mathrm{t}_{\mathrm{CKP2}}$ Clock period - when using complement array.
$\mathrm{t}_{\text {I }} 2 \quad$ Required delay between beginning of valid input and positive transition of clock, when using optional Complement Array (two passes necessary through the AND array).
tvs Required delay between $\mathrm{V}_{\mathrm{CC}}$ (after power-on) and negative transition of clock preceding first reliable clock pulse.
Required delay between negative transition of asynchronous Preset and negative transition of clock preceding first reliable clock pulse.
$\mathrm{t}_{\mathrm{IH}} \quad$ Required delay between positive transition of clock and end of valid input data.
$t_{\text {CKO }} \quad$ Delay between positive transition of clock and when Outputs become valid (with $P R / \overline{O E}$ low).
toE Delay between beginning of Output Enable Low and when Outputs become valid.
toD Delay between beginning of Output Enable High and when Outputs are in the off state.
tsRE Delay between input $I_{0}$ transition to Diagnostic mode and when the Outputs reflect the contents of the State Register.
tsRD Deiay beiween inputio itransition to Logic mode and when the Outputs reflect the contents of the Output Register.
tPR Delay between positive transition of Preset and when Outputs become valid at " 1 ".
Delay between VCC (after poweron) and when Outputs become preset at " 1 ".
tpri Width of preset input pulse.
$f_{\text {MAX }}$ Maximum clock frequency.

TIMING DIAGRAMS (Continued)


## TEST LOAD CIRCUIT

(

## VOLTAGE WAVEFORM



## SPEED VS. "OR" LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:
$\left(1 / f_{\text {MAX }}\right)=t_{C Y}=t_{I S}+t_{C K O}$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $t_{\mathrm{IS}}$, due to capacitive loading. The effect of this loading can be seen in Figure 1, showing the variation of $\mathrm{t}_{\mathrm{IS} 1}$ with the number of terms connected per OR.
The AC electrical characteristics contain three limits for the parameters $\mathrm{t}_{\mathrm{IS} 1}$ and $\mathrm{t}_{\mathrm{IS} 2}$. The first, $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~A}}$ is guaranteed for a device with 48 terms connected to any OR line. $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~B}}$ is guaranteed for a device with 32 terms connected to any OR line. And $\mathrm{t}_{\mathrm{IS} 1 \mathrm{C}}$ is guaranteed for a device with 24 terms connected to any OR line.


The Three other entries in the $A C$ table, $t_{I S 2}$ $A, B$, and $C$ are corresponding 48,32 , and 24 term limits when using the on-chip Complement Array.

The worst case $t_{I S}$ for a given application can be determined by identifying the $O R$ line with the maximum number of $T_{n}$ connections. This can be done by referring to
the interconnect pattern in the FPLS logic diagram, typically illustrated in Figure 2, or by counting the maximum number of "بי" or "L" entries in one of the columns of the device Program Table.

This number plotted on the curve in Figure 1 will yield the worst case $t_{\mid S}$ and, by implication, the maximum clocking frequency for reliable operation.

Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.

In this table, the logic state or action of control variables $\mathrm{C}, \mathrm{I}, \mathrm{P}, \mathrm{N}$, and F , associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding links, defined as follows:

PRESET/OE OPTION - (P/E)


PROGRAMMING:
The PLS167 has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High (H). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs ( H ) as the present state.
"AND" ARRAY - (I), (P)

"OR' ARRAY - (N), (F)

'COMPLEMENT' ARRAY - (C)


| ACTION | CODE |
| :---: | :---: |
| TRANSPARENT | - |

## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $T_{n}$ will be unconditionally inhibited if both the true and complement of any input ( $I, P$ ) are left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

## Field-Programmable Logic Sequencer $(14 \times 48 \times 6) \quad$ PLS167

FPLS PROGRAM TABLE


## NOTES:

1. The FPLS is shipped with all links initially intact. Thus, a background of " 0 " for all Terms, and an "H" for the P/E option, exits in the table, shown BLANK instead for clarity.
2. Unused $C_{n}$, $l_{m,}$ and $P_{s}$ bits are normally programmed Don't Care $(-)$.
3. Unused Transition Terms can be left for future code modification or programmed as ( - ) for maximum speed.
4. Letters in variable fields are used as identifiers by logic type programmers.

## TEST ARRAY

The FPLS may be subjected to AC and DC
parametric tests prior to programming via an on-chip test array.
The array consists of test transition terms 48 and 49, factory programmed as shown below.
Testing is accomplished by clocking the FPLS and applying the proper input sequence to $l_{0-13}$ as shown in the test circuit timing diagram.



TC01592S
FPLS Under Test


| OPTION (P/E) |  |  |  |  |  |  |  |  |  |  | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| On |  |  |  |  |  |  |  |  |  |  |  |
| NEXT STATE (Ns) |  |  |  |  |  |  |  | OUTPUT (Fr) |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |
| 1 | 1 | L | L | L | L | 1 | $L$ | L | L | L | L |
| H | H | H | H | H | H | H | H | H | H | H | H |

Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.


## Signetics

## Application Specific Products

## - Series 24

## DESCRIPTION

The PLS167A is a bipolar, programmable state machine of the Mealy type.The Field-Programmable Logic Sequencer (FPLS) contains logic AND-OR gate arrays with user programmable connections which control the inputs of on-chip State and Output Registers. These consist respectively of $8 Q_{p}$, and $4 Q_{f}$ edgetriggered, clocked S/R flip-flops, with an Asynchronous Preset Option.

All flip-flops are unconditionally preset to " 1 " during power turn-on.

The AND array combines 14 external inputs, $\mathrm{I}_{0-13}$, with 8 internal inputs, $\mathrm{P}_{0-7}$, fed back from the State Register to form up to 48 transition terms (AND terms). In addition, $\mathrm{P}_{0}$ and $\mathrm{P}_{1}$ of the internal State Register are brought off-chip to allow extending the Output Register to 6 bits, if so desired.
All transition terms can include True, False, or Don't Care states of the controlling variables, and are merged in the OR array to issue next-state and nextoutput commands to their respective registers on the Low-to-High transition of the Clock puise.
Both True and Complement transition terms can be generated by optional use of the internal variable (C) from the Complement Array. Also, if desired, the Preset input can be converted to output-

## PLS167A <br> Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ )

Signetics Programmable Logic<br>Product Specification

enable function, as an additional user programmable option.

Order codes are contained on the pages following.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 14 True/Complement buffered inputs
- 48 programmable AND gates
- 25 programmable OR gates
- 8-bit State Register
- 2-bit shared State/Output Register
- 4-bit Output Register
- Transition Complement Array
- Programmable Asynchronous Preset/Output Enable
- Positive edge-triggered clock
- Power-on preset to logic "1" of all registers
- Automatic logic "HOLD" state via S/R flip-flops
- On-chip Test Array
- $\mathrm{f}_{\text {MAX }} \mathbf{2 0 M H z}$
- Power: 600mW (typ.)
- TTL compatible
- Tri-state outputs
- Single +5V supply
- 300mil-wide 24-pin DIP


## FUNCTIONAL DIAGRAM



## PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A low-to-high transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-7 \\ 17-23 \end{gathered}$ | $1_{1-13}$ | Logic Inputs: The 13 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 8 | 10 | Logic/Diagnostic Input: A 14th external logic input to the AND array, as above, when exercised with standard $T L$ levels. When $I_{0}$ is held at +10 V , device outputs $\mathrm{F}_{0-3}$ and $\mathrm{P}_{0-1}$ reflect the contents of state register bits $\mathrm{P}_{2-7}$ (see Diagnostic Output Mode diagram). The contents of flip-flops $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ remain unaltered. | Active-High/Low |
| $\begin{gathered} 9-11 \\ 13 \end{gathered}$ | $\mathrm{F}_{0-3}$ | Logic/Diagnostic Outputs: Four device outputs which normally reflect the contents of Output Register bits $Q_{0-3}$, when enabled. When $I_{0}$ is held at $+10 \mathrm{~V}, \mathrm{~F}_{0-3}=\left(\mathrm{P}_{2-5}\right)$. | Active-High |
| 14-15 | $\mathrm{P}_{0-1}$ | Logic/Diagnostic Outputs: Two register bits with shared function as least significant State Register bits, or most significant Output Register bits. When $\mathrm{I}_{0}$ is held at +10 V , $\mathrm{P}_{0-1}=\left(\mathrm{P}_{6-7}\right)$. | Active-High |
| 16 | PR/ $\overline{O E}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an Asynchronous Preset to logic " 1 " of all State and Output Register bits. Preset overrides Clock, and when held High, clocking is inhibited and $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ are High. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes Low. | Active High (H) |
|  |  | - Output Enable: Provides an Output Enable function to all output buffers. | Active-Low (L) |

## LOGIC FUNCTION

Typical State Transition:

$\operatorname{ser} a_{0}: s_{0}=\left(\bar{Q}_{2} \cdot Q_{1} \cdot \bar{Q}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot c \ldots$
$\mathrm{R}_{0}=0$
RESET $\left.\left.Q_{1}: s_{1}=0 \quad\binom{A_{1}}{A_{1}}=\overline{\left(Q_{2}\right.} * Q_{1}\right) \cdot \overline{Q_{0}}\right) \cdot \bar{B} \cdot C \ldots$
HOLD $Q_{2}: \begin{aligned} S_{2} & =0 \\ A_{2} & =0\end{aligned}$
TB00900s

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. PR/ $\overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0).
3. All $\mathrm{S} / \mathrm{R}$ flip-flop inputs are disabled (0).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program. This is accomplished automatically by any Signetics qualified programming equipment.

TRUTH TABLE ${ }^{1,2,3,4,5,6}$

| Vcc | OPTION |  | 10 | CK | S | R | $Q_{\text {P/F }}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | $\overline{O E}$ |  |  |  |  |  |  |
|  | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ |  | $+10 \mathrm{~V}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ | X X X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & H \\ & Q_{n} \\ & Q_{n} \end{aligned}$ | $\begin{gathered} H \\ \left(Q_{P}\right)_{n} \\ \left(Q_{F}\right)_{n} \end{gathered}$ |
| +5V |  | $\begin{aligned} & H \\ & L \\ & L \end{aligned}$ | $\begin{gathered} +10 \mathrm{~V} \\ \mathrm{X} \end{gathered}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | X X X | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & Q_{n} \\ & Q_{n} \\ & Q_{n} \end{aligned}$ | $\begin{aligned} & \mathrm{Hi}-\mathrm{Z} \\ & \left(\mathrm{Q}_{\mathrm{P}}\right)_{n} \\ & \left(\mathrm{Q}_{\mathrm{F}}{ }_{n}\right. \end{aligned}$ |
|  |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \uparrow \\ & \uparrow \\ & \uparrow \end{aligned}$ | L L H H | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} Q_{n} \\ L \\ H \\ \text { IND. } \end{gathered}$ | $\begin{gathered} \left(Q_{F}\right)_{n} \\ L \\ H \\ \text { IND. } \end{gathered}$ |
| $\uparrow$ | X | X | X | X | X | X | H |  |

NOTES:

1. Positive Logic:

$$
\begin{aligned}
& S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47} \\
& T_{n}=C\left(I_{0} I_{1} I_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{7}\right)
\end{aligned}
$$

2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user programmable option.
3. $\uparrow$ denotes transition from Low-to-High level.
4. $R=S=$ High is an illegal input condition.
5. ${ }^{*}=H / L /+10 V$
6. $X=$ Don't care $(\leqslant 5.5 \mathrm{~V})$

## Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ )

PLS167A

FPLS LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS167AN |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS167AA |

ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| Iout | Output currents |  | + 100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\text {IH }}$ | High | $V_{C C}=$ Max | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low | $\mathrm{V}_{C C}=\mathrm{Min}$ |  |  | 0.8 | $v$ |
| $V_{\text {IC }}$ | Clamp ${ }^{4}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{I}}=-12 \mathrm{~mA}$ |  | -0.8 | -1.2 |  |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOH}^{\mathrm{OH}}=-2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{i}_{\mathrm{H}} \\ & \mathrm{i}_{\mathrm{IL}} \\ & i_{\mathrm{IL}} \end{aligned}$ | High <br> Low <br> Low (CK input) | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \end{array}$ | $\begin{gathered} 25 \\ -100 \\ -250 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{7}$ <br> Short circuit ${ }^{4,8}$ | $\begin{gathered} V_{\mathrm{CC}}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{9}$ | $V_{C C}=M a x$ |  | 120 | 180 | mA |
| Capacitance $^{7}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 10 \end{gathered}$ |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings' may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} . \mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $\mathrm{V}_{\mathrm{HL}}$ applied to $\overline{\mathrm{OE}}$ and a logic high stored, or with $\mathrm{V}_{H \mathrm{H}}$ applied to PR.
6. Measured with a programmed logic condition for which the output is at a low logic level, and VIL applied to PR/DE Output sink current is supplied through a resistor to $V_{C C}$.
7. Measured with $V_{I H}$ applied to PR/DE.
8. Duration of short circuit should not exceed 1 second.
9. ICC is measured with the PR/ $\overline{O E}$ input grounded, all other inputs at 4.5 V and the outputs open.

## Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ )

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | то | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width ${ }^{3}$ |  |  |  |  |  |  |  |
| $t_{\text {CKH }}$ <br> $t_{\text {CKL }}$ <br> ${ }^{\text {t }}{ }^{\text {CKP1 }} 1 \mathrm{~B}$ <br> ${ }^{\mathrm{t}_{\mathrm{CKP}} \mathrm{CB}^{2}}$ <br> $t_{\text {PRH }}$ | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | $\begin{aligned} & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR - } \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK }- \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & 50 \\ & 80 \\ & 25 \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 50 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{IS} 1} \mathrm{~A}$ <br> $\mathrm{tis}_{1} B$ <br> $\mathrm{t}_{\mathrm{IS} 2} \mathrm{~A}$ <br> $\mathrm{t}_{\text {IS } 2} \mathrm{~B}$ <br> tvs <br> tPRS | input <br> Input <br> Input (through Complement Array) Input (through Complement Array) <br> Power-on preset <br> Preset | CK + <br> CK + <br> CK + <br> CK + <br> CK - <br> CK - | Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input <br> $V_{C C}+$ <br> PR - | $\begin{aligned} & 40 \\ & 30 \\ & 70 \\ & 60 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $t_{\text {IH }}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tcko $^{\text {teo }}$ <br> toe <br> tod <br> $t_{P R}$ <br> tppR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output - <br> Output + <br> Output + <br> Output + | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{OE}- \\ & \mathrm{OE}+ \\ & \mathrm{PR}+ \\ & \mathrm{V}_{\mathrm{CC}}+ \end{aligned}$ |  | $\begin{gathered} \hline 15 \\ 20 \\ 20 \\ 18 \\ 0 \end{gathered}$ | $\begin{aligned} & 20 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \\ & \hline \end{aligned}$ | ns |
| Frequency of operation ${ }^{3}$ |  |  |  |  |  |  |  |
| $\begin{aligned} & f_{\text {Max }} B \\ & f_{\text {Max }} B \end{aligned}$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{aligned} & 20.0 \\ & 12.5 \end{aligned}$ | MHz |

## NOTES:

1. All typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 30$ ns.
3. See "Speed vs. OR Loading" diagrams.


需

## TIMING DIAGRAMS



## TIMING DEFINITIONS

tCKH Width of input clock pulse.
$t_{C K L} \quad$ Interval between clock pulses.
tcKP1 Clock period - when not using Compiement array.
$t_{\text {S }} 1$ Required delay between beginning of valid input and positive transition of clock.
tCKP2 Clock period - when using complement array.
$\mathrm{t}_{\text {S } 2}$ Required delay between beginning of valid input and positive transition of clock, when using optional Complement Array (two passes necessary through the AND array).
tvs Required delay between $\mathrm{V}_{\mathrm{CC}}$ (after power-on) and negative transition of clock preceding first reliable clock puise.
Required delay between negative transition of asynchronous Preset and negative transition of clock preceding first reliable clock pulse.
$\mathrm{t}_{\mathrm{IH}} \quad$ Required delay between positive transition of clock and end of valid Input data.
toko Delay between positive transition of clock and when Outputs become valid (with PR/OE Low).
toE Delay between beginning of Output Enable Low and when Outputs become valid.
toD Delay between beginning of Output Enable High and when Outputs are in the off state.
tSRE Delay between input $I_{0}$ transition to Diagnostic mode and when the Outputs reflect the contents of the State Register.
tsRD Delay between input 10 transition to Logic mode and when the Outputs reflect the contents of the Output Register.
$t_{\text {PR }}$ Delay between positive transition of Preset and when Outputs become valid at " 1 ".
tpph Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 ".
$t_{\text {PRH }} \quad$ Width of preset input pulse.
$f_{\text {MAX }}$ Maximum clock frequency.

TIMING DIAGRAMS (Continued)


## test load circuit



## VOLTAGE WAVEFORM

| MEASUREMENTS: <br> All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified. Input Pulses |
| :---: |
|  |  |
|  |  |

TIMING DIAGRAMS (Continued)


## TEST LOAD CIRCUIT

(2)

## VOLTAGE WAVEFORM



MEASUREMENTS:
All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified. Input Pulses

TIMING DIAGRAMS


Power-On Preset

## TIMING DEFINITIONS

tCKH Width of input clock pulse.
tcKL Interval between clock pulses.
$t_{\text {CKP1 }}$ Clock period-when not using Complement array.
$t_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of clock.
$t_{\text {CKP2 }}$ Clock period - when using complement array.
$t_{\text {IS2 }} \quad$ Required delay between beginning of valid input and positive transition of clock, when using optional Complement Array (two passes necessary through the AND array).
tvs Required delay between $V_{C C}$ (after power-on) and negative transition of clock preceding first reliable clock pulse.
tPRS Required delay between negative transition of asynchronous Preset and negative transition of clock preceding first reliable clock pulse.
$\mathrm{t}_{\mathrm{iH}} \quad$ Required delay between positive transition of clock and end of valid Input data.
$t_{\text {CKO }}$ Delay between positive transition of clock and when Outputs become valid (with PR/ $\overline{O E}$ Low).
$t_{\text {OE }} \quad$ Delay between beginning of Output Enable Low and when Outputs become valid.
toD Delay between beginning of Output Enable High and when Outputs are in the off state.
$t_{\text {SRE }}$ Delay between input $t_{0}$ transition to Diagnostic mode and when the Outputs reflect the contents of the State Register.
$t_{\text {SRD }}$ Delay between input $I_{0}$ transition to Logic mode and when the Outputs reflect the contents of the Output Register.
Delay between positive transition of Preset and when Outputs become valid at " 1 ".
Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 ".
$t_{\text {RH }}$ Width of preset input pulse.
$f_{\text {MAX }}$ Maximum clock frequency.

## SPEED VS. 'OR' LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:

$$
\left(1 / f_{M A X}\right)=t_{C Y}=t_{I S}+t_{C K O}
$$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $\mathrm{t}_{\mathrm{IS}}$, due to capacitive loading. The effect of this loading can be seen in Figure 1, showing the variation of $\mathrm{t}_{\mathrm{IS} 1}$ with the number of terms connected per OR

The AC electrical characteristics contain two limits for the parameters $\mathrm{t}_{\mathrm{IS} 1}$ and $\mathrm{t}_{\text {IS2 }}$. The first, $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~A}}$ is guaranteed for a device with 24 terms connected to any OR line. $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~B}}$ is guaranteed for a device with 16 terms connected to any OR line.


Figure 1. $\mathrm{t}_{\mathrm{IS} 1}$ vs. Terms/OR Connected

The three other entries in the $A C$ tabie, $\mathrm{t}_{\text {IS2 }}$ $A$ and $B$ are corresponding 24 and 16 term limits when using the on-chip Complement Array.
The worst case of $t_{1 S}$ for a given application can be determined by identifying the OR line with the maximum number of $T_{n}$ connections. This can be done by referring to the interconnect pattern in the FPLS logic
diagram, typically illustrated in Figure 2, or by counting the maximum number of " H " or "L"' entries in one of the columns of the device Program Table.
This number plotted on the curve in Figure 1 will yield the worst case $t_{i s}$ and, by implication, the maximum clocking frequency for reliable operation.
Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.
In this table, the logic state or action of control variables $C, I, P, N$, and $F$, associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

## PRESET/DE OPTION - (P/E)



PROGRAMMING:
The PLS167A has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High (H). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs ( H ) as the present state.
'AND' ARRAY - (I), (P)

"OR" ARRAY - (N), (F)

"COMPLEMENT" ARRAY - (C)


## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $T_{n}$ will be unconditionally inhibited if both the true and the complement of any input ( $1, P$ ) are left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for C link pairs coupled to active gates $\mathrm{T}_{\mathrm{n}}$.

## Field-Programmable Logic Sequencer $(14 \times 48 \times 6) \quad$ PLS167A

FPLS PROGRAM TABLE


## NOTES:

1. The FPLS is shipped with all links initially intact. Thus, a background of " 0 ' for all Terms, and an ' $H$ " for $P / E$ option, exists in the table, shown BLANK instead for clarity.
2. Unused $C_{n}, I_{m}$, and $P_{s}$ bits are normally programmed Don't Care (-).
3. Unused Transition Terms can be left blank for future code modification or programmed as (-) for maximum speed.
4. Letters in variable fields are used as identifiers by logic programmers.

Field-Programmable Logic Sequencer ( $14 \times 48 \times 6$ )

## TEST ARRAY

The FPLS may be subjected to AC and DC parametric tests prior to programming via an on-chip test array.
The array consists of test transition terms 48 and 49, factory programmed as shown below.
Testing is accomplished by clocking the FPLS and applying the proper input sequence to $l_{0-13}$ as shown in the test circuit timing diagram.


State Diagram


TCO1592S
FPLS Under Test


| OPTION (P/E) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OR |  |  |  |  |  |  |  |  |  |  |  |
| MEXT STATE (Ns) |  |  |  |  |  |  |  | OUTPUT (Fr) |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |
| L | L | $L$ | L | L | L | L | L | L | 1 | L | L |
| H | H | H | H | H | H | H | H | H | H | H | H |

Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.


Test Circuit Timing Diagram


# PLS168 <br> <br> Field-Programmable Logic <br> <br> Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ ) 

 Sequencer ( $12 \times 48 \times 8$ )}

Signetics Programmable Logic<br>Product Specification

## Signetics

## Application Specific Products - Series 24

## DESCRIPTION

The PLS168 is a bipolar, programmable state machine of the Mealy type. It contains logic AND-OR gate arrays with user programmable connections which control the inputs of on-chip State and Output Registers. These consist respectively of $10 Q_{p}$, and $4 Q_{f}$ edge-triggered, clocked S/R flip-flops, with an Asynchronous Preset option.

All flip-flops are unconditionally preset to "1" during power turn-on.
The AND array combines 12 external inputs, $\mathrm{I}_{0-11}$, with 10 internal inputs, $\mathrm{P}_{0-9}$, fed back from the State Register to form up to 48 transition terms (AND terms). In addition, $\mathrm{P}_{0}-\mathrm{P}_{3}$ of the internal State Register are brought off-chip to allow extending the Output Register to 8 bits, if so desired.

All transition terms can include True, False, or Don't Care states of the controlling variables, and are merged in the OR array to issue next-state and nextoutput commands to their respective registers on the Low-to-High transition of the Clock pulse.
Both True and Complement transition terms can be generated by optional use of the internal variable (C) from the Complement Array. Also, if desired, the Preset input can be converted to output-
enable function, as an additional user programmable option.
Order codes for this device are contained on the pages following.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 12 True/Complement buffered inputs
- 48 programmable AND gates
- 29 programmable OR gates
- 10-bit State Register
- 4-bit shared State/Output Register
- 4-bit Output Register
- Transition Complement Array
- Programmable Asynchronous Preset/Output Enable
- Positive edge-triggered clock
- Power-on preset to logic "1" of all registers
- Automatic logic 'HOLD' state via S/R flip-flops
- On-chip Test Array
- $\mathrm{f}_{\text {MAX }}$ : 13.9 MHz
- Power: 600mW (typ.)
- TTL compatible
- Tri-state outputs
- Single +5V supply
- 30̂umii-wide 24-pin DiP

FUNCTIONAL DIAGRAM


## PIN CONFIGURATIONS



APPLICATIONS

- Interface protocols
- Sequence detectors
- Peripheral controllers
- Timing generators
- Sequential circuits
- Elevator controllers
- Security locking systems
- Counters
- Shift registers

PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-6 \\ 18-23 \end{gathered}$ | $\mathrm{I}_{1-11}$ | Logic Inputs: The 11 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 7 | $\mathrm{I}_{0}$ | Logic/Diagnostic Input: A 12th external logic input to the AND array, as above, when exercised with standard TTL levels. When $I_{0}$ is held at +10 V , device outputs $\mathrm{F}_{2-3}$ and $\mathrm{P}_{0-3}$ reflect the contents of State Register bits $\mathrm{P}_{4-9}$ (see Diagnostic Output Mode diagram). The contents of flip-flops $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ remain unaltered. | Active-High/Low |
| 13-16 | $\mathrm{P}_{0-3}$ | Logic/Diagnostic Outputs: Four device outputs which normally reflect the contents of State Register bits $\mathrm{P}_{0-3}$. When $\mathrm{I}_{0}$ is held at +10 V these pins reflect ( $\mathrm{P}_{6}-\mathrm{P}_{9}$ ). | Active-High |
| 10-11 | $\mathrm{F}_{2}-\mathrm{F}_{3}$ | Logic/Diagnostic Outputs: Two register bits ( $F_{2}-F_{3}$ ) which normally reflect Output Register bits $\left(Q_{2}-Q_{3}\right)$. When $I_{0}$ is held at +10 V these pins reflect $\left(P_{4}-P_{5}\right)$. | Active-High |
| 17 | PR/ $\overline{\mathrm{OE}}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an Asynchronous Preset to logic "1" of all State and Output Register bits. Preset overrides Clock, and when held high, clocking is inhibited and $P_{0-9}$ and $F_{0-3}$ are high. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes low. <br> - Output Enable: Provides an Output Enable function to all output buffers. | Active-High (H) Active-Low (L) |
| 8, 9 | $\mathrm{F}_{0}-\mathrm{F}_{1}$ | Logic Output: Two device outputs which reflect Output Registers $Q_{0}-Q_{1}$. When $I_{0}$ is held at $+10 \mathrm{~V} F_{0}-F_{1}=$ Logic " 1 ". |  |

## LOGIC FUNCTION

Typical State Transition:

$\operatorname{SET} Q_{0}: s_{0}=\left(\bar{a}_{2} \cdot Q_{1} \cdot \bar{Q}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot c$.

$$
R_{0}=0
$$

RESET $a_{1}: S_{1}=0, \bar{Q}_{1}=\left(\bar{O}_{2} \cdot Q_{1} \cdot \bar{a}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot C$.
HOLD $Q_{2}: \begin{aligned} & \mathbf{S}_{2}=0 \\ & R_{2}=0\end{aligned}$
TB00900s

## VIRGIN STATE

A factory shipped virgin device contains all fusible links-intaet, sueh that:

1. $\mathrm{PR} / \overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0).
3. All $S / R$ flip-flop inputs are disabled ( 0 ).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program. This is accomplished automatically by any Signetics qualified programming equipment.

TRUTH TABLE ${ }^{1,2,3,4,5,6}$

| $V_{\text {cc }}$ | OPTION |  | $I_{0}$ | CK | S | R | $Q_{\text {P/F }}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | $\overline{O E}$ |  |  |  |  |  |  |
| $+5 \mathrm{~V}$ | H |  | * | x | X | x | H | H |
|  | L |  | +10V | X | X | X | $Q_{n}$ | $\left(Q_{p}\right)_{n}$ |
|  | L |  | X | X | X | X | $Q_{n}$ | $\left(\mathrm{Q}_{\mathrm{F}}\right)_{n}$ |
|  |  | H |  | X | X | X | $Q_{n}$ | Hi-Z |
|  |  | L | $+10 \mathrm{~V}$ | X | X | X | $Q_{n}$ | $\left(Q_{P}\right)_{n}$ |
|  |  | L | X | X | X | X | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | $\uparrow$ | L | L | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | $\uparrow$ | L | H | L | L |
|  |  | L | x | $\uparrow$ | H | L | H | H |
|  |  | L | X | $\uparrow$ | H | H | IND. | IND. |
| $\uparrow$ | X | X | X | X | X | X | H |  |

## NOTES:

1. Positive Logic:

$$
\begin{aligned}
& S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47} \\
& T_{n}=C\left(l_{0} I_{1} I_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{9}\right)
\end{aligned}
$$

2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user programmable option.
3. $\uparrow$ denotes transition from Low to High level.
4. $R=S=$ High is an illegal input condition.
5. ${ }^{*}=H / L /+10 V$
6. $X=$ Don't care $(\leqslant 5.5 \mathrm{~V})$

## FPLS LOGIC DIAGRAM



## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS168N |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS168A |

THERMAL RATING

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{\text {cc }}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $V_{1 N}$ | input voltage |  | $+5.5$ | $V_{D C}$ |
| VOUT | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{N}}$ | Input currents | -30 | +30 | mA |
| IIN | Output currents |  | $+100$ | mA |
| $\mathrm{T}_{\mathrm{A}}$ TSTG | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{I H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High Low Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\operatorname{Min} \\ V_{C C}=\text { Min, }^{\prime} \operatorname{l}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \mathrm{High}^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOH}=-2 \mathrm{~mA} \\ & \mathrm{IOL}=9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{HH}} \\ & I_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{LL}} \end{aligned}$ | High Low Low (CK input) | $\begin{aligned} \mathrm{V}_{\mathbb{N}} & =5.5 \mathrm{~V} \\ \mathrm{~V}_{\mathbb{N}} & =0.45 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IN}} & =0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \end{array}$ | $\begin{gathered} 25 \\ -100 \\ -250 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state $^{7}$ <br> Short circuit ${ }^{4,8}$ | $\begin{gathered} V_{\text {CC }}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 | 1 -1 | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{9}$ | $V_{C C}=$ Max |  | 120 | 180 | mA |
| Capacitance ${ }^{7}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{gathered} V_{\mathrm{CC}}=5.0 \mathrm{~V} \\ \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }}=2.0 \mathrm{~V} \end{gathered}$ |  | 8 10 |  | pF |

## NOTES:

1. Stresses above those tisted under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I L}$ applied to $\bar{O}$ and a logic high stored, or with $V_{i r i}$ applied to PR.
6. Measured with a programmed logic condition for which the output is at a low logic level, and $\mathrm{V}_{\mathrm{IL}}$ applied to PR/ $\overline{\mathrm{OE}}$ Output sink current is supplied through a resistor to $V_{C C}$.
7. Measured with $V_{I H}$ applied to PR/ $\overline{\mathrm{OE}}$.
8. Duration of short circuit should not exceed 1 second.

9 . Icc is measured with the PR/ $\overline{\mathrm{OE}}$ input grounded, all other inputs at 4.5 V and the outputs open.

## Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ )

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | то | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width ${ }^{3}$ |  |  |  |  |  |  |  |
| t. $_{\text {CKH }}$ <br> $t_{\text {CKL }}$ <br> $\mathrm{t}_{\mathrm{CKP}_{1}} \mathrm{~B}$ <br> $\mathrm{t}_{\mathrm{CKP} 2} \mathrm{~B}$ <br> $t_{\text {PRH }}$ | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | $\begin{aligned} & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR - } \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK }- \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{gathered} 25 \\ 25 \\ 80 \\ 120 \\ 25 \end{gathered}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 60 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $t_{I S 1} A$ <br> $t_{1 S 1} B$ <br> ${ }_{\mathrm{t}_{15} 1} \mathrm{C}$ <br> $t_{\text {IS2 }} A$ <br> $\mathrm{t}_{1 \mathrm{~S} 2} \mathrm{~B}$ <br> $\mathrm{t}_{\mathrm{IS}_{2} \mathrm{C}} \mathrm{C}$ <br> tvs <br> tprs | Input <br> Input <br> Input <br> Input (through Complement Array) <br> Input (through Complement Array) <br> Input (through Complement Array) <br> Power-on preset <br> Preset | CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK - <br> CK - | Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> input <br> Input <br> $V_{C C}+$ <br> PR - | $\begin{gathered} 60 \\ 50 \\ 42 \\ 90 \\ 80 \\ 72 \\ 0 \\ 0 \end{gathered}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{H}}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| teko $^{\text {CKO }}$ <br> toe <br> tod <br> $t_{P R}$ <br> tppR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output - <br> Output + <br> Output + <br> Output + | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{OE}- \\ & \mathrm{OE}+ \\ & \mathrm{PR}+ \\ & \mathrm{V}_{\mathrm{CC}}+ \end{aligned}$ |  | $\begin{aligned} & 15 \\ & 20 \\ & 20 \\ & 18 \\ & 0 \end{aligned}$ | $\begin{aligned} & 30 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \end{aligned}$ | ns |
| Frequency of operation ${ }^{3}$ |  |  |  |  |  |  |  |
| $\begin{aligned} & f_{M A X} C \\ & f_{M A X} C \end{aligned}$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} 13.9 \\ 9.8 \end{gathered}$ | MHz |

## NOTES:

1. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 30 \mathrm{~ns}$
3. See 'Speed vs. OR Loading' diagrams.

TIMING DIAGRAMS


## TIMING DEFINITIONS

$\mathrm{t}_{\mathrm{CKH}} \quad$ Width of input clock pulse.
$t_{\text {CKL }} \quad$ Interval between clock pulses.
$\mathrm{t}_{\mathrm{CKP1}} \quad$ Clock period-when not using Complement array.
$\mathrm{t}_{\mathrm{IS} 1} \quad$ Required delay between beginning of valid input and positive transition of clock.
tCKP2 Clock period - when using complement array.
tis2 Required delay between beginning of valid input and positive transition of clock, when using optional Complement Array (two passes necessary through the AND array).
tvs Required delay between $V_{C C}$ (after power-on) and negative transition of clock preceding first reliable clock pulse.
tPRS Required delay between negative transition of asynchronous Preset and negative transition of clock preceding first reliable clock pulse.
$t_{\mathrm{IH}} \quad$ Required delay between positive transition of clock and end of valid input data.
$t_{C K O} \quad$ Delay between positive transition of clock and when Outputs become valid (with PR/OE Low).
toE Delay between beginning of Output Enable Low and when Outputs become valid.
toD Delay between beginning of Output Enable High and when Outputs are in the off state.
tsRE Delay between input $I_{0}$ transition to Diagnostic mode and when the Outputs reflect the contents of the State Register.
tSRD Delay between input ! I $_{0}$ transition to Logic mode and when the Outputs reflect the contents of the Output Register.
tpR Delay between positive transition of Preset and when Outputs become valid " 1 ".
tppR Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 '".
tpRH Width of preset input pulse.
$f_{\text {MAX }}$ Maximum clock frequency.

TIMING DIAGRAMS (Continued)


## TEST LOAD CIRCUIT



TC01570S

(INCLUDES SCOPE
AND JIG
CAPACITANCE)

## VOLTAGE WAVEFORM



All circuit delays are measured at the +1.5 V leve of inputs and output, uniess otherwise specified. Input Pulses

## SPEED VS. 'OR" LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:

$$
\left(1 / f_{M A X}\right)=t_{C Y}=t_{I S}+t_{C K O}
$$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $t_{I S}$, due to capacitive loading. The effect of this loading can be seen in Figure 1 , showing the variation of $t_{S_{1}}$ with the number of terms connected per OR.

The AC electrical characteristics contain three limits for the parameters $t_{I S 1}$ and $t_{I S 2}$. The first, $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~A}}$ is guaranteed for a device with 48 terms connected to any OR line. $t_{\mid S 1 B}$ is guaranteed for a device with 32 terms connected to any OR line. And $\mathrm{t}_{\mathrm{ISi}} \mathrm{C}$ is guaranteed for a device with 24 terms connecied to any OR line.


Figure 1. $\mathrm{t}_{\mathrm{IS} 1}$ vs. Terms/OR Connected

The three other entries in the $A C$ table, $\mathrm{t}_{\mathrm{I}} \mathrm{S}_{2}$ $A, B$ and $C$ are corresponding 48,32 and 24 term limits when using the on-chip Complement Array.
The worst case of $\mathrm{t}_{\text {Is }}$ for a given application can be determined by identifying the $O R$ line with the maximum number of $T_{n}$ connections. This can be done by referring to the interconnect pattern in the FPLS logic
diagram, typically illustrated in Figure 2, or by counting the maximum number of " H " or "L" entries in one of the columns of the device Program Table.

This number plotted on the curve in Figure 1 will yield the worst case $t_{I S}$ and, by implication, the maximum clocking frequency for reliable operation.

Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.

In this table, the logic state or action of control variables $\mathrm{C}, \mathrm{I}, \mathrm{P}, \mathrm{N}$, and F , associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

PRESET/OE OPTION - (P/E)


PROGRAMMING:
The PLS168 has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High $(\mathrm{H})$. When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs $(H)$ as the present state.
"AND" ARRAY - (I), (P)

|  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| STATE CODE | STATE ${ }^{\text {a }}$ ( CODE | STATE $\quad$ CODE | STATE | CODE |
| INACTIVE ${ }^{1,2}$ | $\mathbf{I}, \mathbf{P}$ $\mathbf{H}$ | $\overline{1}, \overline{\mathbf{P}}$ $L$ | DON'T CARE | - |

"OR' ARRAY - (N), (F)

"COMPLEMENT" ARRAY - (C)


NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $T_{n}$ will be unconditionally inhibited if both the true and complement of any input (I or $P$ ) are left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

Field-Programmable Logic Sequencer $(12 \times 48 \times 8) \quad$ PLS168

FPLS PROGRAM TABLE PLS168


## Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ )

## TEST ARRAY

The FPLS may be subjected to $A C$ and DC parametric tests prior to programming via an on-chip test array.

The array consists of test transition terms 48 and 49 , factory programmed as shown below.

Testing is accomplished by clocking the FPLS and applying the proper input sequence to $\mathrm{I}_{0-11}$ as shown in the test circuit timing diagram.


State Diagram


FPLS Under Test


Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.


Test Circuit Timing Diagram


Test Array Deleted

# PLS168A <br> Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ ) 

Signetics Programmable Logic<br>Product Specification

## Signetics

## Application Specific Products - Series 24

## DESCRIPTION

The PLS168A is a bipolar, programmable state machine of the Mealy type. It contains logic AND-OR gate arrays with user programmable connections which control the inputs of on-chip State and Output Registers. These consist respectively of $10 Q_{p}$, and $4 Q_{f}$ edge-triggered, clocked S/R flip-flops, with an Asynchronous Preset option.

All flip-flops are unconditionally preset to "1" during power turn-on.
The AND array combines 12 external inputs, $\mathrm{I}_{0-11}$, with 10 internal inputs, $\mathrm{P}_{0-9}$, fed back from the State Register to form up to 48 transition terms (AND terms). In addition, $\mathrm{P}_{0}-\mathrm{P}_{3}$ of the internal State Register are brought off-chip to allow extending the Output Register to 8 bits, if so desired.

Ail transition terms can inciude True, False, or Don't Care states of the controlling variables, and are merged in the OR array to issue next-state and nextoutput commands to their respective registers on the Low-to-High transition of the Clock pulse.
Both True and Complement transition terms can be generated by optional use of the internal variable (C) from the Complement Array. Also, if desired, the Preset input can be converted to output-
enable function, as an additional user programmable option.
Order codes for this device are contained on the pages following.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 12 True/Complement buffered inputs
- 48 programmable AND gates
- 29 programmable OR gates
- 10-bit State Register
- 4-bit shared State/Output Register
- 4-bit Output Register
- Transition Complement Array
- Programmable Asynchronous Preset/Output Enable
- Positive edge-triggered clock
- Power-on preset to logic "1" of all registers
- Automatic logic "HOLD" state via S/R flip-flops
- On-chip Test Array
- $f_{\text {MAX: }} 20 \mathrm{MHz}$
- Power: 600 mW (typ.)
- TTL compatible
- Tri-state outputs
- Singie +5V supply
- 300mil-wide 24 -pin DIP

FUNCTIONAL DIAGRAM


PIN CONFIGURATIONS


## APPLICATIONS

- Interface protocols
- Sequence detectors
- Peripheral controllers
- Timing generators
- Sequential circuits
- Elevator controllers
- Security locking systems
- Counters
- Shift registers

Field-Programmable Logic Sequencer ( $12 \times 48 \times 8$ )

PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-6 \\ 18-23 \end{gathered}$ | $\mathrm{I}_{1-11}$ | Logic Inputs: The 11 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 7 | 10 | Logic/Diagnostic Input: A 12th external logic input to the AND array, as above, when exercised with standard TTL levels. When $I_{0}$ is held at +10 V , device outputs $F_{2}-F_{3}$ and $P_{0}-P_{3}$ reflect the contents of State Register bits $P_{4-9}$ (see Diagnostic Output Mode diagram). The contents of flip-flops $\mathrm{P}_{0-1}$ and $\mathrm{F}_{0-3}$ remain unaltered. | Active-High/Low |
| 13-16 | $\mathrm{P}_{0-3}$ | Logic/Diagnostic Outputs: Four device outputs which normally reflect the contents of State Register bits $\mathrm{P}_{0-3}$. When $\mathrm{I}_{0}$ is held at +10 V these pins reflect ( $\mathrm{P}_{6}-\mathrm{P}_{9}$ ). | Active-High |
| 10-11 | $F_{2}-F_{3}$ | Logic/Diagnostic Outputs: Two register bits ( $F_{2}-F_{3}$ ) which reflect Output Register bits $\left(Q_{2}-Q_{3}\right)$. When $I_{0}$ is held at +10 V these pins reflect $\left(P_{4}-P_{5}\right)$. | Active-High |
| 17 | $\mathrm{PR} / \overline{\mathrm{OE}}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an Asynchronous Preset to logic "1" of all State and Output Register bits. Preset overrides Clock, and when held high, clocking is inhibited and $P_{0-9}$ and $\mathrm{F}_{0-3}$ are high. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes low. | Active-High (H) |
| 8, 9 | $F_{0}-F_{1}$ | - Output Enable: Provides an Output Enable function to all output buffers. <br> Logic Output: Two device outputs which reflect Output Registers $Q_{0}-Q_{1}$. When $I_{0}$ is held at $+10 \mathrm{~V} \mathrm{~F}_{0}-\mathrm{F}_{1}=$ Logic " 1 " | Active-Low (L) |

## LOGIC FUNCTION

## Typical State Transition:



SET $O_{0}: S_{0}=\left(\bar{O}_{2} \cdot Q_{1} \cdot \bar{Q}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots$

$$
R_{0}=0
$$

RESET $Q_{1}: \begin{aligned} & s_{1}=0 \\ & \left.R_{1}=\overline{\left(Q_{2}\right.} \cdot Q_{1} \cdot \bar{Q}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots\end{aligned}$
HOLD $\mathrm{O}_{2}: \begin{aligned} & \mathrm{S}_{2}=0 \\ & \mathrm{R}_{2}=0\end{aligned}$
твооsoos

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. PR/ $\overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0).
3. All S/R flip-flop inputs are disabled (0).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program.

TRUTH TABLE ${ }^{1,2,3,4,5,6}$

| $\mathrm{V}_{\mathrm{cc}}$ | OPTION |  | $I_{0}$ | CK | S | R | $Q_{\text {P/F }}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | OE |  |  |  |  |  |  |
| $+5 \mathrm{~V}$ | H |  | * | x | X | x | H | H |
|  | L |  | +10V | X | X | X | $\mathrm{Q}_{\mathrm{n}}$ | $\left(\mathrm{Q}_{\mathrm{P}}\right)_{n}$ |
|  | L |  | X | X | $x$ | X | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | H | * | X | X | X | $Q_{n}$ | Hi-Z |
|  |  | L | +10V | X | X | X | $Q_{n}$ | $\left(Q_{P}\right)_{n}$ |
|  |  | L | X | X | X | X | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | $\uparrow$ | L | L | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | , | L | H | L | L |
|  |  | L | X | $\uparrow$ | H | L | H | H |
|  |  | L | X | $\uparrow$ | H | H | IND. | IND. |
| $\uparrow$ | X | X | X | X | X | X | H |  |

NOTES:

1. Positive Logio:

$$
\begin{aligned}
& S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47} \\
& T_{n}=C\left(l_{0} I_{1} l_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{9}\right)
\end{aligned}
$$

2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user programmable option.
3. $\uparrow$ denotes transition from Low to High level.
4. $R=S=$ High is an illegal input condition.
5.     * $=\mathrm{H} / \mathrm{L} /+10 \mathrm{~V}$
6. $X=$ Don't Care $(\leqslant 5.5 \mathrm{~V})$

FPLS LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS168AN |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS168AA |

THERMAL RATING

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## ABSOLUTE MAXIMUM P:ATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {in }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| Vout | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| 1 N | Output currents |  | +100 | mA |
| $\begin{aligned} & T_{A} \\ & T_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \\ \hline \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High | $V_{C C}=$ Max | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low | $V_{C C}=M i n$ |  |  | 0.8 |  |
| VIC | Clamp ${ }^{4}$ | $V_{C C}=$ Min, $\mathrm{l}_{\mathrm{N}}=-12 \mathrm{~mA}$ |  | -0.8 | -1.2 |  |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \mathrm{High}^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOH}=-2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{IH}} \\ & \mathrm{I}_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{L}} \end{aligned}$ | High Low Low (CK input) | $\begin{aligned} & V_{\text {IN }}=5.5 \mathrm{~V} \\ & V_{\mathrm{IN}}=0.45 \mathrm{~V} \\ & V_{\mathrm{IN}}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \end{array}$ | $\begin{gathered} 25 \\ -100 \\ -250 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> los | Hi-Z state ${ }^{7}$ <br> Short circuit ${ }^{4,8}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }} & =0.45 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 -1 | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu A$ <br> mA |
| lcc | $V_{\text {CC }}$ supply current ${ }^{9}$ | $V_{C C}=$ Max |  | 120 | 180 | mA |
| Capacitance ${ }^{7}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{C C} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | 8 10 |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $\mathrm{V}_{I L}$ applied to $\overline{\mathrm{OE}}$ and a logic high stored. or with $\mathrm{V}_{I H}$ applied to PR.
6. Measured with a programmed logic condition for which the output is at a low logic level, and $V_{\mathrm{IL}}$ applied to PR/OE Output sink current is supplied through a resistor to $V_{\mathrm{Cc}}$.
7. Measured with $V_{I H}$ applied to $P R / \overline{O E}$.
8. Duration of short circuit should not exceed 1 second.
9. $I_{C C}$ is measured with the PR/ $\overline{O E}$ input grounded, all other inputs at 4.5 V and the outputs open.

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | Limits |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width ${ }^{3}$ |  |  |  |  |  |  |  |
| tCKH $\mathrm{t}_{\mathrm{CKL}}$ $\mathrm{t}_{\mathrm{CKP} 1} \mathrm{~B}$ ${ }^{\text {t.KMP2 }}$ $t_{\text {PRH }}$ | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | $\begin{aligned} & \mathrm{CK}- \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{PR}- \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & 50 \\ & 80 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 50 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $\mathrm{t}_{1 S}{ }^{A}$ <br> ${ }_{1 / S 1} B$ <br> ${ }_{\mathrm{t}}^{\mathrm{IS} 2} \mathrm{~A}$ <br> $\mathrm{t}_{\mathrm{IS}} \mathrm{B}^{\mathrm{B}}$ <br> tvs <br> tPRS | Input <br> Input <br> Input (through Complement Array) <br> Input (through Complement Array) <br> Power-on preset <br> Preset | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}- \\ & \mathrm{CK}- \end{aligned}$ | input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input <br> $V_{C C}+$ <br> PR- | $\begin{gathered} 40 \\ 30 \\ 70 \\ 60 \\ 0 \\ 0 \end{gathered}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{IH}}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tcko <br> toe <br> tod <br> $t_{\text {PR }}$ <br> tPpR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output- <br> Output + <br> Output + <br> Output + | CK + <br> OE- <br> OE + <br> PR + <br> $\mathrm{V}_{\mathrm{CC}}+$ |  | $\begin{gathered} 15 \\ 20 \\ 20 \\ 18 \\ 0 \end{gathered}$ | $\begin{aligned} & 20 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \end{aligned}$ | ns |
| Frequency of operation ${ }^{3}$ |  |  |  |  |  |  |  |
| $f_{\text {MAX }} B$ $f_{\operatorname{MaX}} B$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} 20 \\ 12.5 \end{gathered}$ | MHz |

NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time ( $10 \%-90 \%$ ) $\leqslant 30 \mathrm{~ns}$.
3. See "Speed vs. OR Loading" diagrams.

## TIMING DIAGRAMS



## TIMING DEFINITIONS

${ }^{\text {t }}$ CKH Width of input clock pulse.
tckL Interval between clock pulses.
$\mathrm{t}_{\mathrm{CKP}} 1$ Clock period - when not using Complement array.
$t_{I S 1} \quad$ Required delay between beginning of valid input and positive transition of clock.
$t_{\text {CKP2 }}$ Clock period - when using complement array.
$t_{\text {IS2 }}$ Required delay between beginning of valid input and positive transition of clock, when using optional Complement Array (two passes necessary through the AND array).
tvs Required delay between $V_{C C}$ (after power-on) and negative transition of clock preceding first reliable clock pulse.
Required delay between negative transition of asynchronous Preset and negative transition of clock preceding first reliable clock pulse.

TIMING DIAGRAMS (Continued)


## TEST LOAD CIRCUIT



(INCLUDES SCOPE
AND JIG
CAPACITANCE

TCOY570s

## VOLTAGE WAVEFORM



MEASUREMENTS:
All circuit delays are measured at the +1.5 V level of inputs and output, unless otherwise specified. Input Pulses

## SPEED VS. "OR" LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:

$$
\left(1 / f_{\text {MAX }}\right)=t_{C Y}=t_{I S}+t_{C K O}
$$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $\mathrm{t}_{\mathrm{l}}$, due to capacitive loading. The effect of this loading can be seen in Figure 1, showing the variation of $\mathrm{t}_{\mathrm{IS} 1}$ with the number of terms connected per OR.

The AC electrical characteristics contain two limits for the parameters $\mathrm{t}_{\mathrm{IS} 1}$ and $\mathrm{t}_{\mathrm{IS} 2}$. The first, $\mathrm{t}_{\mathrm{S} 1 \mathrm{~A}}$ is guaranteed for a device with 24 terms connected to any OR line. $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~B}}$ is guaranteed for a device with 16 terms connected to any OR line.


Figure 1. $\mathrm{t}_{\mathrm{IS} 1}$ vs. Terms/OR Connected

The three other entries in the $A C$ table, $\mathrm{t}_{\mathrm{I}}$ 2 $A$ and $B$ are corresponding 24 and 16 term limits when using the on-chip Complement Array.
The worst case of $\mathrm{t}_{\mathrm{IS}}$ for a given application can be determined by identifying the OR line with the maximum number of $T_{n}$ connections. This can be done by referring to the interconinect pattern in the FPLS logic
diagram, typically illustrated in Figure 2, or by counting the maximum number of " H " or "i"" entries in one of the coiumns of the device Program Table.
This number plotted on the curve in Figure 1 will yield the worst case $t_{i s}$ and, by implication, the maximum clocking frequency for reliable operation.

Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.

In this table, the logic state or action of control variables $\mathrm{C}, \mathrm{I}, \mathrm{P}, \mathrm{N}$, and F , associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

PRESET/言E OPTION - (P/E)


PROGRAMMING:
The PLS168A has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High (H). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs $(H)$ as the present state.
"AND" ARRAY - (I), (P)

"OR' ARRAY - (N), (F)

|  |  |  |  | LS01870S |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
| ACTION | CODE | ACTION | CODE | ACTION | CODE | ACTION | CODE |
| INACTIVE ${ }^{1,3}$ | 0 | SET | H | RESET | L | NO CHANGE | - |

"COMPLEMENT" ARRAY - (C)

LSO1910S

| ACTION | CODE |
| :---: | :---: |
| PROPAGATE | $\bullet$ |


| LSC1920s |  |
| :---: | :---: |
| ACTION | CODE |
| TRANSPARENT | - |

## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $T_{n}$.
2. Any gate $T_{n}$ will be unconditionally inhibited if any one of its I or $P$ link pairs is left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

## Field-Programmable Logic Sequencer $(12 \times 48 \times 8) \quad$ PLS168A

FPLS PROGRAM TABLE PLS168A


## TEST ARRAY

The FPLS may be subjected to $A C$ and $D C$ parametric tests prior to programming via an on-chip test array.

The array consists of test transition terms 48 and 49 , factory programmed as shown below.
Testing is accomplished by clocking the FPLS and applying the proper input sequence to $\mathrm{I}_{0-11}$ as shown in the test circuit timing diagram.



FPLS Under Test


Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.


Test Circuit Timing Diagram

| ano |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | OPTION(PE) |  |  |  |  |  |  |  |  |  | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | OR |  |  |  |  |  |  |  |  |  |  |
| T | -1, inputim) |  |  |  |  |  |  |  |  |  |  | PRESENT STATE (PS) ( $\mathrm{P}_{\mathrm{x}}$ ) |  |  |  |  |  |  |  | remarks | NExt STATE (Ns) |  |  |  | OUTPUT(FI) |  |  |  |  |  |  |
| M |  | $!$ | 9 |  | 16 | 5 | 4 | $3{ }^{3}$ |  | 1 | 0 |  | 8 |  |  |  |  |  |  |  | 9 | 8 | 6 | 5 | 3 | 2 |  |  | ${ }^{2}$ |  | 0 |
| 48 |  | H H | H | H, H | H | H | H | H |  | H | H | H | H | H | H ${ }^{\text {H }}$ | H | H H | H | H |  | - | - | - | - | -- | - | - | - | - |  | - |
| 49 | - | L L | L | $\mathrm{L}_{2}$ | L | 2 | 2 | 1 |  | L | 4 | L | L | 1 | L | L | Lᄂ | 2 | 2 |  | - | - | - | - | -1- | - | - | - | - |  |  |

Test Array Deleted

## Signetics

## Application Specific Products

- Series 24


## DESCRIPTION

The PLS173 is a two-level logic element consisting of 42 AND gates and 10 OR gates with fusible link connections for programming $1 / O$ polarity and direction.
All AND gates are linked to 12 inputs (1) and 10 bidirectional I/O lines (B). These yield variable I/O gate configurations via 10 direction control gates (D), ranging from 22 inputs to 10 outputs.
On chip T/C buffers couple either True ( $1, B$ ) or Complement ( $\overline{(1,}, \bar{B}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. Their output polarity, in turn, is individually programmable through a set of EX-OR gates for implementing AND/OR or AND/NOR logic functions.
The PLS173 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.
Order codes for this device are contained in the pages following.

## PLS173

# Field-Programmable Logic Array ( $22 \times 42 \times 10$ ) 

Signetics Programmable Logic Product Specification

## FEATURES

- Field-Programmable (Ni-Cr links)
- 12 inputs
- 42 AND gates
- 10 OR gates
- 10 bidirectional I/O lines
- Active-High or -Low outputs
- 42 product terms:
- 32 logic terms
- 10 control terms
- I/O propagation delay: 30ns (max.)
- Input loading: $-100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 750mW (typ.)
- Tri-state outputs
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing


## FUNCTIONAL DIAGRAM



AFO:B3:S

Field-Programmable Logic Array ( $22 \times 42 \times 10$ )

FPLA LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS173N |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS173A |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Miaximum ambieni | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| Vout | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{i i} \\ & V_{i H} \\ & V_{I C} \end{aligned}$ | Low High Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=\operatorname{Max} \\ V_{C C}=M i n, I_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \\ \hline \end{gathered}$ | V |
| Output voltage |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Low }^{3,5} \\ & \text { High }^{3,6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOL}_{\mathrm{OL}}=15 \mathrm{~mA} \\ & \mathrm{l}_{\mathrm{OH}}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current ${ }^{11}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{ILL}^{\prime} \\ & I_{\mathrm{IH}} \\ & \hline \end{aligned}$ | Low High | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state $^{\text {to }}$ <br> Short circuit ${ }^{4,6,7}$ | $\begin{gathered} V_{\text {CC }}=M a x \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 |  | $\begin{gathered} 80 \\ -140 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| ICC | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 150 | 170 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & { }^{\mathrm{I} N} \\ & \mathrm{C}_{\mathrm{B}} \\ & \hline \end{aligned}$ | Input I/O | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & V_{I N}=2.0 \mathrm{~V} \\ & V_{B}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \\ \hline \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $\mathrm{t}_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 20 | 30 | ns |
| toe | Output enable | Output- | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pf}$ |  | 20 | 30 | ns |
| tod | Output disable ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 20 | 30 | ns |

NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only.

Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I L}$ applied to $I_{11}$. Pins $1-5=0 \mathrm{~V}$, Pins $6-10=4.5 \mathrm{~V}$, Pin $11=0 \mathrm{~V}$ and Pin $13=10 \mathrm{~V}$.
6. Same conditions as Note 5 except Pin $11=+10 \mathrm{~V}$.
7. Duration of short circuit should not exceed 1 second.
8. $I_{C C}$ is measured with $I_{0}$ and $I_{1}=0 V$ and $I_{2}-I_{11}$ and $B_{0}-B_{9}=4.5 \mathrm{~V}$. Part in Virgin State.
9. Measured at $V_{T}=V_{O L}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.
11. $I_{I L}$ and $I_{I H}$ limits are for dedicated inputs only $\left(I_{0}-I_{11}\right)$.

## TEST LOAD CIRCUIT



## TIMING DEFINITIONS

$t_{P D}$
Propagation delay between input and output.
toD Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toe

Delay between input change and when output reflects specified output level.

## TIMING DIAGRAM



VOLTAGE WAVEFORM


MEASUREMENTS:
All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified.

Input Pulses

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this table, the logic state of variables I, $P$, and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

## OUTPUT POLARITY - (B)


"AND' ARRAY - (I, B)


## OR ARRAY - (B)



## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $P_{n}, D_{n}$.
2. Any gate $P_{n}, D_{n}$ will be unconditionally inhibited if both the true and complement of any input ( $(, B)$ are left intact.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at " H ' polarity.
2. All $P_{n}$ terms are disabled.
3. All $P_{\mathrm{n}}$ terms are active on all outputs.

## CAUTION: PLS173 TEST

 COLUMNSThe PLS173 incorporates two columns not shown in the logic block diagram. These columns are used for in-house testing of the device in the unprogrammed state. These columns must be disabled prior to using the PLS173 in your application. If you are using a Signetics-approved programmer, the disabling is accomplished during the device programming sequence. If these columns are not disabled, abnormal operation is possible.

## FPLA PROGRAM TABLE



Field-Programmable Logic Sequencer ( $20 \times 45 \times 12$ )

Signetics Programmable Logic<br>Product Specification

## Application Specific Products

 - Series 24
## DESCRIPTION

The PLS179 is a Tri-state output, registered logic element combining AND/OR gate arrays with clocked J-K flip-flops. These J-K flip-flops are dynamically convertible to D-type via a "foldback" inverting buffer and control gate $\mathrm{F}_{\mathrm{C}}$. It features 8 registered I/O outputs ( $F$ ) in conjunction with 4 bidirectional I/O lines (B). There are 8 dedicated inputs. These yield variable I/O gate and register configurations via control gates ( $\mathrm{D}, \mathrm{L}$ ) ranging from 20 inputs to 12 outputs.
The AND/OR arrays consist of 32 logic AND gates, 13 control AND gates, and 21 OR gates with fusible link connections for programming 1/O polarity and direction. All AND gates are linked to 8 inputs ( 1 ), bidirectional $1 / O$ lines ( $B$ ), internal ilip-flop outputs ( $Q$ ), and Complement Array output ( $\overline{\mathrm{C}})$. The Complement Array consists of a NOR gate optionally linked to all AND gates for generating and propagating complementary AND terms.

## FEATURES

- Field-Programmable (Ni-Cr link)
- 8 dedicated inputs
* 13 control gates
- 32 AND gates
- 21 OR gates
- 45 product terms:
- 32 logic terms
- 13 control terms
- 4 bidirectional I/O lines
- 8 bidirectional registers
- J/K, T, or D-type flip-flops
- Asynchronous Preset/Reset
- Complement Array
- Active-High or -Low outputs
- Programmable $\overline{O E}$ control
- Positive edge-triggered clock
- Power-on reset on flip-flop ( $F_{n}={ }^{i} 1^{i j}$ )
- Clock frequency: PLS179: 18MHz (max.)
- Input loading: PLS179: - $100 \mu \mathrm{~A}$ (max.)
- Power dissipation: 750mW (typ.)
- TTL compatible
- Tri-state option

FUNCTIONAL DIAGRAM


PIN CONFIGURATIONS


## APPLICATIONS

- Random sequential logic
- Synchronous up/down counters
- Shift registers
- Bidirectional data buffers
- Timing function generators
- System controllers/synchronizers
- Priority encoder/registers

On-chip T/C buffers couple either True (I, B, Q) or Complement ( $\bar{I}, \bar{B}, \bar{Q}, \bar{C}$ ) input polarities to all AND gates, whose outputs can be optionally linked to all OR gates. One group of AND gates drives bidirectional 1/O lines (B), whose output polarity is individually programmable through a set of EX-OR gates for implementing AND-OR or AND-NOR logic functions. Another group drives the $\mathrm{J}-\mathrm{K}$ inputs of all flip-flops, as well as asynchronous Preset and Reset lines (P, R).
All flip-flops are positive edge-triggered and can be used as input, output or I/O (for interfacing with a bidirectional data bus) in conjunction with load control gates (L), steering inputs (I), (B), (Q) and programmable output select lines (E).

The PLS179 is field programmable, enabling the user to quickly generate custom patterns using standard programming equipment.

Order codes are contained on the pages following.

## LOGIC FUNCTION


$\operatorname{SET} Q_{0}: J_{0}=\left(Q_{3} \cdot \overline{O_{2}} \cdot Q_{1} \cdot \overline{O_{0}}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots$
$K_{0}=0$
RESET $Q_{1}: \begin{aligned} & J_{1}=0 \\ & K_{1}=\left(O_{3} \cdot \overline{Q_{2}} \cdot Q_{1} \cdot \overline{Q_{0}}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots\end{aligned}$
HOLD $Q_{2}: \begin{aligned} & J_{2}=0 \\ & K_{2}=0\end{aligned}$
togale $O_{3}: J_{3}=\left(O_{3} \cdot \overline{Q_{2}} \cdot Q_{1} \cdot \overline{Q_{0}}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots$

$$
K_{3}=\left(Q_{3} \cdot \overline{O_{2}} \cdot Q_{1} \cdot \overline{O_{0}}\right) \cdot \bar{A} \cdot \tilde{B} \cdot C \ldots
$$

TB00901S

## NOTES:

Similar logic functions are applicable for D and T mode flip-flops.

## FLIP-FLOP TRUTH TABLE

| $\overline{O E}$ | L | CK | P | R | J | K | Q | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H |  |  |  |  |  |  |  | H/Hi-Z |
| L | X | X | X | X | X | X | L | H |
| $L$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | H L | L | X | X | H L | $\begin{aligned} & L \\ & H \end{aligned}$ |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | L | $\begin{aligned} & \uparrow \\ & \uparrow \\ & \uparrow \\ & \uparrow \end{aligned}$ | L L L L | L L L L | L L H $H$ | L H L H | Q <br>  <br>  <br>  | $\begin{aligned} & \bar{Q} \\ & H \\ & L \\ & Q \end{aligned}$ |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | H H | $\uparrow$ | L | L | L | H L | L | $\begin{aligned} & \mathrm{H}^{*} \\ & \mathrm{~L}^{*} \end{aligned}$ |
| +10V | X X | $\uparrow$ | X | X | L H | H L | L | $\begin{aligned} & \mathrm{H}^{* *} \\ & \mathrm{~L}^{* *} \end{aligned}$ |

NOTES:

1. Positive Logic:
$\mathrm{J} / \mathrm{K}=\mathrm{T}_{0}+\mathrm{T}_{1}+\mathrm{T}_{2}+\ldots+\mathrm{T}_{31}$
$T_{n}=\bar{C} \cdot\left(l_{0} \quad \cdot I_{1} \cdot I_{2} \ldots\right) \cdot\left(Q_{0} \cdot Q_{1} \ldots\right) \cdot\left(B_{0} \cdot B_{1} \ldots\right)$
2. $\uparrow$ denotes transition from Low to High level.
3. $X=$ Don't Care
4.     * $=$ Forced at $F_{n}$ pin for loading $\mathrm{J} / \mathrm{K}$ flip-flop in $1 / \mathrm{O}$ mode. $L$ must be enabled, and other active $T_{n}$ disabled via steering input(s) I, B, or Q .
5. At $P=R=H, Q=H$. The final state of $Q$ depends on which is released first.
6. ${ }^{* *}=$ Forced at $F_{n}$ pin to load J/K flip-flop independent of program code (Diagnostic mode), Tri-state B outputs.

## VIRGIN STATE

The factory shipped virgin device contains all fusible links intact, such that:

1. $\overline{\mathrm{OE}}$ is always enabled.
2. Preset and Reset are always disabled.
3. All transition terms are disabled.
4. All flip-flops are in D-mode unless otherwise programmed to $\mathrm{J} / \mathrm{K}$ only or $\mathrm{J} / \mathrm{K}$ or D (controlled).
5. All B pins are inputs and all $F$ pins are outputs unless otherwise programmed.

Field-Programmable Logic Sequencer ( $20 \times 45 \times 12$ )

FPLS LOGIC DIAGRAM


## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLS179N |
| 28-pin Plastic Leaded <br> Chip Carrier | PLS179A |

ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $V_{\text {IN }}$ | Input voltage |  | $+5.5$ | $V_{D C}$ |
| Vout | Output voltage |  | $+5.5$ | $V_{D C}$ |
| I IN | Input currents | -30 | +30 | mA |
| Iout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voitage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{I H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High <br> Low <br> Clamp | $\begin{gathered} V_{C C}=M a x \\ V_{C C}=M \operatorname{Min} \\ V_{C C}=M \operatorname{Min}, \mathrm{l}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{OH}}$ <br> Vol | High Low | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{gathered}$ | 2.4 | 0.35 | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{IH}} \\ & \mathrm{I}_{\mathrm{LL}} \end{aligned}$ | High Low | $\begin{gathered} V_{C C}=M a x, V_{I N}=5.5 \mathrm{~V} \\ V_{I N}=0.45 \mathrm{~V} \end{gathered}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 40 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(OFF) los | Hi-Z state ${ }^{5,8}$ <br> Short circuit ${ }^{4,6}$ | $\begin{gathered} V_{\text {CC }}=\text { Max, } V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ V_{\text {out }}=0 \mathrm{~V} \end{gathered}$ | - -15 | 1 | $\begin{gathered} 80 \\ -140 \\ -70 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| Icc | $V_{C C}$ supply current ${ }^{7}$ | $V_{C C}=M a x$ |  | 150 | 210 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }}=2.0 \mathrm{~V} \end{gathered}$ |  | $\begin{gathered} \hline 8 \\ 15 \end{gathered}$ |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I H}$ applied to $\overline{\mathrm{OE}}$.
6. Duration of short circuit should not exceed 1 second.
7. $\mathrm{I}_{\mathrm{CC}}$ is measured with the $\overline{\mathrm{OE}}$ input grounded, all other inputs at 4.5 V , and the outputs open.
8. Leakage values are a combination of input and output leakage.

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ | Leakage values are a combination of input and outst leakage.

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | LImits |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min ${ }^{5}$ | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  | $C_{L}=30 \mathrm{pF}$ |  |  |  |  |
| $t_{\text {CKH }}$ <br> ${ }^{\text {t. }}$ CLL <br> $t_{\text {CKP }}$ <br> tprh | Clock $^{2}$ high <br> Clock low <br> Period <br> Preset/Reset pulse | $\begin{aligned} & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & (1, B)+ \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK - } \\ & \text { CK + } \\ & (1, B)- \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 20 \\ & 55 \\ & 35 \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \\ & 45 \\ & 30 \end{aligned}$ |  | ns |
| Setup time |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{t}_{1 S 1} \\ & \mathrm{t}_{1 / 2} \\ & \mathrm{t}_{1 S 3} \end{aligned}$ | Input <br> Input (through $\mathrm{F}_{\mathrm{n}}$ ) <br> Input (through <br> Complement Array) ${ }^{4}$ | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \end{aligned}$ | $\begin{gathered} (1, B) \pm \\ \mathrm{F} \pm \\ (1, B) \pm \end{gathered}$ |  | $\begin{aligned} & 35 \\ & 15 \\ & 55 \end{aligned}$ | $\begin{aligned} & 30 \\ & 10 \\ & 45 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |  |
| $\begin{aligned} & t_{\mid H 1} \\ & t_{1 / H 2} \end{aligned}$ | input <br> Input (through $\mathrm{F}_{\mathrm{n}}$ ) | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{CK}+ \end{aligned}$ | $\begin{gathered} (\mid, B) \pm \\ F \pm \end{gathered}$ |  | 0 15 | $\begin{array}{r}-5 \\ 10 \\ \hline\end{array}$ |  | ns |
| Propagation delay |  |  |  |  |  |  |  |  |
| $t_{\text {CKO }}$ <br> toen <br> toD1 <br> ${ }^{t}{ }_{P D}$ <br> toe 2 <br> $\mathrm{t}_{\mathrm{OD} 2}$ <br> tpro <br> tppR | Clock <br> Output enable <br> Output disable ${ }^{3}$ <br> Output <br> Output enable <br> Output disable ${ }^{3}$ <br> Preset/Reset <br> Power-on preset | $\begin{aligned} & \mathrm{F} \pm \\ & \mathrm{F}- \\ & \mathrm{F}+ \\ & \mathrm{B} \pm \\ & \mathrm{B} \pm \\ & \mathrm{B}+ \\ & \mathrm{F} \pm \\ & \mathrm{F}- \end{aligned}$ | CK $\pm$ <br> $\overline{\mathrm{OE}}$ - <br> $\overline{\mathrm{OE}}+$ <br> $(1, B) \pm$ <br> $(1, B)+$ <br> ( $1, B$ ) - <br> $(1, B)+$ <br> $V_{C C}+$ | $C_{L}=5 \mathrm{pF}$ $C_{L}=30 \mathrm{pF}$ $C_{L}=5 \mathrm{pF}$ $C_{L}=30 \mathrm{pF}$ |  | $\begin{aligned} & 15 \\ & 20 \\ & 20 \\ & 25 \\ & 20 \\ & 20 \\ & 35 \\ & 0 \end{aligned}$ | $\begin{aligned} & 20 \\ & 30 \\ & 30 \\ & 35 \\ & 30 \\ & 30 \\ & 45 \\ & 10 \end{aligned}$ | ns |

## NOTES:

1. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 10 \mathrm{~ns}$.
3. Measured at $\mathrm{V}_{\mathrm{T}}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
4. When using the Complement Array $\mathrm{T}_{\mathrm{CKP}}=75 \mathrm{~ns}$ (min).
5. Limits are guaranteed with 12 product terms maximum connected to each sum term line.

## TEST LOAD CIRCUIT




VOLTAGE WAVEFORM


TIMING DIAGRAMS


## TIMING DEFINITIONS

$t_{\text {CKH }}$
${ }^{\text {t CKL }}$
$\mathrm{t}_{\mathrm{CKP}}$
tPRH
Width of input clock pulse. Interval between clock pulses. Clock period.
Width of preset input pulse. of clock. of clock.
$\mathrm{t}_{\mathrm{H} 1}$ Required delay between positive input data. pins. valid (with $\overline{O E}$ Low). come valid.
toD1 Delay between beginning of Output in the off state.
$t_{\text {PPR }}$ Delay between $V_{C C}$ (after poweroutputs at " 0 '). national inputs and outputs. tional Outputs become valid.

Required delay between beginning of valid input and positive transition

Required delay between beginning of valid input forced at flip-flop output pins, and positive transition transition of clock and end of valid

Required delay between positive transition of clock and end of valid input data forced at flip-flop output

Delay between positive transition of clock and when Outputs become

Delay between beginning of Output Enable Low and when Outputs beEnable High and when Outputs are on) and when flip-flop outputs become preset at " 1 " (internal $Q$

Propagation delay between combi-
Delay between predefined Output Enable High, and when combina-

Delay between predefined Output Enable Low and when combinational Outputs are in the off state. Delay between positive transition of predefined Preset/Reset input, and when flip-flop outputs become valid.

## TIMING DIAGRAMS (Continued)



The FPLS can be programmed by means of Logic Programming equipment.

With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these Tables, the logic state or action of all I/O, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:
'AND' ARRAY - (I), (B), (Qp)
(T,
'COMPLEMENT" ARRAY - (C)

"OR" ARRAY - ( $\mathrm{Q}_{\mathrm{N}}=\mathrm{D}-$ Type $)$

"AND" ARRAY - ( $Q_{N}=\mathrm{J}-\mathrm{K}$ Type $)$

'OR' ARRAY - (S or B),(P),(R)

"EX-OR" ARRAY - (B)

"OE " ARRAY - (E)

LSO2250s


| ACTION | CODE |
| :---: | :---: |
| DISABLE | - |

## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate ( $\left.T, F_{C}, L, \bar{F}, \bar{R}, \bar{D}\right)_{n}$ wiii be unconditionaily inhibited if any one of the $i, B$, or $Q$ ink pairs is iefitiact.
3. To prevent oscillations, this state is not allowed for $C$ link, pairs coupled to active gates $T_{n}, F_{C}$.
4. $E_{n}=O$ and $E_{n}=\cdot$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates (L, P, R, D) $)_{n}$ due to their lack of "OR" array links.


## Signetics

## Application Specific Products

- Series 24


## DESCRIPTION

The PLHS473 is a two level logic device consisting of 24 AND gates and 22 OR gates with fusible link connections for programming I/O polarity and direction. The Signetics state of the art OxideIsolated Bipolar process is used to produce performance not yet achieved in devices of this complexity.

All AND gates are linked to 11 input pins, 9 bidirectional I/O pins, and 2 dedicated output pins. The bidirectional pins are controlled via the OR array. Using these features, the PLHS473 can be configured with up to 20 inputs and as many as 11 outputs.
The AND array input buffers provide both the True and Complement of the inputs ( I X ) and the bidirectional signals ( $\mathrm{B}_{\mathrm{X}}$ ) as programmable connections to the AND gates. All 24 AND gates can then be optionally linked to all 22 OR gates (a feature known as Product Term sharing not found in PALs ${ }^{1}$ or most macroceli architectures). The OR array drives 11 output buffers which can be programmed as Active-High for AND-OR functions or Active-Low for AND-NOR functions. In addition, the I/O configuration of each bidirectional pin is individually controlled by a sum-of-products (AND-OR) function which may also con-

# PLHS473 <br> Field-Programmable Logic <br> Array ( $20 \times 24 \times 11$ ) 

Signetics Programmable Logic Preliminary Specification

FUNCTIONAL DIAGRAM

tain any of the 24 AND gate outputs. This allows dynamic I/O configuration of all 9 bidirectional pins.
The PLHS473 contains two new features of significance. A code verification lock has been incorporated to improve user security. The addition of three test columns and one test row enables the user to test the device in an unprogrammed state.
The PLHS473 is field programmable using Vertical Ávalanche Migration Programmed (VAMP ${ }^{T M}$ ) fuses to program the cells. This enables the generation of custom logic patterns using standard programming equipment.
Order codes for this device are contained in the pages following.

## FEATURES

- Fie!d-Programmable
- 11 dedicated inputs
- 2 dedicated outputs
- 9 bidirectional I/O lines
- 24 product terms
- 22 OR gates
- I/O direction decoded in OR array
- Output Enable decoded in OR array

PIN CONFIGURATIONS

$N=$ Plastic
A Package

cDos300s
A = Plastic Leaded Chip Carrier

- I/O propagation delay: 20ns (max.)
- Input loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Power dissipation: 700mW (typ.)
- Security fuse
- Testable in unprogrammed state
- Programmable as Tri-state or Open-Collector outputs
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing

[^12]Field-Programmable Logic Array ( $20 \times 24 \times 11$ )

FPLA LOGIC DIAGRAM


## NOTES:

1. All unprogrammed or virgin "AND" gate locations are pulled to logic " 1 ".
2. All unprogrammed or virgin "OR" gate locations are pulled to logic " 0 ".
3. WWrakemmente cinnemant

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Plastic DIP <br> 300mil-wide | PLHS473N |
| 28-pin Plastic Leaded <br> Chip Carrier | PLHS473A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | $+7$ | $V_{D C}$ |
| $V_{\text {IN }}$ | Input voltage |  | $+5.5$ | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| Iout | Output currents |  | $+100$ | mA |
| $\begin{aligned} & T_{A} \\ & T_{S T G} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant V_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | Low <br> High Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=\operatorname{Min} \\ V_{C C}=\text { Max } \\ V_{C C}=\text { Min, } I_{N}=-12 m A \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \\ \hline \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | $\begin{aligned} & \text { Low }^{5} \\ & \text { High }^{6} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOL}_{\mathrm{OL}}=15 \mathrm{~mA} \\ & \mathrm{IOH}=-2 \mathrm{~mA} \end{aligned}$ | 2.4 |  | 0.5 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{IL}} \\ & \mathrm{I}_{\mathrm{H}} \\ & \hline \end{aligned}$ | Low High | $\begin{aligned} & V_{C C}=\mathrm{Max} \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} -100 \\ 40 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| loroff) los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{10}$ <br> Short circuit ${ }^{4,6,7}$ | $\begin{aligned} V_{\text {CC }} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & 0 \mathrm{~V} \end{aligned}$ | -15 |  | $\begin{gathered} 40 \\ -100 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| loc | $V_{C C}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 140 | 155 | mA |
| Capacitance |  |  |  |  |  |  |
| $\begin{aligned} & { }^{\mathrm{IN}_{1}} \\ & \mathrm{C}_{\mathrm{B}} \end{aligned}$ | Input I/O | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & V_{I N}=2.0 \mathrm{~V} \\ & V_{B}=2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}, \mathrm{R}_{1}=470 \Omega, \mathrm{R}_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | то | FROM | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | Typ | Max |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 15 | 20 | ns |
| toe | Output enable | Output- | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 15 | 20 | ns |
| tod | Output disable ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 15 | 20 | ns |

NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with Pins $1-5=0 \mathrm{~V}$, Pins $6,8=4.5 \mathrm{~V}$, and Pins $7,9-11=10 \mathrm{~V}$.
6. Same conditions as Note 5 except Pin $9=4.5 \mathrm{~V}$.
7. Duration of short circuit should not exceed 1 second.
8. ICC is measured with all inputs and bidirectional pins at 4.5V. Part in Virgin State.
9. Measured at $\mathrm{V}_{\mathrm{T}}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.
10. Leakage values are a combination of input and output leakage.

## TEST LOAD CIRCUIT



## TIMING DEFINITIONS

tpD
Propagation delay between input and output.
toD Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toE Delay between input change and when output reflects specified output level.

TIMING DIAGRAM


## VOLTAGE WAVEFORM



## MEASUREMENTS:

All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified.

Input Pulses

## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.

With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.

In this table, the logic state of variables I, P , and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

## OUTPUT POLARITY - ( $\mathbf{O}, \mathrm{B}$ )


"AND' ARRAY - (I, B)


## OR ARRAY - ( $0, ~ B)$

|  |  |  |  |
| :---: | :---: | :---: | :---: |
| $P_{n}$ STATUS | COOE | $P_{n}$ STATUS | CODE |
| InACTIVE ${ }^{1}$ | $\bullet$ | Active | A |
|  | TCuresus |  | TCOLS |

## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $P_{n}$ will be unconditionally inhibited if the true and complement of either input (I or $B$ ) are both programmed for a connection.

## VIRGIN STATE

A factory shipped virgin device contains ali fusible links intact, such that:

1. All outputs at ' L " polarity.
2. All $P_{n}$ terms are enabled. (Don't Cares).
3. All $P_{n}$ terms are inactive on all outputs.


## Signetics

## Application Specific Products - Series 24

## DESCRIPTION

The PLC473 is a two-level logic CMOS Erasable Programmable Logic Device (EPLD) consisting of 24 AND gates and 22 OR gates with EPROM cell connections for programming I/O polarity and direction. The Signetics state-of-the-art Floating Gate CMOS process is used to produce performance not yet achieved in devices of this complexity.

All AND gate inputs are linked to 11 dedicated input pins $\left(I_{0}-I_{10}\right)$ and 9 bidirectional I/O pins ( $B_{0}-B_{8}$ ). These bidirectional pins are controlled via the OR array. Employing the 2 dedicated outputs ( $\mathrm{O}_{\mathrm{A}}-\mathrm{O}_{\mathrm{B}}$ ) and the programmable I/ O direction feature, the PLC473 can be configured with up to 20 inputs - and as many as 11 outputs.

The ANDD array input buffers provide both the True and Complement of the inputs ( $\mathrm{I}_{\mathrm{x}}$ ) and the bidirectional signals ( $\mathrm{B}_{\mathrm{X}}$ ) as programmable connections to the AND gates. All 24 AND gates can then be optionally linked to all 22 OR gates (a feature known as Product Term sharing not found in PALs ${ }^{1}$ or most

## PLC473 <br> Erasable-Programmable Logic Array $(20 \times 24 \times 11)$

Signetics Programmable Logic<br>Preliminary Specification

macrocell architectures). The OR array drives 11 output buffers which can be programmed as Active-High for AND-OR functions or Active-Low for AND-NOR functions. In addition, the I/O configuration of each bidirectional pin is individually controlled by a sum-of-products (AND-OR) function which may also contain any of the 24 AND gate outputs. This allows dynamic I/O configuration of all 9 bidirectional pins.

The PLC473 contains two new features of significance. Additional testing capability includes stress test mode, whereby all cells can be stressed to ensure reliability. In another test mode, the threshold voltage of each cell can be individually checked to ensure charge retention.
The PLC473 is field programmable using Floating Gate Ultraviolet Erasable Cells. This enables the generation of custom logic patterns using standarr',rogramming equipment.

## FUNCTIONAL DIAGRAM



PIN CONFIGURATION


## FEATURES

- Electrically Programmable; UV erasable
- 11 dedicated inputs
- 2 dedicated outputs
- 9 bidirectional I/O lines
- 24 product terms
- I/O direction decoded in OR array
- i/O propagation deiay: 35ns (max.)
- Input loading: $-10 \mu \mathrm{~A}$ (max.)
- Power dissipation at 10 MHz CMOS: 210mW
TTL: 270mW
- Threshold voltage test mode for individual cells
- Stress test mode for individual cells
- Output: Tri-state condition decoded in OR array
- TTL compatible


## APPLICATIONS

- Random logic
- Code converters
- Fault detectors
- Function generators
- Address mapping
- Multiplexing


## FPLA LOGIC DIAGRAM



1002630s

[^13]Erasable-Programmable Logic Array ( $20 \times 24 \times 11$ )

ORDERING CODE

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 24-pin Ceramic DIP <br> with Window <br> 300mil-wide | PLC473-35FA |
|  |  |
|  |  |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\text {cc }}$ | Supply voitage |  | + 7 | $V_{D C}$ |
| $V_{\text {IN }}$ | Input voltage |  | $\mathrm{V}_{C C}+0.5$ | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | $\mathrm{V}_{C C}+0.5$ | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{IN}}$ | Input currents | -30 | +30 | mA |
| Hout | Output cuirents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

## LOGIC FUNCTION



AT OUTPUT POLARITY $=\mathbf{L}$
$Z=\overline{P 0}+\bar{P} 1+\bar{P} 2+\ldots$
NOTES:
. For each of the 11 outputs, either function $Z$ (Active-High) or $\overline{\mathrm{Z}}$ (Active-Low) is avaitable, but not bor. The desired output polarity is programmed
$\rightarrow$ A $B$ -
fixed inp bidirectional pins (B).

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS |  | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{1} \end{aligned}$ | Low <br> High | $\begin{aligned} & V_{C C}=\operatorname{Min} \\ & V_{C C}=M a x \end{aligned}$ |  | $\begin{gathered} \hline-0.3 \\ 2.0 \end{gathered}$ |  | $\begin{gathered} 0.8 \\ v_{C C}+0.3 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ $\mathrm{V}_{\mathrm{OH}}$ | Low High |  |  | 2.4 |  | 0.45 | V |
| Input current |  |  |  |  |  |  |  |
| $\begin{aligned} & !_{\mathrm{iL}} \\ & !_{\mathrm{H}} \end{aligned}$ | $\begin{aligned} & \text { Low } \\ & \text { High } \end{aligned}$ |  |  |  |  | $\begin{gathered} -10 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |  |
| lo(OFF) <br> los | $\mathrm{Hi}-\mathrm{Z}$ state $^{8}$ <br> Short circuit ${ }^{4,7}$ | $\begin{aligned} & V_{\text {OUT }}=V_{\text {CC }} \\ & V_{\text {OUT }}=G N D \\ & V_{\text {OUT }}=G N D \end{aligned}$ |  | -15 |  | $\begin{array}{r} 10 \\ -10 \\ -70 \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mathrm{~mA} \end{aligned}$ |
| Icc | $\mathrm{V}_{\mathrm{CC}}$ supply current (Active) ${ }^{5,6}$ | No load$f=1 \mathrm{MHz}$ | CMOS inputs |  |  | 40 | mA |
|  |  |  | TTL inputs |  |  | 50 | mA |
| Capacitance |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{N}} \\ & \mathrm{C}_{\mathrm{B}} \\ & \hline \end{aligned}$ | Input I/O |  |  |  | $\begin{gathered} 6 \\ 12 \end{gathered}$ |  | pF |

AC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant V_{C C} \leqslant 5.25 \mathrm{~V}, R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega$

| SYMBOL | PARAMETER | TO | FROM | TEST CONDITIONS | PLC473-35 |  | PLC473-45 |  | PLC473-60 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $t_{\text {PD }}$ | Propagation delay | Output $\pm$ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 |  | 45 |  | 60 | ns |
| toe | Output enable | Output- | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 |  | 45 |  | 60 | ns |
| tod | Output disable ${ }^{9}$ | Output+ | Input $\pm$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 35 |  | 45 |  | 60 | ns |

[^14]
## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} . \mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. CMOS inputs: $V_{I L}=G N D, V_{H H}=V_{C C}$

TTL inputs: $\mathrm{V}_{\mathrm{IL}}=0.45 \mathrm{~V}, \mathrm{~V}_{\mathbb{I}}=2.4 \mathrm{~V}$
6. Measured with all inputs and outputs switching.
7. Duration of short circuit should not exceed 1 second.
8. Leakage values are a combination of input and output leakage.
9. Measured at $\mathrm{V}_{\mathrm{T}}=\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$.

## TEST LOAD CIRCUIT



TIMING DIAGRAM


## TIMING DEFINITIONS

tPD Propagation delay between input and output.
$t_{O D} \quad$ Delay between input change and when output is off ( $\mathrm{Hi}-\mathrm{Z}$ or High).
toe Delay between input change and when output reflects specified output level.

VOLTAGE WAVEFORM


MEASUREMENTS
All circuit delays are measured at the +1.5 V level of inputs and outputs, unless otherwise specified. Input Pulses

## Erasable-Programmable Logic Array ( $20 \times 24 \times 11$ )

## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table on the following page.
In this table, the logic state of variables I, P,

OUTPUT POLARITY - (O, B)
 and $B$ associated with each Sum Term $S$ is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:
"AND' ARRAY - (I, B)


OR ARRAY - ( $0, B$ )


## NOTES:

1. This is the initial unprogrammed state of all link pairs.
2. Any Product Term $\left(P_{\mathrm{C}}\right)$ will always be False (iogic low) if at least one of its ( $1, B$ ) link pairs is unprogrammed as shown.

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. All outputs at " H ' polarity.
2. All $P_{n}$ terms are disabled.
3. All $P_{n}$ terms are active on all outputs.


Application Specific Products

## INDEX

Section 6-PLD Data Sheets

## Series 28

PLS100/PLS101 Field-Programmable Logic Array $(16 \times 48 \times 8)$.......... 6-3
PLS103
PLS105
PLS105A
PLUS405A

Field-Programmable Gate Array $(16 \times 9 \times 9$ ) ............ 6-10
Field-Programmable Logic Sequencer $(16 \times 48 \times 8) \ldots$ 6-16
Field-Programmable Logic 'Sequencer $(16 \times 48 \times 8) \ldots \quad 6-27$
Field-Programmable Logic Sequencer $(16 \times 64 \times 8) \ldots \quad 6-38$

## Signetics

## Application Specific Products

- Series 28


## DESCRIPTION

The PLS100 (Tri-state) and PLS101 (Open Collector) are bipolar, fuse Programmable Logic Arrays (FPLAs). Each device utilizes the standard AND/OR/ Invert architecture to directly implement custom sum of product logic equations.
Each device consists of 16 dedicated inputs and 8 dedicated outputs. Each output is capable of being actively controlled by any or all of the 48 product terms. The True, Compiement, or Don't Care condition of each of the 16 inputs can be ANDed together to comprise one P-term. All 48 P-terms can be selectively ORed to each output.
The PLS100 and PLS101 are fully TTL compatible, and chip enable control for expansion of input variables and output inhibit. They feature either Open Collector or Tri-state outputs for ease of expansion of product terms and application in bus-organized systems.
Order codes are contained on the pages following.

# PLS100/PLS101 <br> Field-Programmable Logic <br> Array $(16 \times 48 \times 8)$ 

## Signetics Programmable Logic

 Product Specification
## FEATURES

- Field-Programmable (Ni-Cr link)
- Input variables: 16
- Output functions: 8
- Product terms: 48
- I/O propagation delay: 50ns (max.)
- Power dissipation: 600mW (typ.)
- Input loading: $\mathbf{- 1 0 0 \mu} \mathrm{A}$ (max.)
- Chip Enable input
- Output option:
- PLS100: Tri-state
- PLS101: Open-Collector
- Output disable function:
- Tri-state: Hi-Z
- Open-Collector: High


## APPLICATIONS

- CRT display systems
- Code conversion
- Peripheral controllers
- Function generators
- Look-up and decision tables
- Microprogramming
- Address mapping
- Character generators
- Data security encoders
- Fault detectors
- Frequency synthesizers
- 16-bit to 8-bit bus interface
- Random logic replacement

FUNCTIONAL DIAGRAM


Field-Programmable Logic
Array ( $16 \times 48 \times 8$ )

FPLA LOGIC DIAGRAM


## Field-Programmable Logic Array ( $16 \times 48 \times 8$ )

ORDERING INFORMATION

| DESCRIPTION | TRI-STATE | OPEN-COLLECTOR |
| :---: | :---: | :---: |
| 28-pin Plastic DIP 600mil-wide | PLS100N | PLS101N |
| 28-pin Plastic Leaded Chip Carrier | PLS100A | PLS101A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{C C}$ | Supply voltage |  | + 7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input currents | -30 | +30 | mA |
| IOUT | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

The PLS100 device is also processed to military requirements for operation over the military temperature range. For specifications and ordering information consult the Signetics Military Data Book.

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & V_{I H} \\ & V_{I L} \\ & V_{I C} \end{aligned}$ | High Low Clamp ${ }^{3,4}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=\text { Min, } \operatorname{liN}_{\text {IN }}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \\ \hline \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { High (PLS100) } \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}_{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{HH}} \\ & \mathrm{I}_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 25 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> los | Hi-Z state (PLS100) <br> Short circuit (PLS100) ${ }^{4,7}$ | $\begin{gathered} \overline{\mathrm{CE}}=\text { High, } \mathrm{V}_{\mathrm{CC}}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ \overline{\mathrm{CE}}=\text { Low, } V_{\text {OUT }}=O \mathrm{~V} \end{gathered}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| ICC | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{8}$ | $V_{C C}=$ Max |  | 120 | 170 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{gathered} \overline{\mathrm{CE}}=\text { High, } \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ V_{\text {IN }}=2.0 \mathrm{~V} \\ V_{\text {OUT }}=2.0 \mathrm{~V} \end{gathered}$ |  | $\begin{gathered} 8 \\ 17 \end{gathered}$ |  | pF |

[^15]Field-Programmable Logic
Array $(16 \times 48 \times 8)$

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | то | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Propagation delay |  |  |  |  |  |  |  |
| $t_{\text {PD }}$ | Input | Output | Input |  | 35 | 50 | ns |
| $t_{\text {ce }}$ | Chip enable | Output | Chip enable |  | 15 | 30 | ns |
| Disable time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CD}}$ | Chip disable | Output | Chip enable |  | 15 | 30 | ns |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those indicated in the operational and programming specification of the device is not implied.
2. All values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one pin at a time.
5. Measured with $V_{I L}$ applied to $\overline{C E}$ and a logic high stored.
6. Measured with a programmed logic condition for which the output test is at a low logic level. Output sink current is applied through a resistor to VCC-
7. Duration of short circuit should not exceed 1 second.
8. $\mathrm{I}_{\mathrm{CC}}$ is measured with the chip enable input grounded, all other inputs at 4.5 V and the outputs open.

Field-Programmable Logic Array ( $16 \times 48 \times 8$ )

## LOGIC PROGRAMMING

The FPLA can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR/EXOR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table.
In this Table the logic state or action of variabies I, P, and $F$, associated with each Sum Term $\mathrm{S}_{\mathrm{n}}$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:
"AND' ARRAY - (I)

"OR'' ARRAY - (F)

## OUTPUT POLARITY - (F)



| $P_{n}$ STATUS $^{\text {LSO2010S }}$ | CODE |
| :---: | :---: | :---: | :---: | :---: |
| ACTIVE |  |
|  | $\mathbf{A}$ |

## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $P_{n}$.
2. Any gate $P_{n}$ will be unconditionally inhibited if any one of its (I) ink pairs is left intact.

## TEST LOAD CIRCUIT



## TIMING DIAGRAM



## VOLTAGE WAVEFORM



## TIMING DEFINITIONS

tcE Delay between beginning of Chip Enable low (with Input valid) and when Data Output becomes valid.
$t_{C D}$ Delay between when Chip Enable becomes High and Data Output is in off state ( $\mathrm{Hi}-\mathrm{Z}$ or High).
tpD Delay between beginning of valid Input (with Chip Enable Low) and when Data Output becomes valid.

## VIRGIN STATE

The PLS $100 / 101$ virgin devices are factory shipped in an unprogrammed state, with all fuses intact, such that:

1. All $P_{n}$ terms are disabled (inactive).
2. All $P_{n}$ terms are active on all outputs.
3. All outputs are Active-High.

Field-Programmable Logic Array ( $16 \times 48 \times 8$ )

FPLA PROGRAM TABLE


## Signetics

## Application Specific Products - Series 28

## DESCRIPTION

The PLS103 is a bipolar, fuse Programmable Gate Array. The device consists of nine AND/NAND gates which share 16 common inputs. The type of gate is selected by programming the output as Active-High (H) or Active-Low (L). Each of the 16 inputs $I_{0}-I_{15}$ can be programmed to provide the True (H), Complement (L), or Don't Care ( - ) state to each of the nine AND/NAND gates. OR/ NOR logic functions can also be implemented by complementing the inputs and outputs via on-chip inverting buffers.
The device is field programmable, which means that custom patterns are immediately available.
The PLS103 includes chip-enable control for output strobing and inhibit. It features Tri-state outputs for ease of expansion of input variables and application in bus-organized systems.
Order codes are contained on the pages following.

FUNCTIONAL DIAGRAM


[^16]
## PLS103

## FEATURES

- Field-Programmable (Ni-Cr link)
- 16 input variables
- 9 output functions
- Chip Enable input
- I/O propagation delay: 35ns (max.)
- Power dissipation: 600mW (typ.)
- Input loading: $\mathbf{- 1 0 0} \mu \mathrm{A}$ (max.)
- Tri-state outputs
- Output disable function: Hi-Z
- Fully TTL compatible


## APPLICATIONS

- Random logic
- Address decoders
- Code detectors
- Peripheral selectors
- Fault monitors
- Machine state decoders


# Field-Programmable Gate Array $(16 \times 9 \times 9)$ 

Signetics Programmable Logic Product Specification

## PIN CONFIGURATIONS



## LOGIC FUNCTION

```
TYPICAL OUTPUT FUNCTIONS:
    ACTIVE-HIGH
        \(X=A \cdot \bar{B} \cdot C \cdot \ldots\)
    ACTIVE-LOW
        \(X=\bar{A} \cdot \bar{B} \cdot C \cdot \ldots\)
        \(X=\bar{A}+\mathbf{B}+\bar{C}+\ldots\)
```

NOTES:

1. For each of the 9 outputs, either function $X$ (ActiveHigh) or X (Active-Low) is available, but not both. The desired output polarity is programmed via the EX-OR gates.
2. $X, A, B, C$, etc. are user defined connections to fixed inputs (I) and output pins (O).

Field-Programmable Gate

## Array $(16 \times 9 \times 9$ )

FPGA LOGIC DIAGRAM


## Field-Programmable Gate <br> Array ( $16 \times 9 \times 9$ )

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :---: | :---: |
| 28-pin Plastic DIP 600mil-wide | PLS103N |
| 28-pin Plastic Leaded Chip Carrier | PLS103A |

## ABSOLUTE MAXIMUM RATINGS

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $V_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| IN | Input current | -30 | +30 | mA |
| Iout | Output current |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{1}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ <br> $V_{\text {IL }}$ <br> $V_{1 C}$ | High Low Clamp ${ }^{3}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=\text { Min, } \mathbb{I}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2.0 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{1}$ |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{OH}}$ $V_{O L}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{4} \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{OH} & =-2 \mathrm{~mA} \\ \mathrm{OL} & =9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathrm{IH}} \\ & I_{\mathrm{IL}} \end{aligned}$ | High Low | $\begin{aligned} & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \end{array}$ | $\begin{gathered} 25 \\ -100 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| lo(off) <br> .... los | $\mathrm{Hi}-\mathrm{Z}$ state <br> Short circuit ${ }^{3.6}$ | $\begin{gathered} \hline \overline{\mathrm{CE}}=\text { High, } V_{\mathrm{CC}}=\mathrm{Max} \\ V_{\text {OUT }}=5.5 \mathrm{~V} \\ V_{\text {OUT }}=0.45 \mathrm{~V} \\ \overline{\mathrm{CE}}=\text { Low, } V_{\text {OUT }}=0 \mathrm{~V} \end{gathered}$ | -15 | $\begin{gathered} 1 \\ -1 \end{gathered}$ | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| 1 cc | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{7}$ | $V_{C C}=M a x$ |  | 120 | 170 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 15 \end{gathered}$ |  | pF |

[^17]AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TO | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Propagation delay |  |  |  |  |  |  |  |
| $t_{\text {PD }}$ | Input | Output | Input |  | 20 | 35 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | Chip enable | Output | Chip enable |  | 15 | 30 | ns |
| Disable time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CD}}$ | Chip disable | Output | Chip enable |  | 15 | 30 | ns |

## NOTES:

1. All voltage values are with respect to network ground terminal.
2. All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
3. Test one pin at a time.
4. Measure with a programmed logic condition for which the output under test is at a low logic level. Output sink current is supplied through a resistor to $V_{C C}$ 5. Measured with $\mathrm{V}_{\mathrm{IL}}$ applied to $\overline{\mathrm{CE}}$ and a logic high at the output.
5. Duration of short circuit should not exceed 1 second.
6. Icc is measured with the outputs open.
7. Stresses above those listed under "Absolute Maximum Ratings " may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other conditions above those listed in the operational and programming specification of the device is not implied.

## Field-Programmable Gate

## TEST LOAD CIRCUIT



VOLTAGE WAVEFORM


## LOGIC PROGRAMMING

In a virgin device all $\mathrm{Ni}-\mathrm{Cr}$ links are intact.
The FPGA can be programmed by means of Logic programming equipment.

With Logic programming, the AND/EX-OR gate input connections necessary to implement the desired logic function are coded directly from logic equations using the Program Table.

In this table, the logic state of variables I and $F$ associated with each P-term $P_{n}$ is assigned

OUTPUT POLARITY - (F)
 a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:
'AND' ARRAY - (I), (P)


## NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $G_{n}$ will be unconditionally inhibited if both the true and complement fuses of any input (I) are left intact.

## VIRGIN STATE

The PLS103 virgin device is factory shipped in an unprogrammed state, with all fuses intact, such that:

1. All $P_{n}$ terms are disabled (inactive).
2. All $P_{n}$ terms are active on all outputs.
3. All outputs are Active-Low.

## Field-Programmable Gate <br> Array $(16 \times 9 \times 9)$

## FPGA PROGRAM TABLE

| CUSTOMER NAME | THIS POPTION TO BE COMPLETED BY SIGNETICS |
| :---: | :---: |
| PURCHASE ORDER \# | CF ( $X X X X$ ) |
| SIGNETICS DEVICE \# | CUSTOMER SYMBOLIZED PART \# |
| TOTAL NUMBER OF PARTS | Date received |
| PROGRAM TABLE \# | COMMENTS |

$F_{0}(18)$
$F_{1}(17)$
$F_{2}(16)$
$F_{3}(15)$
$F_{4}(13)$
$F_{5}(12)$
$F_{6}(11)$
$F_{7}(10)$
$F_{8}(9)$


## Signetics

## Application Specific Products

 - Series 28
## DESCRIPTION

The PLS105 is a bipolar programmable state machine of the Mealy type. It contains logic AND-OR gate arrays with user programmable connections which control the inputs of on-chip State and Output Registers. These consist respectively of $6 Q_{p}$, and $8 Q_{F}$ edge-triggered, clocked S/R flip-flops, with an Asynchronous Preset option. All flip-flops are unconditionally preset to " 1 " during power turn on.
The AND array combines 16 external inputs $\mathrm{l}_{0-15}$ with six internal inputs $P_{0-5}$, which are fed back from the State Registers to form up to 48 transition terms (AND terms). All transition terms can include True, False, or Don't Care states of the controlling variables, and are merged in the OR array to issue next-state and next-output commands to their respective registers on the Low-toHigh transition of the Clock pulse. Both True and Complement transition terms can be generated by optional use of the internal input variable (C) from the Complement Array. Also, if desired, the Preset input can be converted to Output Enable function, as an additional userprogrammable option.
Order codes are contained on the pages following.

## PLS105

Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

Signetics Programmable Logic<br>Product Specification

## FEATURES

- Field-Programmable ( $\mathrm{Ni}-\mathrm{Cr}$ link)
- 16 input variables
- 8 output functions
- 48 transition terms
- 6-bit State Register
- 8-bit Output Register
- Transition Complement Array
- Positive edge-triggered clocked flip-flops
- Programmable Asynchronous Preset or Output Enable
- Power-on preset to all "1" of internal registers
- $\mathrm{f}_{\mathrm{MAX}}=13.9 \mathrm{MHz}$
- Power dissipation: 600mW (typ.)
- TTL compatible
- Single +5 V supply
- Tri-state outputs


## APPLICATIONS

- Interface protocols
- Sequence detectors
- Peripheral controllers
- Timing generators
- Sequential circuits
- Elevator controllers
- Security locking systems
- Counters
- Shift registers

PIN CONFIGURATIONS


## LOGIC FUNCTION

Typical State Transition:


```
ser }\mp@subsup{Q}{0}{}:\mp@subsup{s}{0}{}=(\overline{\mp@subsup{Q}{2}{}}\cdot\mp@subsup{O}{1}{}\cdot\overline{\mp@subsup{O}{0}{}})\cdot\overline{A}\cdot\overline{B}\cdotC
```

    \(R_{0}=0\)
    RESET $Q_{1}: S_{1}=0$
$: S_{1}=0$
$R_{1}=\left(O_{2} \cdot Q_{1} \cdot \bar{Q}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots$
HOLD $Q_{2}: S_{2}=0$
$R_{2}=0$

## PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-8 \\ 20-27 \end{gathered}$ | $l_{1-15}$ | Logic Inputs: The 15 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 9 | 10 | Logic/Diagnostic Input: A 16th external logic input to the AND array, as above, when exercised with standard TTL levels. When $I_{0}$ is held at +10 V , device outputs $F_{0-5}$ reflect the contents of State Register bits $\mathrm{P}_{0-5}$. The contents of each Output Register remains unaltered. | Active-High/Low |
| $\begin{aligned} & 10-13 \\ & 15-18 \end{aligned}$ | $F_{0-7}$ | Logic/Diagnostic Outputs: Eight device outputs which normally reflect the contents of Output Register bits $Q_{0-7}$, when enabled. When $I_{0}$ is held at $+10 \mathrm{~V}, \mathrm{~F}_{0-5}=\left(\mathrm{P}_{0-5}\right)$, and $F_{6,7}=$ Logic " 1 ". | Active-High |
| 19 | PR/ $\overline{O E}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an Asynchronous Preset to logic "1" of all State and Output Register bits. Preset overrides Clock, and when heid rign, ciocking is inhibited and $F_{0-7}$ are High. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes Low. | Active-High (H) |
|  |  | - Output Enable: Provides an Output Enable function to all output buffers $F_{0-7}$ from the Output Register. | Active-Low (L) |

## TRUTH TABLE 1, 2, 3, 4, 5, 6

| $\mathrm{V}_{\mathrm{cc}}$ | OPTION |  | $i_{0}$ | CK | S | ㅁ | Qpif | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | $\overline{O E}$ |  |  |  |  |  |  |
| $+5 \mathrm{~V}$ | H |  |  | X | X | X | H | H |
|  | L |  | +10V | X | X | X | $Q_{n}$ | $\left(Q_{P}\right)_{n}$ |
|  | L |  | X | X | X | X | $Q_{n}$ | $\left(\mathrm{Q}_{\mathrm{F}}\right)_{n}$ |
|  |  | H | * | X | X | X | $Q_{n}$ | $\mathrm{Hi}-\mathrm{Z}$ |
|  |  | L | $+10 \mathrm{~V}$ | X | X | X | $Q_{n}$ | $\left(Q_{P}\right)_{n}$ |
|  |  | L | X | X | X | X | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | $\uparrow$ | L | L | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | $x$ | , | L | H | L | L |
|  |  | L | X | $\uparrow$ | H | L | H | H |
|  |  | L | X | $\uparrow$ | H | H | IND. | IND. |
| $\uparrow$ | X | X | X | X | X | X | H |  |

## NOTES:

1. Positive Logic:
$S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47}$
$T_{n}=C\left(l_{0} I_{1} I_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{5}\right)$
2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user-programmable option.
3. $\uparrow$ denotes transition from Low to High level.
4. $R=S=$ High is an illegal input condition.
5. ${ }^{*}=H / L /+10 \mathrm{~V}$
6. $X=$ Don't Care $(\leqslant 5.5 \mathrm{~V})$

## VIRGIN STATE

A factory shipped virgin device contains ail fusible links intact, such that:

1. $\mathrm{PR} / \overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0)
3. All S/R flip-flop inputs are disabled (0).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program. This is accomplished automatically when using Signetics qualified programming equipment.

## Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

FPLS LOGIC DIAGRAM


## Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

PLS105

ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 28 -pin Plastic DIP 600mil-wide | PLS105N |
| 28 -pin Plastic Leaded Chip Carrier | PLS105A |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\text {Cc }}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $V_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{N}}$ | Input currents | -30 | +30 | mA |
| 'out | Output currents |  | $+100$ | mA |
| $\begin{aligned} & T_{A} \\ & T_{\text {STG }} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{array}{r} +75 \\ +150 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{LL}} \\ & \mathrm{~V}_{\mathrm{IC}} \end{aligned}$ | High Low Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=\text { Min, } \mathrm{I}_{\mathbb{N}}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}^{\mathrm{OH}} & =-2 \mathrm{~mA} \\ \mathrm{O}_{\mathrm{OL}} & =9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{\mathbb{H}} \\ & I_{L L} \end{aligned}$ $I_{I L}$ | High Low Low (CK input) | $\begin{aligned} V_{\mathbb{I N}} & =5.5 \mathrm{~V} \\ V_{\mathbb{N}} & =0.45 \mathrm{~V} \\ V_{\mathbb{I N}} & =0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \\ \hline \end{array}$ | $\begin{gathered} \hline 25 \\ -100 \\ -250 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| $l_{\text {O(OFF) }}$ <br> los | $\mathrm{Hi}-\mathrm{Z}$ state ${ }^{7}$ <br> Short circuit ${ }^{4,8}$ | $\begin{aligned} V_{\text {CC }} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 -1 | $\begin{gathered} 40 \\ -40 \\ -70 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| $l_{\text {cc }}$ | $V_{\text {CC }}$ supply current ${ }^{9}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |  | 120 | 180 | mA |
| Capacitance ${ }^{7}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\mathrm{IN}} & =2.0 \mathrm{~V} \\ V_{\mathrm{OUT}} & =2.0 \mathrm{~V} \end{aligned}$ |  | 8 10 |  | pF |

[^18]NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{\mathrm{IL}}$ applied to $\overline{\mathrm{OE}}$ and a logic high stored, or with $\mathrm{V}_{\mathrm{IH}}$ applied to PR.
6. Measured with a programmed logic condition for which the output is at a low logic level, and $V_{I L}$ applied to PR/ $\overline{O E}$ Output sink current is supplied through a resistor to $V_{c c}$.
7. Measured with $\mathrm{V}_{\mathrm{IH}}$ applied to $\mathrm{PR} / \overline{\mathrm{OE}}$.
8. Duration of short circuit should not exceed 1 second.

9 . ICC is measured with the PR/ $\overline{\mathrm{OE}}$ input grounded, all other inputs at 4.5 V and the outputs open.
AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{PF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | то | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |
| $t_{\text {CKH }}$ <br> ${ }^{\text {t CKL }}$ $\mathrm{t}_{\mathrm{CKP}} \mathrm{CB}_{\mathrm{B}}$ <br> $\mathrm{t}_{\mathrm{CKP}}{ }^{\mathrm{B}}$ <br> tpRH | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | CK - <br> CK + <br> CK + <br> CK + <br> PR- | $\begin{aligned} & \text { CK + } \\ & \text { CK }- \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{gathered} 25 \\ 25 \\ 80 \\ 120 \\ 25 \end{gathered}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 60 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $t_{I S} A$ <br> ${ }^{t_{1 S}} B$ <br> ${ }_{\mathrm{t}_{1 S}} \mathrm{C}$ <br> ${ }_{\mathrm{t}_{15}} \mathrm{~A}$ <br> $\mathrm{t}_{\mathrm{IS} 2} B$ <br> $\mathrm{t}_{\mathrm{IS} 2} \mathrm{C}$ <br> tvs <br> tPRS | Input <br> Input <br> Input <br> Input (through Complement Array) <br> Input (through Complement Array) <br> input (through Complement Array) <br> Power-on preset <br> Preset | CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK + <br> CK - <br> CK - | Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input $\pm$ <br> Input <br> Input <br> $\mathrm{V}_{\mathrm{CC}}+$ <br> PR- | $\begin{aligned} & 60 \\ & 50 \\ & 42 \\ & 90 \\ & 80 \\ & 72 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{H}}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tско <br> toe <br> toD <br> $t_{p R}$ <br> tpPR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output - <br> Output + <br> Output + <br> Output + | CK + <br> OE- <br> OE + <br> PR + <br> $\mathrm{V}_{\mathrm{CC}}{ }^{+}$ |  | $\begin{gathered} 15 \\ 20 \\ 20 \\ 18 \\ 0 \end{gathered}$ | $\begin{aligned} & 30 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \end{aligned}$ | ns |
| Frequency of operation ${ }^{3}$ |  |  |  |  |  |  |  |
| $\begin{aligned} & f_{\text {MAXC }} \\ & f_{\text {MAX }} \end{aligned}$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} 13.9 \\ 9.8 \end{gathered}$ | MHz |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 30 \mathrm{~ns}$.
3. See ''Speed vs. OR Loading' diagrams.

## TIMING DIAGRAMS



## TIMING DEFINITIONS

${ }^{\text {t}}{ }^{\text {CKH }}$ Width of input clock pulse.
$\mathrm{t}_{\mathrm{CKL}}$. Interval between clock pulses.
tcKP1 Clock period - when not using Complement Array:
$\mathrm{t}_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of Clock.
$\mathrm{t}_{\text {CKP2 }}$ Clock period - when using Complement Array.
$t_{1 S 2} \quad$ Required delay between beginning of valid input and positive transition of Clock, when using optional Complement Array (two passes necessary through the AND Array).
tvs Required delay between $\mathrm{V}_{\mathrm{CC}}$ (after power-on) and negative transition of Clock preceding first reliable clock pulse.
tpRS Required delay between negative transition of Asynchronous Preset and negative transition of Clock preceding first reliable clock pulse. Required delay between positive transition of Clock and end of valid Input data.
$\mathrm{t}_{\mathrm{CK}}$ Delay between positive transition of clock and when outputs become valid (with PR/ $\overline{O E}$ low).
toE Delay between beginning of Output Enable Low and when Outputs become valid.
toD Delay between beginning of Output Enable High and when Outputs are in the off state.
${ }^{\text {tsRE }}$ Delay between input $\mathrm{I}_{0}$ transition to Diagnostic Mode and when the Outputs reflect the contents of the State Register.
tsRD Delay between input $i_{0}$ transition to Logic mode and when the Outputs reflect the contents of the Output Register.
$t_{P R}$ Delay between positive transition of Preset and when Outputs become valid at " 1 ".
tPPR Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 ".
tpRH Width of preset input pulse.
$\mathrm{f}_{\text {MAX }}$ Maximum clock frequency.

TIMING DIAGRAMS (Continued)


## TEST LOAD CIRCUIT



## VOLTAGE WAVEFORM



## MEASUREMENTS:

All circuit dełays are measured at the +1.5 V leve of inputs and outputs, unless otherwise specified. Input Pulses

## SPEED VS. "OR" LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:

$$
\left(1 / f_{\mathrm{MAX}}\right)=\mathrm{t}_{\mathrm{CY}}=\mathrm{t}_{\mathrm{IS}}+\mathrm{t}_{\mathrm{CKO}}
$$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $t_{\text {IS }}$, due to capacitive loading. The effect of this loading can be seen in Figure 1 , showing the variation of $t_{I S 1}$ with the number of terms connected per OR.

The AC electrical characteristics contain three limits for the parameters $\mathrm{t}_{\mathrm{IS} 1}$ and $\mathrm{t}_{\mathrm{IS} 2}$. The first, $\mathrm{I}_{\mathrm{IS} 1 \mathrm{~A}}$ is guaranteed for a device with 48 terms connected to any OR line. $t_{I S 1 B}$ is guaranteed for a device with 32 terms connected to any OR line. And $\mathrm{t}_{\mathrm{ISIC}}$ is guaranteed for a device with 24 terms connected to any OR line.


Figure 1. $\mathrm{t}_{\mathrm{S} 1}$ vs. Terms/OR Connected

The three other entries in the AC tabie, $\hat{t}_{\text {IS2 }}$ $\mathrm{A}, \mathrm{B}$, and C are corresponding 48,32 , and 24 term limits when using the on-chip Complement Array.

The worst case $t_{\text {IS }}$ for a given application can be determined by identifying the OR line with the maximum number of $t_{n}$ connections. This can be done by reterring to
the interconnect pattern in the FPLS logic diagram, typically illustrated in Figure 2, or by counting the maximuim number of "H" or "L" entries in one of the columns of the device Program Table.

This number plotted on the curve in Figure 1 will yield the worst case $t_{i s}$ and, by implication, the maximum clocking frequency for reliable operation.

Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.

In this Table, the logic state or action of control variables $\mathrm{C}, \mathrm{I}, \mathrm{P}, \mathrm{N}$, and F , associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding links, defined as follows:

PRESET/OE OPTION - (P/E)

|  | LS01820 |  |
| :---: | :---: | :---: |
| OPTION ${ }^{\text {P }}$ CODE | OPTION | CODE |
| PRESET $^{1} \mathrm{H}$ | $\overline{O E}$ | L. |

PROGRAMMING THE PLS105:
The PLS105 has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High ( H ). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs $(H)$ as the present state.
"AND' ARRAY - (I), (P)

"OR" ARRAY - (N), (F)

"COMPLEMENT' ARRAY - (C)


NOTES:

1. This is the initial unprogrammed state of all links.
2. Any gate $T_{n}$ will be unconditionally inhibited if both the true and complement fuses of any input ( $1, P$ ) are left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

FPLS PROGRAM TABLE


## NOTES:

The FPIS is shipped with all links initially intact Thus, abackground of " O " for all Termis, and an "H" for the P/E option, exits in the table shown BLANK instead for clarity.
2. Unused Cn Im , and Ps bits are normally programmed Don't Care ( - ).
3. Unused Transition Terms can be left blank for future code modification, or programmed as $(-)$ for maximum speed.
4. Letters in variable fields are used as identifiers by logic type programmed.

## TEST ARRAY

The FPLS may be subjected to $A C$ and DC parametric tests prior to programming via an on-chip test array.

The array consists of test transition terms 48 and 49 , factory programmed as shown below.

Testing is accomplished by clocking the FPLS and applying the proper input sequence to $\mathrm{I}_{0-15}$ as shown in the test circuit timing diagram.


State Diagram


FPLS Under Test

## TEST ARRAY PROGRAM



Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.

Test Circuit Timing Diagram

TEST ARRAY DELETED

| $\begin{aligned} & \mathbf{Y} \\ & \mathbf{E} \\ & \mathbf{R} \\ & \mathbf{M} \end{aligned}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | c | INPUT (Im) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Present state (Ps) |  |  |  |  |  |
|  |  | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  | 5 | 4 | 3 | 2 | 1 | 0 | $\bigcirc$ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 5 | 4 | 3 | 2 | 1 | 0 |
| 48 | - | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H |
| 49 | $\bullet$ | $\llcorner$ | 1 | L | $\downarrow$ | L | L | L | L | $\downarrow$ | L | L | L | 1 | L | L | L | L | L | 1 | L | L | 1 |


| OPTION (P'E) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| next state (Ns) |  |  |  |  |  | OUTPUT (FI) |  |  |  |  |  |  |  |  |
| 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  | 0 |
| - | - | - | - | - | - | - | - | - | - | - | - | - |  | - |
| - | - | - | - | - | - | - | - | - | - | - | - | - |  | - |

## Signetics

## Application Specific Products <br> - Series 28

## DESCRIPTION

The PLS105A is a bipolar programmable state machine of the Mealy type. It contains logic AND-OR gate arrays with user programmabie connections which control the inputs of on-chip State and Output Registers. These consist respectively of $6 Q_{p}$, and $8 Q_{F}$ edge-triggered, clocked S/R flip-flops, with an Asynchronous Preset option. All flip-flops are unconditionally preset to " 1 " during power turn on.
The AND array combines 16 external inputs $I_{0-15}$ with 6 internal inputs $P_{0-5}$, which are fed back from the State Registers to form up to 48 Transition terms (AND terms). All Transition terms can include True, False, or Don't Care states of the controlling variabies, and are merged in the OR array to issue nextstate and next-output commands to their respective registers on the Low-to-High transition of the Clock pulse. Both True and Complement Transition terms can be generated by optional use of the internal input variable (C) from the Complement Array. Also, if desired, the Preset input can be converted to OutputEnable function, as an additional user programmable option.
Order codes are contained on the pages following.

FUNCTIONAL DIAGRAM


## FEATURES

- Field-Programmable (Ni-Cr link)
- 16 input variables
- 8 output functions
- 48 transition terms
- 6-bit State Register
- 8-bit Output Register
- Transition complement array
- Positive edge-triggered clocked flip-flops
- Programmable Asynchronous Preset or Output Enable
- Power-on preset to all " 1 " of internal registers
- $\mathrm{f}_{\text {MAX }}=\mathbf{2 0 M H z}$
- Power dissipation: 600mW (typ.)
- TTL compatible
- Single +5 V supply
- Tri-state outputs


## APPLICATIONS

- Interface protocols
- Sequence detectors
- Peripheral controllers
- Timing generators
- Sequential circuits
- Elevator controllers
- Security locking systems
- Counters
- Shift registers


## PIN CONFIGURATIONS



## LOGIC FUNCTION



## PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active-High |
| $\begin{gathered} 2-8 \\ 20-27 \end{gathered}$ | $I_{1-15}$ | Logic Inputs: The 15 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active-High/Low |
| 9 | 10 | Logic/Diagnostic Input: A 16th external logic input to the AND array, as above, when exercised with standard TTL levels. When $I_{0}$ is held at +10 V , device outputs $F_{0-5}$ reflect the contents of State Register bits $\mathrm{P}_{0-5}$. The contents of each Output Register remains unaltered. | Active-High/Low |
| $\begin{aligned} & 10-13 \\ & 15-18 \end{aligned}$ | $\mathrm{F}_{0-7}$ | Logic/Diagnostic Outputs: Eight device outputs which normally reflect the contents of Output Register bits $Q_{0-7}$, when enabled. When $\mathrm{I}_{0}$ is held at $+10 \mathrm{~V}, \mathrm{~F}_{0-5}=\left(\mathrm{P}_{0-5}\right)$, and $F_{6,7}=$ Logic " 1 ". | Active-High |
| 19 | $\mathrm{PR} / \overline{\mathrm{OE}}$ | Preset or Output Enable Input: A user programmable function: <br> - Preset: Provides an Asynchronous Preset to logic "1" of all State and Output Register bits. Preset overrides Clock, and when held High, clocking is inhibited and $\mathrm{F}_{0-7}$ are High. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after Preset goes Low. | Active-High (H) |
|  |  | - Output Enable: Provides an output enable function to buffers $F_{0-7}$ from the Output Register. | Active-Low (L) |

TRUTH TABLE 1, 2, 3, 4, 5, 6

| $\mathrm{V}_{\mathrm{cc}}$ | OPTION |  | $I_{0}$ | CK | S | R | $Q_{\text {P/F }}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PR | $\overline{O E}$ |  |  |  |  |  |  |
| +5V | H |  | * | x | X | X | H | H |
|  | L |  | $+10 \mathrm{~V}$ | X | X | X | $\mathrm{Q}_{\mathrm{n}}$ | $\left(Q_{p}\right)_{n}$ |
|  | L |  | X | X | X | X | $Q_{n}$ | $\left(\mathrm{Q}_{\mathrm{F}}\right)_{n}$ |
|  |  | H | * | x | X | X | $Q_{n}$ | $\mathrm{Hi}-\mathrm{Z}$ |
|  |  | L | $+10 \mathrm{~V}$ | X | X | X | $Q_{n}$ | $\left(Q_{P}\right)_{n}$ |
|  |  | L | X | X | X | X | $Q_{n}$ | $\left(\mathrm{Q}_{\mathrm{F}}\right)_{n}$ |
|  |  | L | X | $\dagger$ | L | L | $Q_{n}$ | $\left(Q_{F}\right)_{n}$ |
|  |  | L | X | , | L | H | L | L |
|  |  | L | X | , | H | L | H | H |
|  |  | L | X | $\uparrow$ | H | H | IND. | IND. |
| $\uparrow$ | X | X | X | X | X | X | H |  |

## NOTES:

1. Positive Logic:

$$
S / R=T_{0}+T_{1}+T_{2}+\ldots+T_{47}
$$

$$
T_{n}=C\left(l_{0} I_{1} I_{2} \ldots\right)\left(P_{0} P_{1} \ldots P_{5}\right)
$$

2. Either Preset (Active-High) or Output Enable (Active-Low) are available, but not both. The desired function is a user-programmable option.
3. $\uparrow$ denotes transition from Low to High level.
4. $R=S=$ High is an illegal input condition.
5. ${ }^{*}=H / L /+10 V$
6. $X=$ Don't Care $(\leqslant 5.5 \mathrm{~V})$

## VIRGIN STATE

A factory shipped virgin device contains all fusible links intact, such that:

1. $\mathrm{PR} / \overline{\mathrm{OE}}$ option is set to PR. Thus, all outputs will be at " 1 ", as preset by initial power-up procedure.
2. All transition terms are disabled (0).
3. All S/R flip-flop inputs are disabled (0).
4. The device can be clocked via a Test Array pre-programmed with a standard test pattern.
NOTE: The Test Array pattern MUST be deleted before incorporating a user program. This is accomplished automatically when using any of Signetics' qualified programming equipment.

FPLS LOGIC DIAGRAM


## NOTES:

. All AND gate inputs with a blown link float to a logic " 11
2. All OR gate inputs with a blown fuse float to logic " 0 "
3. Frifermmatif connection.

Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 28-pin Plastic DIP 600mil-wide | PLS105AN |
| 28-pin Plastic Leaded Chip Carrier | PLS105AA |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{Cc}}$ | Supply voltage |  | +7 | $V_{D C}$ |
| $\mathrm{V}_{\mathrm{IN}}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{I}_{\mathrm{N}}$ | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & \mathrm{T}_{\mathrm{A}} \\ & \mathrm{~T}_{\mathrm{STG}} \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \end{gathered}$ | $\begin{gathered} +75 \\ +150 \\ \hline \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{HH}} \\ & \mathrm{v}_{\mathrm{IL}} \\ & \mathrm{v}_{\mathrm{C}} \end{aligned}$ | High Low Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=\operatorname{Max} \\ V_{C C}=\operatorname{Min} \\ V_{C C}=\text { Min, } \operatorname{liN}^{N}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{aligned} & \text { High }^{5} \\ & \text { Low }^{6} \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =\mathrm{Min} \\ \mathrm{IOH}^{\circ} & =-2 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & I_{I H} \\ & I_{I L} \\ & I_{L L} \end{aligned}$ | High Low Low (CK input) | $\begin{aligned} V_{I N} & =5.5 \mathrm{~V} \\ V_{I N} & =0.45 \mathrm{~V} \\ V_{I N} & =0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \end{array}$ | $\begin{gathered} 25 \\ -100 \\ -250 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| loroff) <br> los | Hi-Z state $^{7}$ Short circuit ${ }^{4,8}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ V_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 <br> -1 | $\begin{array}{r} 40 \\ -40 \\ -70 \end{array}$ | $\mu \mathrm{A}$ mA |
| Icc | $\mathrm{V}_{C C}$ supply current ${ }^{9}$ | $V_{C C}=$ Max |  | 120 | 180 | mA |
| Capacitance $^{7}$ |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | Input Output | $\begin{aligned} V_{\mathrm{CC}} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 10 \end{gathered}$ |  | pF |

[^19]
## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Measured with $V_{I L}$ applied to $\overline{O E}$ and a logic high stored, or with $V_{I H}$ applied to PR.
6. Measured with a programmed logic condition for which the output is at a low logic level, and $V_{\mathrm{IL}}$ applied to $\mathrm{PR} / \overline{\mathrm{OE}}$ Output sink current is supplied through a resistor to $V_{c c}$.
7. Measured with $V_{I H}$ applied to $P R / \overline{O E}$.
8. Duration of short circuit should not exceed 1 second.
9. ICC is measured with the PR/ $\overline{O E}$ input grounded, all other inputs at 4.5 V and the outputs open.

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{CC}} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETERS | TO | FROM | LImits |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |
| t.к. $t_{\text {CKL }}$ $\mathrm{t}_{\mathrm{CKP} 1} \mathrm{~B}$ ${ }^{\mathrm{t}_{\mathrm{CKP2}}{ }^{\mathrm{B}}}$ $t_{\text {PRH }}$ | Clock ${ }^{2}$ high <br> Clock low <br> Period (without Complement Array) <br> Period (with Complement Array) <br> Preset pulse | $\begin{aligned} & \text { CK - } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR - } \end{aligned}$ | $\begin{aligned} & \text { CK + } \\ & \text { CK }- \\ & \text { CK + } \\ & \text { CK + } \\ & \text { PR + } \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & 50 \\ & 80 \\ & 25 \end{aligned}$ | $\begin{aligned} & 15 \\ & 15 \\ & 40 \\ & 50 \\ & 15 \end{aligned}$ |  | ns |
| Setup time ${ }^{3}$ |  |  |  |  |  |  |  |
| $t_{\text {IS }} A$ <br> ${ }_{t_{I S} \mid} B$ <br> $\mathrm{t}_{\mathrm{IS} 2} \mathrm{~A}$ <br> $\mathrm{t}_{1 \mathrm{iS}} \mathrm{B}$ <br> tvs <br> tpRS | Input <br> Input <br> Input (through Complement Array) Input (through Complement Array) Power-on preset Preset | $\begin{aligned} & \text { CK + } \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}+ \\ & \mathrm{CK}- \\ & \mathrm{CK}- \end{aligned}$ | Input $\pm$ <br> Input $\pm$ <br> input $\pm$ <br> !nput <br> $\mathrm{V}_{\mathrm{CC}}{ }^{+}$ <br> PR- | $\begin{gathered} 40 \\ 30 \\ 70 \\ 60 \\ 0 \\ 0 \end{gathered}$ | $\begin{aligned} & -10 \\ & -10 \end{aligned}$ |  | ns |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{H}}$ | Input | Input $\pm$ | CK + | 5 | -10 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tско <br> toe <br> $t_{0 D}$ <br> tPR <br> tpPR | Clock <br> Output enable <br> Output disable <br> Preset <br> Power-on preset | Output $\pm$ <br> Output - <br> Output + <br> Output + <br> Output + | $\begin{aligned} & \mathrm{CK}+ \\ & \mathrm{OE}- \\ & \mathrm{OE}+ \\ & \mathrm{PR}+ \\ & \mathrm{V}_{\mathrm{CC}}+ \end{aligned}$ |  | $\begin{aligned} & 15 \\ & 20 \\ & 20 \\ & 18 \\ & 0 \end{aligned}$ | $\begin{aligned} & 20 \\ & 30 \\ & 30 \\ & 30 \\ & 10 \end{aligned}$ | ns |
| Frequency of operation |  |  |  |  |  |  |  |
| $f_{\text {MAX }}$ <br> $f_{\text {MAX }}{ }^{B}$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} \hline 20 \\ 12.5 \end{gathered}$ | MHz |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=+25^{\circ} \mathrm{C}$.
2. To prevent spurious clocking, clock rise time $(10 \%-90 \%) \leqslant 30 \mathrm{~ns}$.
3. See "Speed vs. OR Loading" diagramtis.

## TIMING DIAGRAMS





## TIMING DEFINITIONS

$t_{\text {CKH }}$ Width of input clock pulse.
tekl Interval between clock pulses.
$t_{\text {CKP }} \quad$ Clock period - when not using Complement Array.
$t_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of Clock.
tcKP2 Clock period - when using Complement Array.
$t_{\text {IS2 }} \quad$ Required delay between beginning of valid Input and positive transition of Clock, when using optional Complement Array (two passes necessary through the AND Array).
tvs Required delay between VCC (after power-on) and negative transition of Clock preceding first reliable clock pulse.
tpRS Required delay between negative transition of Asynchronous Preset and negative transition of Clock preceding first reliable clock pulse. Required delay between positive transition of Clock and end of valid Input data.
${ }^{\text {t.ко }}$
toe ald (wih PR/OE low).

Delay between beginning of Output Enable High and when Outputs are in the off state.
tSRE Delay between input $I_{0}$ transition to Diagnostic Mode and when the Outputs reflect the contents of the State Register.
tSRD Delay between input $l_{0}$ transition to Logic mode and when the Outputs reflect the contents of the Output Register.
$\mathrm{t}_{\mathrm{PR}} \quad$ Delay between positive transition of Preset and when Outputs become valid at " 1 ".
tPPR Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 ".
tpRH Width of preset input pulse.
$f_{\text {MAX }}$ Maximum clock frequency.

TIMING DIAGRAMS (Continued)


TEST LOAD CIRCUIT


VOLTAGE WAVEFORM


## Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

## SPEED VS. 'OR" LOADING

The maximum frequency at which the FPLS can be clocked while operating in sequential mode is given by:

$$
\left(1 / f_{\text {MAX }}\right)=t_{\mathrm{CY}}=\mathrm{t}_{\mathrm{IS}}+\mathrm{t}_{\mathrm{CKO}}
$$

This frequency depends on the number of transition terms $T_{n}$ used. Having all 48 terms connected in the AND array does not appreciably impact performance; but the number of terms connected to each OR line affects $t_{\mathrm{I}}$, due to capacitive loading. The effect of this loading can be seen in Figure 1, showing the variation of $t_{I S 1}$ with the number of terms connected per OR.

The AC electrical characteristics contain two limits for the parameters $\mathrm{t}_{\mathrm{IS} 1}$ and $\mathrm{t}_{\mathrm{IS} 2}$. The first, $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~A}}$ is guaranteed for a device with 24 terms connected to any OR line. $\mathrm{t}_{\mathrm{IS} 1 \mathrm{~B}}$ is guaranteed for a device with 16 terms connected to any OR line.

The two other entries in the $A C$ table, $t_{\text {IS2 }} A$ and $B$ are corresponding 24 and 16 term limits when using the on-chip Complement array.


Figure 1. $\mathrm{t}_{\mathrm{I} 1}$ vs. Terms/OR Connected

The worst case of $t_{\text {IS }}$ for a given application can be determined by identifying the OR line with the maximum number of $T_{n}$ connections. This can be done by referring to
the interconnect pattern in the FPLS logic diagram, typically illustrated in Figure 2, or by counting the maximum number of " H " or 'L' entries in one of the columns of the device Program Table.

This number plotted on the curve in Figure 1 will yield the worst case $t_{s}$ and, by implication, the maximum clocking frequency for reliable operation.

Note that for maximum speed all UNUSED transition terms should be disconnected from the OR array.


Figure 2. Typical OR Array Interconnect Pattern

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.

With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table of the following page.

In this Table, the logic state or action of control variables $C, I, P, N$, and $F$, associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding links, defined as follows:

PRESET/OE OPTION - (P/E)

PROGRAMMING THE PLS105A:
The PLS105A has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic High (H). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all Highs $(\mathrm{H})$ as the present state.
"AND" ARRAY - (I), (P)


## "OR" ARRAY - (N), (F)


"COMPLEMENT" ARRAY - (C)


## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $T_{n}$.
2. Any gate $T_{n}$ will be unconditionally inhibited if both the true and complement fuses of any input ( $1, P$ ) are left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

Field-Programmable Logic Sequencer ( $16 \times 48 \times 8$ )

## FPLS PROGRAM TABLE

PROGRAM TABLE ENTRIES


LD02251S

[^20]
## TEST ARRAY

The FPLS may be subjected to AC and DC parametric tests prior to programming via an on-chip test array.
The array consists of test transition terms 48 and 49 , factory programmed as shown below.
Testing is accomplished by clocking the FPLS and applying the proper input sequence to $l_{0-15}$ as shown in the test circuit timing diagram.



FPLS Under Test

## TEST ARRAY PROGRAM

| $\begin{aligned} & T \\ & E \\ & R \\ & M \end{aligned}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | c | INPUT (Im) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | PRESENT STATE (Ps) |  |  |  |  |  |
|  |  | 5 | 4 | 3 | 2 | 1 | 0 | $\bigcirc$ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 5 | 4 | 3 | 2 | 1 | 0 |
| 48 | A | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H |
| 49 | $\bullet$ | $L$ | L | L | L | L | L | L | 1 | L | L | L | 1 | L | 1 | L | L | L | L | L | L | L | L |


| OPTION (P/E) |  |  |  |  |  |  |  |  |  |  |  |  | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OR |  |  |  |  |  |  |  |  |  |  |  |  |  |
| NEXT STATE (NS) |  |  |  |  |  | OUTPUT (FI) |  |  |  |  |  |  |  |
| 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| L | L | L | L | L | L | L | L | 2 | L | $L$ | L | L | L |
| H | H | H | H | H | H | H | H | H | H | H | H | H | H |

Test Array Program

Both terms 48 and 49 must be deleted during user programming to avoid interfering with the desired logic function. This is accomplished automatically by any of Signetics' qualified programming equipment.


TEST ARRAY DELETED

| $\begin{aligned} & \mathbf{T} \\ & \mathbf{E} \\ & \mathbf{R} \\ & \mathbf{M} \end{aligned}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | c | INPUT (Im) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | PRESENT STATE (Ps) |  |  |  |  |  |
|  |  | $1$ | $1$ | 1 | $1$ | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  | 5 | 4 | 3 | 2 | 1 | 0 | $\bigcirc$ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 5 | 4 | 3 | 2 | 1 | - |
| 48 | - | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H |
| 49 | - | L | L | L | L | L | L | L | L | L | L | L | L | 1 | L | L | 1 | 1 | L | L | L | L | 1 |



Test Array Deleted

## Signetics

## Application Specific Products - Series 28

## DESCRIPTION

The PLUS405A is a bipolar, programmable state machine of the Mealy type. Both the AND and the OR array are user programmable. All 64 AND gates are connected to the 16 external dedicated inputs $\left(I_{0}-I_{15}\right)$ and to the feedback paths of the 8 on-chip State Registers $\left(Q_{P 0}-Q_{P 7}\right)$. Both true and complement transition terms can be generated via optional use of the two internal Complement Arrays (input variables $\mathrm{C}_{0}, \mathrm{C}_{1}$ ).
All transition terms can include True, False and Don't Care states of the controlling state variables. All AND gates are merged into the programmable OR array to issue the next-state and next-output commands to their respective registers. Because the OR array is programmable, any one or all of the 64 transition terms can be connected to any or all of the State and Output Registers.
All state $\left(Q_{P 0}-Q_{P 7}\right)$ and output $\left(Q_{F 0}-Q_{F 7}\right)$ registers are edge-triggered, clocked J-K flip-flops, with Asynchronous Preset and Reset options. The PLUS405A architecture provides the added flexibility of the J-K toggle function which is indeterminate on S-R flipflops. Each register may be individually programmed such that a specific PresetReset pattern is initialized when the initialization pin is raised to a logic level "1". (Note: Upon power-up, all registers are unconditionally preset to "1"). If desired, the initialization input pin (INIT) can be converted to an Output Enable ( $\overline{O E}$ ) function as an additional user programmable feature.
Availability of two user programmable clocks allows the user to design an independent counter or state machine function that can be used to control the bank of output registers.
Order codes are contained on the pages following.

# PLUS405A <br> Field-Programmable Logic Sequencer ( $16 \times 64 \times 8$ ) 

Signetics Programmable Logic<br>Preliminary Specification

## FEATURES

- Field-Programmable (Ti-W fusible link)
- 16 input variables
- 8 output functions
- 64 transition terms
- 8-bit State Register
- 8-bit Output Register
- 2 Transition complement array term
- Multiple clocks
- Programmable Asynchronous Preset/Reset or Output Enable
- Power-on preset to " 1 " of registers
- $\mathrm{f}_{\text {MAX }}=40 \mathrm{MHz}$
- 950mW power dissipation (typ.)
- TTL compatible
- J-K or S-R flip-flop functions
- Tri-state outputs
- Functional superset of PLS105/ 105A


## APPLICATIONS

- Interface protocols
- Sequence detectors
- Peripheral controllers
- Timing generators
- Sequential circuits
- Elevator controllers
- Security locking systems
- Counters
- Shift registers


## LOGIC FUNCTION


$\operatorname{sEr} Q_{0}: S_{0}=\left(\bar{O}_{2} \cdot Q_{1} \cdot{\overline{O_{0}}}_{0}\right) \cdot \bar{A} \cdot \bar{B} \cdot c \ldots$

$$
R_{0}=0
$$

RESET $Q_{1}: S_{1}=0, \quad\left(\overline{Q_{1}}=Q_{1} \cdot \overline{Q_{0}}\right) \cdot \bar{A} \cdot \bar{B} \cdot C \ldots$
HOLD $Q_{2}: \begin{array}{r}S_{2} \\ R_{2}=0\end{array}$

PIN CONFIGURATIONS


## PIN DESCRIPTION

| PIN NO. | SYMBOL | NAME AND FUNCTION | POLARITY |
| :---: | :---: | :---: | :---: |
| 1 | CK | Clock: The Clock input to the State and Output Registers. A Low-to-High transition on this line is necessary to update the contents of both registers. | Active trigin (H) |
| $\begin{gathered} 2,4-9 \\ 26-27 \\ 21-22 \end{gathered}$ | $\begin{gathered} l_{0}-l_{5}, l_{7} \\ I_{8}-l_{9} \\ l_{13}-l_{14} \end{gathered}$ | Logic Inputs: The 11 external inputs to the AND array used to program jump conditions between machine states, as determined by a given logic sequence. | Active High/Low (H/L) |
| 3 | $\mathrm{I}_{6} / \mathrm{CK}$ | Logic Input/Clock: A user programmable function: <br> - Logic Input: A 12th external logic input to the AND array, as above. | Active High/Low ( $\mathrm{H} / \mathrm{L}$ ) |
|  |  | - Clock: A 2nd clock for the State Registers, as above. The Output Registers continue to be clocked off of Pin 1. if two separate State Machines are designed, setup and hold times must be adhered to in order to synchronize both banks of registers. Note that input buffer $i_{6}$ must be deleted from the AND array (i.e. all fuse locations "Don't Care') when using Pin 3 as a Clock. | Active High (H) |
| 20 | $\mathrm{I}_{15}$ | High Fan-Out Logic Input: A 13th external logic input to the AND array, as above. $I_{15}$ is capable of pulling down all 64 Product Terms by itself. | Active High/Low ( $\mathrm{H} / \mathrm{L}$ ) |
| 23 | $l_{12}$ | Logic/Diagnostic Input: A 14th external logic input to the AND array, as above, when exercising standard TTL levels. When $\mathrm{I}_{12}$ is held at +10 V , device outputs $F_{0}-F_{7}$ reflect the contents of State Register bits $P_{0}-P_{7}$. The contents of each Output Register remains unaltered. | Active High/Low (H/L) |
| 24 | $l_{11}$ | Logic/Diagnostic Input: A 15th external logic input to the AND array, as above, when exercising standard TTL levels. When $\mathrm{I}_{11}$ is held at +10 V , device outputs $\mathrm{F}_{0}-\mathrm{F}_{7}$ become direct inputs for State Register bits $\mathrm{P}_{0}-\mathrm{P}_{7}$; a Low-to-High transition on the appropriate clock line loads the values on pins $F_{0}-F_{7}$ into the State Register bits $\mathrm{P}_{0}-\mathrm{P}_{7}$. The contents of each Output Register remains unaltered. | Active High/Low ( $\mathrm{H} / \mathrm{L}$ ) |
| 25 | $I_{10}$ | Logic/Diagnostic Input: A 16th external logic input to the AND array, as above, when exercising standard TTL levels. When $\mathrm{I}_{10}$ is held at +10 V , device outputs $\mathrm{F}_{0}-\mathrm{F}_{7}$ become direct inputs for Output Register bits $Q_{0}-Q_{7}$; a Low-to-High transition on the appropriate clock line loads the values on pins $F_{0}-F_{7}$ into the Output Register bits $Q_{0}-Q_{7}$. The contents of each State Register remains unaltered. | Active High/Low (H/L) |
| $\begin{aligned} & 10-13 \\ & 15-18 \end{aligned}$ | $\mathrm{F}_{0}-\mathrm{F}_{7}$ | Logic Outputs/Diagnostic Outputs/Diagnostic Inputs: Eight device outputs which normally reflect the contents of Output Register Bits $Q_{0}-Q_{7}$, when enabled. When $I_{12}$ is held at $+10 \mathrm{~V}, F_{0}-F_{7}=\left(P_{0}-P_{7}\right)$. When $I_{11}$ is held at +10 V , $F_{0}-F_{7}$ become inputs to State Register bits $P_{0}-P_{7}$. When $l_{10}$ is held at +10 V , $F_{0}-F_{7}$ become inputs to Output Register bits $Q_{0}-Q_{7}$. | Active High (H) |
| 19 | INIT/OE | Initialization or Output Enable Input: <br> A user programmable function: <br> - Initialization: Provides an asynchronous preset to logic "1" or reset to logic ' 0 " of all State and Output Register bits, determined individually for each register bit through user programming. INIT overrides Clock, and when held HIGH, clocking is inhibited and $\mathrm{F}_{0}-\mathrm{F}_{7}$ are in their initialization state. Normal clocking resumes with the first full clock pulse following a High-to-Low clock transition, after INIT goes low. <br> - Output Enable: Provides an output enable function to buffers $F_{0}-F_{7}$ from the Output Registers. | Active - <br> High <br> (H) <br> Active - <br> Low <br> (L) |

Field-Programmable Logic
Sequencer ( $16 \times 64 \times 8$ )

## TRUTH TABLE 1, 2, 3, 4, 5, 6, 7

| Vcc | OPTION |  | $I_{10}$ | 111 | $\mathrm{I}_{12}$ | CK | J | K | $Q_{p}$ | $\mathbf{Q}_{\mathbf{F}}$ | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | INIT | $\overline{O E}$ |  |  |  |  |  |  |  |  |  |
| $+5 \mathrm{~V}$ | H |  | * | * | * | x | X | X | H/L | H/L | QF |
|  | L |  | $+10 \mathrm{~V}$ | x | $x$ | $\uparrow$ | X | x | $Q_{p}$ | L | $L^{9}$ |
|  | L |  | +10V | X | X | $\uparrow$ | X | X | $Q_{p}$ | H | $\mathrm{H}^{9}$ |
|  | L |  | X | $+10 \mathrm{~V}$ | X | $\uparrow$ | $x$ | x | L | $Q_{F}$ | $L^{9}$ |
|  | L |  | X | $+10 \mathrm{~V}$ | X | $\uparrow$ | X | X | H | $Q_{F}$ | $\mathrm{H}^{9}$ |
|  | L |  | X | X | $+10 \mathrm{~V}$ | X | X | X | $Q_{P}$ | $\mathrm{Q}_{\mathrm{F}}$ | Qp |
|  | L |  | X | X | X | X | X | X | $\mathrm{Q}_{\mathrm{P}}$ | $Q_{F}$ | Q ${ }_{\text {F }}$ |
|  |  | H | X | X | * | $\times$ | X | X | $Q_{p}$ | $\mathrm{Q}_{\mathrm{F}}$ | $\mathrm{Hi}-\mathrm{Z}$ |
|  |  | X | $+10 \mathrm{~V}$ | X | X | $\uparrow$ | X | X | $Q_{p}$ | L | $L^{9}$ |
|  |  | X | $+10 \mathrm{~V}$ | X | X | $\uparrow$ | X | X | Qp | H | $\mathrm{H}^{9}$ |
|  |  | X | x | +10V | $x$ | $\uparrow$ | X | x | L | $\mathrm{Q}_{\mathrm{F}}$ | $L^{9}$ |
|  |  | X | $x$ | $+10 \mathrm{~V}$ | X | $\uparrow$ | X | X | H | $Q_{F}$ | $\mathrm{H}^{9}$ |
|  |  | L | X | X | $+10 \mathrm{~V}$ | X | X | X | $Q_{p}$ | $\mathrm{Q}_{\mathrm{F}}$ | $\mathrm{Q}_{\mathrm{P}}$ |
|  |  | L | X | X | X | X | X | X | $\mathrm{Q}_{\mathrm{p}}$ | $\mathrm{Q}_{\mathrm{F}}$ | $Q_{\text {F }}$ |
|  |  | L | x | X | X | $\uparrow$ | L | L |  | $Q_{F}$ |  |
|  |  | L | X | X | X | $\uparrow$ | L | H | L | L | L |
|  |  | L | X | X | X | $\uparrow$ | H | L | H | H | H |
|  |  | L | X | X | X | $\uparrow$ | H | H | $\overline{Q_{P}}$ | $\overline{Q_{F}}$ | $\overline{Q_{F}}$ |
| $\uparrow$ | X | X | X | X | X | X | X | X | X | X | H |

## NOTES:

1. Positive Logic:
$S / R($ or $\mathrm{J} / \mathrm{K})=\mathrm{T}_{0}+\mathrm{T}_{1}+\mathrm{T}_{2}+\ldots \mathrm{T}_{63}$
$T_{n}=\left(C_{0}, C_{1}\right)\left(I_{0}, I_{1}, I_{2}, \ldots\right)\left(P_{0}, P_{1}, \ldots P_{7}\right)$
2. Either Initialization (Active-High) or Output Enable (Active - Low) are available, but not both. The desired function is a user-programmable option.
3. $\uparrow$ denotes transition from Low-to-High level.
4. ${ }^{*}=H / L /+10 V$
5. $X=$ Don't Care $(\leqslant 5.5 \mathrm{~V})$
6. H/L implies that either a High or a Low can occur, depending upon user programmed selection (each State and Output Register individually programmabie).
7. When using the $F_{n}$ pins as inputs to the State and Output Registers in diagnostic mode, the F buffers are tri-stated and the indicated levels on the output pins are forced by the user.

## VIRGIN STATE

A factory-shipped virgin device contains all fusible links intact, such that:

1. INIT/研 option is set to INIT. In order to use the INIT function, the user must select either the PRESET or the RESET option for each flip-flop. Note that regardless of the user programmed initialization, or even if the INIT function is not used, all registers are preset to " 1 " by the powerup procedure.
2. All transition terms are disabled (0).
3. All $S / R$ (or $J / K$ ) flip-flop inputs are disabled ( 0 ).
4. The device can be clocked via a Test Array preprogrammed with a standard test pattern. NOTE: The Test Array pattern must be deleted before incorporating a user program.

FUNCTIONAL DIAGRAM


Field-Programmable Logic Sequencer ( $16 \times 64 \times 8$ )

FPLS LOGIC DIAGRAM


## DETAILS FOR REGISTERS FOR PLUS405A



Detail B


Detail C

Field-Programmable Logic Sequencer ( $16 \times 64 \times 8$ )

## ORDERING INFORMATION

| DESCRIPTION | ORDER CODE |
| :--- | :---: |
| 28-Pin Plastic DIP 600mil-wide | PLUS405AN |
| 28-Pin Plastic Leaded Chip Carrier | PLUS405AA |

## THERMAL RATINGS

| TEMPERATURE |  |
| :--- | :---: |
| Maximum junction | $150^{\circ} \mathrm{C}$ |
| Maximum ambient | $75^{\circ} \mathrm{C}$ |
| Allowable thermal rise <br> ambient to junction | $75^{\circ} \mathrm{C}$ |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| SYMBOL | PARAMETER | RATING |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | + 7 | $V_{D C}$ |
| $\mathrm{V}_{\text {IN }}$ | Input voltage |  | +5.5 | $V_{D C}$ |
| $\mathrm{V}_{\text {OUT }}$ | Output voltage |  | +5.5 | $V_{D C}$ |
| In | Input currents | -30 | +30 | mA |
| lout | Output currents |  | +100 | mA |
| $\begin{aligned} & T_{A} \\ & T_{\text {STG }} \\ & \hline \end{aligned}$ | Temperature range Operating Storage | $\begin{gathered} 0 \\ -65 \\ \hline \end{gathered}$ | $\begin{gathered} +75 \\ +150 \end{gathered}$ | ${ }^{\circ} \mathrm{C}$ |

DC ELECTRICAL CHARACTERISTICS $0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75 \leqslant \mathrm{~V}_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETER | TEST CONDITIONS | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ ${ }^{2}$ | Max |  |
| Input voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{LL}} \\ & \mathrm{~V}_{\mathrm{C}} \end{aligned}$ | High Low Clamp ${ }^{4}$ | $\begin{gathered} V_{C C}=\text { Max } \\ V_{C C}=\text { Min } \\ V_{C C}=M_{\text {in }}, \operatorname{liN}^{\prime}=-12 \mathrm{~mA} \end{gathered}$ | 2 | -0.8 | $\begin{gathered} 0.8 \\ -1.2 \end{gathered}$ | V |
| Output voltage ${ }^{3}$ |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | High Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} \\ & \mathrm{IOH}^{\mathrm{OH}}=-2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=9.6 \mathrm{~mA} \end{aligned}$ | 2.4 | 0.35 | 0.45 | V |
| Input current |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{IH}} \\ & \mathrm{I}_{\mathrm{LL}} \\ & \mathrm{I}_{\mathrm{L}} \end{aligned}$ | High <br> Low <br> Low (CK input) | $\begin{aligned} & V_{I N}=5.5 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \\ & V_{I N}=0.45 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} <1 \\ -10 \\ -50 \end{array}$ | $\begin{gathered} 25 \\ -100 \\ -250 \end{gathered}$ | $\mu \mathrm{A}$ |
| Output current |  |  |  |  |  |  |
| Io(OFF) <br> los | Hi-Z state Short circuit ${ }^{4,5}$ | $\begin{aligned} V_{\mathrm{CC}} & =\mathrm{Max} \\ V_{\text {OUT }} & =5.5 \mathrm{~V} \\ \mathrm{~V}_{\text {OUT }} & =0.45 \mathrm{~V} \\ V_{\text {OUT }} & =0 \mathrm{~V} \end{aligned}$ | -15 | 1 -1 | $\begin{gathered} 40 \\ -40 \\ -70 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA |
| ${ }^{\text {cc }}$ | $\mathrm{V}_{\text {CC }}$ supply current ${ }^{6}$ | $\mathrm{V}_{C C}=\mathrm{Max}$ |  | 190 | 225 | mA |
| Capacitance |  |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout | input Output | $\begin{aligned} V_{C C} & =5.0 \mathrm{~V} \\ V_{\text {IN }} & =2.0 \mathrm{~V} \\ V_{\text {OUT }} & =2.0 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 8 \\ 10 \end{gathered}$ |  | pF |

## NOTES:

1. Stresses above those listed under "Absolute Maximum Ratings" may cause malfunction or permanent damage to the device. This is a stress rating only. Functional operation at these or any other condition above those indicated in the operational and programming specification of the device is not implied.
2. All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
3. All voltage values are with respect to network ground terminal.
4. Test one at a time.
5. Duration of short circuit should not exceed 1 second.
6. $I_{C C}$ is measured with the $\operatorname{INIT} / \overline{O E}$ input grounded, all other inputs at 4.5 V and the outputs open.

Field-Programmable Logic
Sequencer ( $16 \times 64 \times 8$ )

AC ELECTRICAL CHARACTERISTICS $R_{1}=470 \Omega, R_{2}=1 \mathrm{k} \Omega, C_{L}=30 \mathrm{pF}, 0^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+75^{\circ} \mathrm{C}, 4.75^{\circ} \mathrm{CV} \leqslant V_{C C} \leqslant 5.25 \mathrm{~V}$

| SYMBOL | PARAMETERS | TO | FROM | LIMITS |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ ${ }^{1}$ | Max |  |
| Pulse width |  |  |  |  |  |  |  |
| ${ }_{\text {t }}^{\text {CKH }}$ | Clock high | CK- | CK+ | 10 | 8 |  |  |
| tckL | Clock low | CK+ | CK- | 10 | 8 |  |  |
| $\mathrm{tckP1}_{1}$ | Period (without Complement Array) | CK+ | CK+ | 20 | 15 |  | ns |
| tckP2 | Period (with Complement Array) | CK+ | CK+ | 30 | 25 |  |  |
| ${ }_{\text {tinith }}$ | Initialization pulse | INIT+ | INIT- | 10 | 8 |  |  |
| Setup time ${ }^{\mathbf{2}}$ |  |  |  |  |  |  |  |
| ${ }_{t}{ }_{\text {S }}{ }_{1}$ | Input | CK+ | Input $\pm$ | 15 | 12 |  |  |
| ${ }_{\text {t/S2 }}$ | Input (through Complement Array) | CK+ | Input $\pm$ | 25 | 20 |  |  |
| tvs | Power-on preset | CK- | $\mathrm{V}_{\mathrm{CC}}{ }^{+}$ | 0 | -10 |  | ns |
| tinits | Initialization | CK- | INIT- | 0 | -10 |  |  |
| Hold time |  |  |  |  |  |  |  |
| $\mathrm{t}_{1 \mathrm{H}}$ | Input | Input $\pm$ | CK+ | 0 | -5 |  | ns |
| Propagation delay |  |  |  |  |  |  |  |
| tcko | Clock | Output $\pm$ | CK+ |  | 8 | 10 |  |
| toe | Output enable | Output- | OE- |  | 12 | 15 |  |
| tod | Output disable | Output+ | OE+ |  | 12 | 15 | ns |
| tinit | Initialization | Output+ | INIT+ |  | 15 | 20 |  |
| tPPR | Power-on preset | Output+ | $\mathrm{V}_{\text {CC }}{ }^{+}$ |  | 0 | 10 |  |
| Frequency of operation |  |  |  |  |  |  |  |
| $f_{\text {MAX }}$ $f_{\text {max }}$ | Without Complement Array With Complement Array |  |  |  |  | $\begin{gathered} 40 \\ 28.5 \end{gathered}$ | MHz |

## NOTES:

1. All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$.
2. Product term loading considerations: Connecting more than 8 toggle-mode registers to only one product term by itself may compromise the setup time performance. Product term loading restrictions do not apply if toggle mode functions are not used.

Field-Programmable Logic
Sequencer ( $16 \times 64 \times 8$ )

## PLUS405A

## TIMING DIAGRAMS



## TIMING DEFINITIONS

$\mathrm{t}_{\mathrm{CKH}} \quad$ Width of input clock pulse.
$\mathrm{t}_{\mathrm{CKL}} \quad$ Interval between clock pulses.
tcKP Clock period - when not using Complement Array.
$t_{\text {IS1 }} \quad$ Required delay between beginning of valid input and positive transition of Clock.
$\mathrm{t}_{\mathrm{CKP} 2}$ Clock period - when using Complement Array.
tIS2 Required delay between beginning of valid Input and positive transition of Clock, when using optional Complement Array (two passes necessary through the AND Array).
tvs Required delay between $\mathrm{V}_{\mathrm{CC}}$ (after power-on) and negative transition of Clock preceding first reliable clock pulse.
$\mathrm{t}_{\text {INITs }}$ Required delay between negative transition of Asynchronous Initialization and negative transition of Clock preceding first reliable clock pulse.
$t_{\mathrm{IH}}$
Required delay between positive transition of Clock and end of valid Input data.
$\mathrm{t}_{\mathrm{CKO}}$ Delay between positive transition of Clock and when Outputs become valid (with INIT/OE low).
toE Delay between beginning of Output Enable Low and when Outputs become valid.
tod Delay between beginning of Output Enable High and when Outputs are in the off state.
tSRE Delay between input $\mathrm{l}_{12}$ transition to Diagnostic Mode and when the Outputs reflect the contents of the State Register.
Delay between input $I_{12}$ transition to Logic mode and when the Outputs reflect the contents of the Output Register.
tinit Delay between positive transition of Initialization and when Outputs become valid.
tpPR Delay between $V_{C C}$ (after poweron) and when Outputs become preset at " 1 ".
$\mathrm{t}_{\text {INITH }}$ Width of initialization input pulse. Required delay between positive transition of Clock and end of valid input data when jaming data into State or Output Registers in diagnostic mode.
$t_{\text {RJS }} \quad$ Required delay between inputs $I_{11}$ or $\mathrm{I}_{10}$ transition to State and Output Register Input Jam Diagnostic Modes, respectively, and when the ouput pins become available as inputs.
$t_{\text {RJH }} \quad$ Required delay between positive transition of Clock and end of inputs $\mathrm{I}_{11}$ or $\mathrm{I}_{10}$ transition to State and Output Register Input Jam Diagnostic Modes, respectively.

TIMING DIAGRAMS (Continued)


TEST LOAD CIRCUIT


## VOLTAGE WAVEFORM



MEASUREMENTS:
All circuit delays are measured at the +1.5 V level of inputs and outputs, untess otherwise specified.

## Input Pulses

Field-Programmable Logic
Sequencer ( $16 \times 64 \times 8$ )

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.

With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table of the following page.

In this table, the logic state or action of control variables $\mathrm{C}, \mathrm{I}, \mathrm{P}, \mathrm{N}$, and F , associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

## PRESET/RESET OPTION - (P/R)

"AND" ARRAY - (I), (P)

|  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| STATE $\quad$ CODE | STATE $\quad$ CODE | STATE CODE | STATE | CODE |
| INACTIVE ${ }^{1,2}$ O | I, P $\quad \mathrm{H}$ | $\overline{\mathbf{I}}, \overline{\mathbf{P}}$ $\mathbf{L}$ | DON'T CARE | - |

"OR" ARRAY - J-K FUNCTION - (N), (F)


Field-Programmable Logic
"'COMPLEMENT' ARRAY - (C)


## CLOCK OPTION-(CLK1/CLK2)



## NOTES:

1. This is the initial unprogrammed state of all links. It is normally associated with all unused (inactive) AND gates $T_{n}$
2. Any gate $T_{n}$ will be unconditionally inhibited if any one of its $I$ or $P$ link pairs is left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.
5. These states are not allowed when using PRESET/RESET option.
6. Input buffer $I_{6}$ must be deleted from the AND array (i.e. all fuse locations "Don't Care") when using second clock option.
7. A single product term cannot drive more than 8 registers by itself when used in TOGGLE mode.

Field-Programmable Logic Sequencer ( $16 \times 64 \times 8$ )

## PLUS405A FPLS PROGRAM TABLE



## NOTES:

1. The FPLS is shipped with all links initially intact. Thus, a background of " $O$ " for all Terms, and an " H " for the $\operatorname{IN} / E$ and H for the clock option, exits in the table, shown BLANK instead for clarity.
2. Unused $C_{n} I_{m}$, and $P_{s}$ bits are normally programmed Don't Care ( - ),
3. Unused Transition Terms can be left blank for future code modification, or programmed as ( - ) for maximum speed.

## Section 7

 Military Errata
## Application Specific Products

Effective October 1986, this section has been superseded by the Military Products Data Manual. Information regarding this manual can be obtained from the Military Division in Sacramento, (916) 925-6700.
Electrical specifications herein do not necessarily describe the performance characterization of military processed products.

## Signetics

Application Specific Products

## INDEX

## Section 8 - Development Software

AMAZE - Automatic Map and Zap Equations Design Software

## Application Specific Products

## SOFTWARE SUPPORT FOR USER PROGRAMMABLE LOGIC

Computer Aided Design (CAD) support is becoming necessary to address the time-consuming details required by the more complex programmable logic devices available today. The design effort can include the manipulation of Boolean equations, truth tables, state diagrams, flowcharts etc, to create the binary fuse map required to program such devices.

For many years, design engineers have used programmable read-only memories (PROM's) to replace conventional logic. The architecture of the PROM can be described as a programmable logic device containing a fixed AND array followed by a programmable OR array. The fixed structure of the PROM requires a full assignment of outpuit words to be programmed for every input combination. Therefore, little use can be made of programmable logic software programs for logic minimization or other compiling efforts when using PROM's.
Signetics Programmable Logic Devices are the most advanced approach to solving the inherent limitations of PROM's. Their architecture consists of a programmable AND array, followed by a programmable OR array - with the addition of a programmable invert function for flexible output control.

A Signetics PLD device can implement any set of Boolean expressions, provided that they are first put into the standard sum of products form. The logical AND's are implemented at the first gate level of the programmable logic device and the logical OR's are implemented by the second gate level within the PLD. The only limitations on the expressions are those imposed by the number of inputs, outputs, and internal product terms provided by the particular PLD circuit selected. The efficiency of implementing the set of equations can be increased significantly by applying DeMorgan's theorem, and utilizing the programmable invert function on each output.
If there seems to be too few product terms to handle a relatively large equation set, one of several minimization methods can be pursued.
The probability of reducing such equations to manageable size is enhanced through the flexibility of shared AND terms for each output function, the accessibility of all AND terms to each output, and having a programmable invert function on each output. All of these features can be utilized by applying the manual manipulation of Venn Diagrams or Karnaugh Maps. However, the time and effort to accomplish these tasks as well as document the effort for procure-
ment specification purposes increase the need and desire to have software programs to automatically perform such manipulations.
Many types of software programs are being developed to provide this assistance for operation on a wide range of computer hardware. This list of software is expanding rapidly, consisting of both Signetics generated software and some independent software houses' contributions.
This discussion is intended to outline the Signetics developed software program called AMAZE (Automatic Map And Zap Equation Entry) The AMAZE software program currently consists of five modules, BLAST ('Boolean Logic And State Transfer' entry program), PTP ('PAL To PLD' conversion program), DPI ('Device Programmer Interface' program), PLD SIM ('PLD Simulator' program) and the PTE ('Program Table Editor' program). Other modules will be added when product developments require additional software tools.
It must be noted that the AMAZE program is not by any means the total extent of software available for use in designing with PLD (Programmable Logic Devices). Please contact your local Signetics representative for the latest word on the most currently available software.

## Programmable Logic Development Software

## AMAZE

## Description

Automatic Map And Zap Equation Entry software program. The AMAZE software program consists of the following five modules:

- BLAST ('Boolean Logic And State

Transfer' entry program)

- PTE ('Program Table Editor')
- PTP ('PAL To PLD' conversion program)
- DPI ('Device Programmer Interface' program)
- PLD SIM ('PLD Simulator' program)

Each module performs specific tasks as outlined in the following sections.

## Features

- Multiple modules allowing expansion for future requirements
- Each module designed to be user triendly
- Both HELP and ERROR messages
- Document printout: Header, Pin diagram, Boolean equation and Fuse map
- Interface with most commercial programmers
- SIMULATOR programs provide both test and applications assistance


## Equipment

- The PC version of AMAZE is capable of operating on an IBM-PC with MSDOS operating system and having 512 K bytes of on-board RAM
- The VAX version of AMAZE is capable of operating on a VAX computer with VMS operating system Please contact your Signetics Sales Representative for availability and ordering information.


## Products Supported

AMAZE will support the following products:

- 20-pin PLDs: PLS151

PLS153
PLS153A
PLHS153
PLUS153
PLS155
PLS157
PLS159
PLS159A
PLHS18P8A

- 24-pin PLDs: PLS161

PLS162
PLS163
PLS167
PLS167A
PLS168
PLS168A
PLS173
PLUS173
PLS179
PLHS473
PLC473

- 28-pin PLDs: PLS100

PLS101
PLS103
PLS105
PLS $105 A$
PLC105

## PLUS405A

- 52-pin PLDs: PLHS501

PLHS502

## BLAST

Boolean Logic And State Transfer program is a menu driven software package that supports the engineer in implementing logic designs into Signetics Programmable Logic Devices. It checks design data and automatically compiles a program table from Boolean and State Machine equations. Data from the program table is then used to produce a Standard File which contains the fusing codes in a form acceptable to all the AMAZE modules (i.e. PLD-SIM and DPI).

BLAST reports the logic and syntax errors, and lists the equations in a Sum of Products form, which can help the user to minimize the entered logic equations. It will automatically partition State machine designs into specified devices, and then delete redundant terms during compilation.
BLAST also provides the capability of modifying a current logic set programmed into a device by overlaying new data onto unused fuses.

## BOOLEAN LOGIC AND STATE TRANSFER FEATURES

- Üser íriendiy interactive piniist editor
- Boolean equation or state vector entry
- Schematic entry (with external schematic capture package)**
- On-line error checking, minimization, and design overlay
- Capable of partitioning single designs into multiple PLDs
- Generates standard PLD fusemap files
- Supports all Signetics' PLDs and PLEs
- User definable device files for support of PALs and other PLD devices


## PTE

Program Table Entry is an interactive editor which allows the logic designer to enter data into AMAZE in the form of SIGNETICS APPROVED PROGRAM TABLES. Each Signetics PLD data sheet has the program table format which applies to that device. In addition, PTE can be used to document completed designs and to make changes in logic functions which have been previously defined in the BLAST module.

## PROGRAM TABLE EDITOR <br> FEATURES

- Allows easy creation and editing of new and existing PLD designs
- Truth-tabie representation of PLD fusemap in High/Low format
- On-line editor provides automatic cursor control and prevents syntax errors
- On-line help screen and print facility
- Operates on standard PLD fusemap files


## PTP

PAL ${ }^{\text {TM }}$ To PLD is a conversion program to allow easy transfer of the various PAL 20 and 24 pin circuits to the Signetics PLD 20 and 24 pin series devices.

PTP can automatically upload the PAL ${ }^{\text {TM }}$ pattern from a Commercial programmer, convert the pattern into a PLD pattern, and then download the PLD pattern into the programmer. The PAL ${ }^{T M}$ pattern and it's corresponding PLD pattern are documented, and the PLD pattern can be directed to other AMAZE modules.
PTP can also convert the PAL ${ }^{\text {TM }}$ fuse file in a HEXPLOT format.

## PAL-TO-PLD CONVERSION FEATURES

- Menu-driven fusemap conversion of 20- and 24-pin PALs to pin and functional equivalent Signetics' PLDs
- Automatic assembler removes duplicated $p$-terms providing efficient PLD mapping
- Accepts JEDEC, fuseplot files or direct PAL master input via commercial PLD programmer
- User selectable RS-232 programmable interface parameters
- Provides fusemap conversion documentation
- Generates standard PLD fusemap files compatible with other AMAZE modules


## DPI

Device Programmer Interface is the software module that provides the interface between the Standard File created by the AMAZE modules and a commercial programmer. This
module allows both download (Sending from Host to programmer) and upload (Sending from programmer into the host) operations.
DPI supports both JEDEC and Signetics H \& $L$ formats to convey fusing information to and from several commercial programmers.

## DEVICE PROGRAMMER <br> INTERFACE FEATURES

- Supports standard JEDEC and Signetics High/Low fusemap file formats
- RS-232 interface to commercial PLD programmers
- Screen menus for easy upload and download of fusemaps
- User selectable RS-232 parameters for programmer flexibility
- Test vectors automatically transferred to programmer along with fusemap file
- Operates with standard PLD fusemap files


## PLD SIMULATOR

The PLD Simutator program is a software package that simulates the operation of the logic that has been defined for Signetics PLD products. The input to the program is the Standard File generated by other AMAZE modules. The simulator has the capability of running manually or automatically. In the automatic mode the simulator creates a file of test vectors that can be used to test the programmed devices. In the manual mode the program will allow the operator to assigned an input vector and observe the resultant output.

## PLD FUNCTIONAL SIMULATOR FEATURES

- Functional simulation of designs created from equations, program tables, or existing programmed devices
- Automatic test vector generation from standard or JEDEC PLD fusemap files
- Interactive keyboard entry or batch file input of test vectors
- Detects illegal State Machine transitions and flags affected p-terms
- On-line help screen

[^21]
## Programmable Logic Development Software

## AMAZE HARDWARE <br> REQUIREMENTS

P/N
82SOFT523-SS IBM-PC or IBM-XT or compatible computer 512K Memory
PC-DOS Operating System Version 2.0 or higher. 2 Floppy Disk Drives or 1 Floppy and 1 Hard disk 82SOFT211-SS VAX Series Computer VMS operating systemall revisions.
AMAZE comes fully documented with appropriate magnetic media. Applications support is provided by Signetics Field Application Engineers in most areas. Contact the Sales Office in your area for information on AMAZE and Signetics Programmable Logic Products.

## INDEX

Section 9 - Application Notes

| AN7 | Single Chip Multiprocessor Arbiter | 9-3 |
| :---: | :---: | :---: |
| AN8 | Introduction to Signetics Programmable Logic. | 9-15 |
| AN10 | 4-Bit Binary-To-7 Segment Decoder | 9-27 |
| AN11 | PLD Programmable Retriggerable One-Shot | 9-51 |
| AN12 | Low Cost Programmer for PLD 20-Pin Series.. | 9-55 |
| AN13 | Oscillator With PLS159. | 9-71 |
| AN14 | Latches and Flip-Flops With PLS153 | 9-76 |
| AN15 | PLS159 Primer | 9-89 |
| AN16 | PLS159 as Modulo Counters | 9-100 |
| AN17 | Electronic Combination Lock | 9-107 |
| AN18 | Schmitt Trigger Using PLS153 and PLS159 | 9-110 |
|  | Eiectronic Dice | 9-1才8 |
| AN20 | Single Pin Debouncer Using PLS153/159 | 9-122 |
| AN21 | 9 -Bit Parity Generator/Checker With PLS153/153A.. | 9-125 |
| AN22 | PLS151 Toolkit. | 9-131 |
| AN23 | PLS168/168A Primer | 9-139 |
| AN24 | PLS173 as a 10-Bit Comparator, 74LS460 | 9-152 |
| AN25 | A Simple Entry/Exit Meeting Device (PLS157) | 9-158 |
| AN26 | PLHS18P8A Primer. | 9-164 |
| AN27 | PLHS473 Primer | 9-172 |
| AN28 | High-Speed 12-Bit Tracking A/D Converter |  |
|  | Using PLS179 ........................ | 9-180 |
| AN29 | PLHS501 Programmable Macro Logic Primer | 9-190 |

## Signetics

## Application Specific Products

## INTRODUCTION

In multiprocessor environments there is considerable savings to be made through sharing system resources. If each processor must support its own bus structure, 1/O devices, and bulk storage medium, system cost could be very high. In the configuration shown in Figure 1, all processors share a common communication bus, and a number of system resources.

Since every processor must use the common system bus to communicate with its peripherals, a priority structure that resolves simultaneous processor bus requests into a single bus grant must be integrated into the system. In addition to making request-grant transactions, transient bus contention due to grant switching must be removed by inserting precise guard band times between bus grants.
Signetics' Field Programmabie Logic Sequencer provides a convenient and costeffective means for implementing a synchronous arbiter to perform these tasks within a single chip.

AN7

## Single Chip Multiprocessor Arbiter

Application Note

## ARBITER STRUCTURE

Within a multiprocessor system, two general classes of processors can be recognized: Priority A and Priority b. Priority A processors have the highest request priority and must only compete with other Priority A processors for bus control. The arbiter must issue " A " grants in manner that prevents any high priority "A" processor from locking out another Priority A processor. To enable this, the Priority A rules implemented here use a Last Granted Lowest Priority (LGLP) ring structure. After an " A " processor has completed a busrelated task, its next arbitrated request priority will be lowest in the " $A$ " request group. The previously second highest priority " A " processor will then become highest priority requester. The net effect of the "round robin" exchange is that every Priority A processor will have a turn at being highest priority processor. Priority A processors are typically ones that perform real-time operations or vital system tasks.

Priority b processors are lower in priority than the "A's' and may only be granted system control when no " A " requests are pending. " $b$ " processors usually perform background tasks. Within the Priority b group, further priority ordering exists such that each " $b$ " processor has a fixed priority position.
Plumber ${ }^{1}$, Pearce ${ }^{2}$, and Hojberg ${ }^{3}$ present asynchronous techniques of arbiter implementation. These methods all have hardwired priority rules and imprecise guard band times during grant switching. As pointed out by Hojberg, a synchronous state machine can be configured as a Mealy-type controller to provide not only precise guard band times and programmable priority rules, but also programmable input/output polarity. The state machine in Figure 2 is made from a control PROM array and an edge-triggered latch. The " A " and ' b " requests and the machine's present state are used by the control PROM to determine the next " $A$ " and " b " grants and the next state.


Figure 1. Multiprocessor Structure

a. $A$ and $b$ service requests $\left(R_{N}, r_{N}\right)$ plus the present state determine, through the control PROM, the next state and the next grant outputs ( $\mathrm{G}_{\mathrm{N}}, \mathrm{g}_{\mathrm{N}}$ ).

b. Requests $\mathbf{R}_{0}, \mathbf{R}_{1}, r_{0}$, and $\mathbf{r}_{1}$ are asserted fow in the same clock sample period. The priority rules that determine the order in which the grants are lssued and the shaded guard-band areas are programmed into the control PROM. Note that the A and $b$ request lines and the present state input to the PROM must have a set-up time equal or greater than the latch set-up time plus the PROM access time.

Figure 2. Arblter Constructed From A Mealy-Type State Machine

## SYSTEM OPERATION

Two machine states can be identified by inspection: a wait state and a grant state. The state machine enters a grant state as a response to a system request on either $\mathbf{R}_{\mathrm{N}}$ or ${ }^{\prime}{ }_{N}$. The machine will remain in this state with a single grant line asserted as long as the request remains asserted. Upon releasing the request line, the machine will pass through a single wait state before considering other pending requests. This provides a single state guard band time. The requests received must meet the set-up requirement of the edgetriggered latch after propagating through the control PROM. If these time considerations do not fit within a given multiprocessor structure, an input latch may be added such that the $R_{N}$ and $r_{N}$ lines are clocked through the latch by the system clock, thereby removing asynchronous set-up time considerations. On the basis of a state machine approach, two techniques of implementation are feasible: 1) using an architecturally advanced single IC controller, the FPLS, and, 2) a traditional PROM/LATCH configuration.

## Single Chip Multiprocessor Arbiter


a. FPLS Single Chip System



TB00800:
b. FPLS Standard Program Table

| $\mathbf{C K}$ | $\mathbf{S}$ | $\mathbf{R}$ | $\mathbf{Q}$ |
| :---: | :---: | :---: | :---: |
| $\uparrow$ | 0 | 0 | $\mathbf{Q}$ |
| $\uparrow$ | 0 | 1 | 0 |
| $\uparrow$ | 1 | 0 | 1 |
| $\uparrow$ | 1 | 1 | Undefined |

NOTE:
( $\uparrow$ ) denotes positive clock transition. $S=R=1$ is an illegal input condition.
c. Transition Table of Clocked S/R Flip-Flop

Figure 3

## FPLS ARBITER

## IMPLEMENTATION

A five Priority " A " and three Priority ' b " arbiter will be constructed such that all grant outputs will be asserted low for grants and all request inputs will be asserted low for system requests.

## Brief FPLS Description

The FPLS block diagram shown in Figure 3(a) consists of a control PLA and 14 clocked S/R flip-flops. The control PLA is actually an ANDOR logic array that functions as a Content Addressable PROM. The PLA is organized as 48 words of 28 bits with 16 external input
lines, and six internal inputs fed back from the State Register. The 28 PLA outputs drive the S/R inputs of the six-bit State Register and eight-bit Output Register. Note that the state feedback path is made inside the FPLS.
$I_{N}$ and present state inputs, $P_{S}$, represent $2^{22}$ possible input codes; 48 of these codes may be mapped in the PLA to provide a 14 bit register control word. As shown in Figure 3(b) each input code may be specified by assigning to the variables either Low "L"', High ' H ', or Don't Care "-'" logic states. If any input code falls logically outside the programmed codes, the PLA asserts a Low on all its 28
internal outputs, thereby issuing a "no change" command to the R/S flip-flops.

This is an important architectural feature because it requires that only state or output transition terms be programmed. Looping terms that change neither state nor output need not be programmed in the FPLS, owing to the functional characteristics of $S / R$ flipfiops tabutated in Figure $\mathrm{G}(\mathrm{c})$. An example of this is shown in Figure 4.

The S/R inputs of both state and output registers are specified by using PLA outputs ('AND' functions of request inputs and present state) in the program table of Figure 3(c).

The corresponding next state of each bit will be set to 0 for " L ", 1 for ' H ", and No Change for "-". The FPLS's PR/OE line may be assigned either Asynchronous Preset or Output Enable functions, via a user programmable option.
The entire function is integrated into a single 28-pin package designated as PLS105.

## State Algorithm

Figure 5(a) displays the circular state form and all possible state transitions of the LGLP priority structure. Hex states 3F, 3E, 3D, 3C, and $3 B$ are arbiter wait states $W_{0-4}$. In these states, processor " $A$ " and ' $b$ " requests are monitored. Figure 5(b) illustrates a typical grant to processor $A_{1}$ in hex state 07. As long as $A_{1}$ asserts its request line low, the next state will be $07_{16}$ and the next output will remain with $\mathrm{G}_{1}$ asserted low and all the other grant outputs asserted high. Since no change in state or grant output results from this transition, no PLA resources are required.
As soon as processor $A_{1}$ returns its request line, $R_{1}$, to 1 , a state transition is made to 3 D , and an output transition is made to set all grant outputs to 1 . Since processor $A_{1}$ was the last to be granted system resources, it will now have the lowest $A$ level request priority (LGLP). In wait state $W_{2}$, the highest priority processor will be $A_{2}$, second $A_{3}$, third $A_{4}$, and fourth $A_{0}$. To maintain the LGLP rule, grant transitions must follow the state rule $\mathrm{G}_{\mathrm{N}} \rightarrow \mathrm{W}_{(\mathrm{N}+1)}$, and wait states, $\mathrm{W}_{\mathrm{M}}$, must set their " $A$ " priorities so that processor $A_{M}$ is highest priority. Priority decreases as one proceeds clockwise around the state ring to the lowest priority processor, $A_{(m-1)}$.
When no " $A$ " requests are pending, ' $b$ " requests may be granted. To avoid upsetting the LGLP priority rule, a " $b$ " grant must leave and return to the same wait state. Since the " $b$ " priority structure is the same regardless of the wait state, only a single set of " $b$ " transition terms are required.


NOTE:
$T_{N} / F_{N}=$ inputs/outputs.
The FPLS requires that only two out of the three transition terms be programmed.
Figure 4. FPLS State and Output Transitions

For example, a grant transition to $\mathrm{g}_{2}$ (Hex 20-25) can be issued only if there are no " $A$ ", ' $b_{0}$ ", or " $b_{1}$ " requests pending. Given the binary wait state code 111XXX, where " X 's" represent Don't Cares, a request code of 01111111 will transfer the arbiter to the grant state $\mathrm{g}_{2}$ from any of the wait states, $W_{0-4}$.
It is important to realize that in making this transition, the lower three-state bits will not be changed - they provide the wait state return address. When $r_{2}$ returns high, 1XXXXXXX, a transition back to the previously exited wait state is made by forcing a " 1 " in the three most significant state bits and leaving the lower three-state bits unchanged.
All output and state bits are initially preset to " 1 " through the use of the optional preset function. Grant output lines are only forced low when transitions are made to grant states and are returned to " 1 " when jumping back to a wait state.
Table 1 provides the complete arbiter program. The complete arbiter circuit diagram is shown in Figure 6. The AMAZE equations are shown in Figure 7.

## PROM/LATCH IMPLEMENTATION

The same five " A " processor and three " b " processor arbiter can be implemented with discrete PROM's and Latches using the same state diagrams for the FPLS, except that now looping transition terms must be programmed. Coding of all state and output transitions requires programming of two memory fields: the " A " request PROM's $(2 K X 6)$ and the " $b$ " request PROM $(64 \times 3)$. The complete circuit diagram is shown in Figure 6(b).
The " $A$ " request PROM's determine the next machine state ( $\mathrm{N}_{0-5}$ ) at all times, except when there are no " A " requests pending and there is a " $b$ " request, or if the machine is presently in a " $b$ " grant state. In these cases, the ' $b$ '" request PROM controls the machine's next state.
The grant control lines are decoded from the next state lines and latched in two quad output latches. This PROM/LATCH organization is conceptually the same as that shown in Figure 2.

## Single Chip Multiprocessor Arbiter



Figure 5. Arbiter State Transition Diagram

## Single Chip Multiprocessor Arbiter



Figure 6. Arbiter Circuit Diagram Summary

Table 1. FPLS Program Table for Priority Arbiter


```
#********************* ARBITERS **********************
AREITERB/825105
ESTATE VECTORS
[ FF5, FF4, FF3, FF2, FF1, FFO ]
WO =O3Fh ;
W1 = OBEh;
W2 = 03Dh
W3 = 03Ch
W4 = 0.3Eh
WO4 = 111--b;
GAO = Obh ;
GA1 = 07h ;
GA2 = OEh;
GAB = OFh;
GA4 = 16h;
GBO = 101--b ;
GB1 = 110---b;
GB2 = 100---b ;
@INPUT VECTORS
aOUTPUT VECTORS
[OE2, OB1, OBO, OA4, OA3, OA2, OA1, OAO]
QAO' = FEh ;
QA1' = FDh
QA2' = FBh
QA3' = F7h
QA4' = EFh
QBO' = DFh
QB1' = BFh
QE2'= 7Fh
NOGRANT' = FFh ;
@TRANSITIONS
WHILE [WO]
    CASE
        [/RAO] :: [GAO] WITH [QAO']
        [/RAI * RAO] :: [GA1] WITH [QA1']
        [/RA2 * RA1 * RAO] :: [GA2] WITH [QA2']
        [/RA3 * RA2 * RA1 * RAO] :: [GA3] WITH [QAJ']
        [/RA4 * RA3 * RA2 * RA1 * RAO] :: [GA4] WITH [QA4']
    ENDCASE
WHILE [WI]
    CASE
        [/RA1] :: [GA1] WITH [QA1']
        [/RA2 * RA1] :: [GA2] WITH [QAZ']
        [/RA3 * RA2 * RAI] :: [GA3] WITH [QA3']
        [/RA4 * RA3 * RA2 * RA1] :: [GA4] WITH [QA4`]
        [/RAO * RA4 * RA3 * RA2 * RAI] :: [GAO] WITH [QAO']
    ENDCASE
```


## a. Arbiter State Equations

Figure 7

```
WHILE [W2]
    CASE
        [/RA2] :: [GAZ] WITH [QAZ']
        [/RAS * RAZ] :% [GAS] WITH [QAB']
        [/RA4 * RAS * RA2] :: [GA4] WITH [QA4']
        [/RAO * RA4 * FAS * RA2] : : [GAO] WITH [QAO']
        [/FA1 * RAO * RA4 * RA3 * RAZ] :: [GA1] WITH [QA1']
    ENDCASE
WHILE [W.3]
    CASE
        [/RAZ] :: [GAS] WITH [QAS']
        [/RA4 * RAB] :: [GA4] WITH [QA4`]
        [/RAO * RA4 * RAJ] :: [GAO] WITH [QAO']
        [/RA1 * RAO * RA4 * RA3] :: [GA1] WITH [QA1']
        [/RAZ * RA1 * RAO * FAS4 * RAB] : : [GAZ] WITH [QAZ']
    ENDCASE
WHilLE [W4]
    CASE
        [/FA4] :: [GA4] WITH [QA4']
        [/RAO * RA4] :: [GAO] WITH [QAO']
        [/RA1 * RAO * RA4] :: [GA1] WITH [GA1']
        [/RA2 * RA1 * RAO * RA4] :: [GA2] WITH [QA2']
        [/RAS * FA2 * RA1 *FA1 * RA4] :: [GAS] WITH [QAB']
    ENDCASE
WHILE [WO4]
    CASE
        [/FBO * RA4 * RA3 * RAZ * RA1 * RAO] :: [GBO] WITH [QEO']
        [/RE1 * RBO * RA4 * RA3 * RA2 * RA1 * RAO] : : [GB1] WITH [OB1']
        [/RE2 * RE1 * REO * RA4 * RAS * RA2 * fA1 * FAOG] : : [GE2] WITH [QEZ I
    ENDCASE
WHILE [GAO]
    IF [RAO] THEN [W1] WITH [NOGRANT']
WHILE [GA1]
    IF [RA1] THEN [WZ] WITH [NOGRANT']
WHILE [GA2]
    IF [FAR] THEN [WS] WITH [NOGRANT']
WHILE [GAJ]
    IF [RAS] THEN [W4] WITH [NOGRANT']
WHILE [GA4]
    IF [RA4] THEN [WO] WITH [NOGRANT']
WHILE [GBO]
    IF [REO] THEN [GE1] WITH [NOGGANT']
WHILE [GE1]
    IF [RE1] THEN [GB2] WITH [NOGRANT']
WHILE [GB2]
    IF [RB2] THEN [GBO] WITH [NOGRANT`]
```



Table 2. Arbiter Program Table



$0!\overrightarrow{A!-}$


उ!A!- - - -, - - - , - - - , L H H H!H H, H H H H!L L, H H H H!H.HHH,L H H H!
4!A! - - - , - - - $-\infty-L, H H H H!H$ H,H H H H!L H,L H HL!H H HL,H H H H!





1O!A! - - - - - - . - - - - L - - !H H,H HL H!LL,H H H L!H H H H, HL H H!

12!A! - - - , - - - , - - L, H H - - ! H H,H H L H!L H,L H HL!HHHL,HHHH!
1S!A! - - - , - - - - - - H,HH-L!H H,H HLH!LL,LHHL!HHHH,HHHL:
14!A! - - - - - - - , - - H,HHL H!H H,H HL H!LL,LHHH!HHHH,H HLH:

16!A! - - - , - - - - - - L., H - - - H H,HHLL.L.H,LHHL!HHHL,HHHH!
17!A!- - - - - - - - - H, H- L!H H, H L L. L L, LHHL!HHHH,H H H L







25!A! - - - - - - - - LH,HHHH!HH,H- - - HLH
26!A!- - - -, - - - - L H H,H H H H!H H, H - - - ! H H, L - - - H L H H, H H H H!
27'A!- - - - - - - , L HHH,HHHH!HH,H---!HL,L - - - L H H H,HHHH!
28!A! - - - - - - - - - - - - - H:L , L H HLiHH,HHHL!HHHH,HHHH:
29!A! - - - , - - - , - - - , - H-!LL,LHH H!HH,HHLH!HHHH,HHHH!


उ2!A!- - - , - - - , - - H, - - - ! L H, LHHL!HH,HHHH!HHHH,HHHH!
SI!A! - - - - - - , - - H-, - - - ! L L, H - - - H H, L - - - H H H H, H H H H:

उS!A!- - - - - - - , H - - , - - - !H L, L - - - ! H L, H - - - ! H H H H,HHHH!




$4010: 0 \quad 0 \quad 0 \quad 0,0 \quad 0 \quad 0 \quad 0,0 \quad 0 \quad 0 \quad 0,0 \quad 0 \quad 0 \quad 010 \quad 0,0 \quad 0 \quad 0 \quad 010 \quad 0,0 \quad 0 \quad 0 \quad 010 \quad 0 \quad 0 \quad 0,0 \quad 0 \quad 0 \quad 01$








NNNNNNNNRRRRERRRFFFFFFFFFFFFOOOOOOO O / / / / / / / / / E EAAAAAFFFFFFFFFFFFEBEAAAAA


## Single Chip Multiprocessor Arbiter

## SUMMARY

As can be seen from the circuit diagrams, the FPLS can offer significant advantages over discrete MSI arrays in the design of state machines. The tradeoff in both design alternatives for the Priority Arbiter is shown in Table 2. Clearly, the FPLS approach uses fewer parts, with savings in PC board space and power requirements.

## REFERENCES

1. W.W. Plumber: 'Asynchronous Arbiters'; IEEE Transactions on Computers, January 1972, pp. 37-42.

Table 3. Design Alternatives for the Priority Arbiter

| PARAMETER | F.P.L.S. | PROM/LATCH |
| :--- | :---: | :---: |
| Parts count | 1 IC | $\approx 19 \mathrm{IC's}$ |
| PCB space | $.84 \mathrm{in}^{2}$ | $7.92 \mathrm{in}^{2}$ |
| Power | .65 W | 2.85 W |
| Voltage | +5 V | +5 V |

2. R.C. Pearce, J.A. Field, and W.D. Little: "Asynchronous Arbiter Module'; IEEE Transactions on Computers, September 1975, pp. 931-933.
3. K. Soe Hojberg: "An Asynchronous Arbiter Resolves Resource Allocation Con-
flicts on a Random Priority Basis'; Computer Design, August 1977, pp. 120-123.
4. K. Soe Hojberg: "One-Step Programmable Arbiter for Multiprocessors'; Computer Design, April 1978, pp. 154-158.

## Application Specific Products

Author: K. A. H. Noach

## INTRODUCTION

Custom logic is expensive - too expensive if your production run is short. 'Random logic' is cheaper but occupies more sockets and board space. Signetics Programmable Logic bridges the gap. Using PLD, you can configure an off-the-shelf chip to perform just the logic functions you need. Design and development times are much shorter, and risk much lower than for custom logic. Connections are fewer than for random logic, and, for all but the simplest functions, propagation delay is usualiy shorter. Yet another advantage that PLD has over custom logic is that it allows you to redesign the functions without redesigning the chip-giving you an invaluable margin not only for cut-and-try during system development, but also for later revision of system design. You're not tied down by the need to recover capital invested in a custom chip.

A PLD chip is an array of logic ele-ments-gates, inverters, and flip-flops, for instance. In the virgin state, everything is connected to everything else by nichrome fuses, and although the chip has the capacity to perform an extensive variety of logic functions, it doesn't have the ability to. What gives it that is programming: selectively blowing undesired fuses so that those that remain provide the interconnections necessary for the required functions.
Signetics Series 20 PLD, named for the number of pins, supplements the well-known Series 28. The package is smaller-little more than a third the size, in fact - but the improved architecture, with user-programmabie shared $1 / O$. compensates for the fewer pins. The series comprises the following members, in order of increasing complexity:

## - PLS151-field-programmable gate

 array- PLS153-field-programmable logic array


# Introduction To Signetics Programmable Logic 

## Application Note

## - PLS155 - field-programmable logic sequencer

- PLS157-field-programmable logic sequencer
- PLS159 - field-programmable logic sequencer
Entry to all the devices is via a product matrix, an array of input and shared I/O lines fuseconnected to the multiple inputs of an array of AND gates (see Figures 1, 2 and 5). To exploit the capacity of any device, it is important to make the most economical use of the AND gates it has available. Application of de Morgan's theorem can help in this. For example, inputs for the function

$$
F=A+B+C+D
$$

would occupy four of the AND gates of the product matrix. However, the same function rewritten as

$$
\bar{F}=\bar{A} \bar{B} \bar{C} \bar{D}
$$

would occupy only one. Moreover, the second function could be done on the simplest of the Series 20 devices (and leave eleven gates over for other functions), whereas the first could not. The fact that all inputs of the Series 20 devices, including the shared ones, incorporate double buffers that make the true and complement forms of all input variables equally accessible, greatly facilitates the use of de Morgan's theorem for logic minimization.

To convert the minimized logic equations to the pattern of fuses to be blown, you can use either a programming sheet (see e.g. Table 1) or Boolean equation program-entry software that lets you enter the equations via the keyboard of a terminal. The direct programmability of logic equations makes system design with PLD simple and sure. Functional changes can be made by replacing one PLD chip by another differently programmed. In many cases you can even remove the original one, reprogram it on the spot, and re-insert it. Programming machines qualified for the Se-
ries 20 are at present available from DATA I/ O, KONTRON, and STAG.

## FPGA PLS151

The field-programmable gate array is the simplest of the Series 20 PLD devices; Figure 1 shows the functional diagram. The array can accept up to 18 inputs. There are six dedicated input pins ( $A$ ) and twelve ( $A^{\prime}$ ) that can be programmed as inputs, outputs, or bidirectional I/O. All input variables, whether on dedicated or programmed input pins, are available in both true and complement form in the product matrix (B), and both forms are buffered: either form can drive all 12 product lines if required. In the virgin state, all the input variables and their complements are connected to all the product lines via a diode and a fuse (C), and the product matrix is effectively inoperative. To enabie it to generate the required functions, unrequired connections between individual input lines and product lines are severed by blowing the connecting fuses.
At the output of the product matrix are 12 NAND gates, each with 36 inputs to accommodate the 18 possible input variables and their complements. Each of the product terms is normally active-Low, but a unique feature of Signetics PLD is that any or all of them can be independently programmed active-High. This is done by means of an array of exclusive-OR gates (D) at the NAND-gate outputs; when the fuse that grounds the second input of each OR gate is blown, the output of that gate is inverted.
The product matrix and exclusive OR-gate connections shown in Figure 1 illustrate the flexibility conferred by having buffered complements of all input variables internally available, together with independently programmable output polarities. Output $\mathrm{B}_{11}$, shown with its exclusive OR-gate fuse intact, is programmed

$$
\overline{B_{11}}=I_{0} 1_{1} \overline{I_{5}}
$$



## NOTE:

A, dedicated inputs; $A^{\prime}$, programmable I/O. B, product (NAND) matrix with fused connections $C$; each of the vertical lines in the matrix represents 36 inputs to the lerminating NAND gated. D, exclusive-OR array with inputs grounded via fuses for polarity control. E, programmable Tri-state output buffers. F, fuse-programmable control matrix. Square dots ( $\mathbf{m}$ ) represent permanent connections; round dots ( $\bullet$ ) intact fuse connections. Connected as shown, the array is programmed for the functions $\overline{\mathrm{B}}_{11}=I_{0} I_{1} \bar{\Gamma}_{5}$ and $\mathrm{B}_{10}=\bar{T}_{0} \bar{I}_{1} \bar{I}_{5}$.

Figure 1. Field-Programmable Gate Array PLS151A

## Introduction To Signetics Programmable Logic



NOTE:
$A$ to $F_{1}$ as in Figure 1. G, sum (OR) matrix. Connected as shown, the array is programmed as a single-bit adder with Carry Enable.
Figure 2. Field-Programmable Logic Array PLS153

At the same time, and without using any additional inputs, output $\mathrm{B}_{10}$ (fuse blown) is programmed

$$
B_{10}=T_{0} \Gamma_{1} \Gamma_{5}
$$

Each of the exclusive-OR gates drives a three-state output buffer. In the virgin state all the buffers ( $E$ ) are disabled and therefore in the high-impedance state. The function of the programmable $1 / O$ pins $\left(A^{\prime}\right)$ is then determined by the I/O control matrix (F). The three AND gates at the control-matrix output are

Active-High, and when one of them is in the High state, the four output buffers it controls are enabled; the corresponding I/O pins then act as outputs. conversely, when a controlmatrix AND-gate output is Low and the control fuse for the corresponding Tri-state buffer is intact, the pins controlled by that gate act as inputs. Thus, these pins can be programmed in groups of up to four to act as inputs or outputs according to the state of selected input variables. If required, any of the programmable //O pins can be made a
dedicated output by blowing the control fuse of the output buffer associated with it.

The speed of the FPGA compares favorably with TTL, although its propagation delay is longer than the individual gate delay of TTL. When the number of inputs required is large, however, the FPGA more than makes up for this. When more than eight inputs are required, for example, the FPGA has a distinct advantage. Then, the overall propagation de-

## Introduction To Signetics Programmable Logic

lay of TTL often amounts to two or three gate delays, but that of the FPGA to only one.

## FPLA PLS153

## Architecture

With two levels of logic embodied in a product matrix terminating in 32 AND gates coupled to a ten-output OR matrix (Figure 2), the FPLA is a step up in complexity from the FPGA. Again, there is provision for 18 input variables, internally complemented and buffered, but here divided between eight dedicated input pins and ten individually programmable I/O pins. As before, exclusive-OR gates grounded by fuses provide output polarity control, and any of the programmable I/O pins can be made a dedicated output by blowing the control fuse of the output buffer associated with it.

## Programming

When the required functions have been defined, corresponding programming instructions are entered in a programming table, the layout of which reflects the FPLA architecture. (A Signetics computer program named AMAZE, which accepts Boolean equations as input and generates an FPLA programming table as output, is also available.) The programming machine blows the FPLA fuses in the pattern prescribed by the table.
As an illustration of FPLA programming, consider a full adder. Figure 3 shows a TTL version ( 74 L S 80 ) and the corresponding logic equations. Note that the feedback of $\overline{\mathrm{C}}_{\mathrm{n}+1}$ introduces a second propagation delay. In the FPLA this is eliminated by redefining $\Sigma$ in terms of $A, B$, and $C_{n}$, as shown in Figure 4, and using the right side of the equation for $\overline{\mathrm{C}}_{\mathrm{n}+1}$ instead of the term itself. At first glance this would appear to require a minimum of three product terms for $\overline{\mathrm{C}}_{n+1}$ plus four for $\Sigma$, or a total of seven. The Karnaugh maps, however, show considerable overlap between the two functions: the map for $\overline{\mathrm{C}}_{n+1}$ differs from that for $\Sigma$ only by having A B $C_{n}$ instead of $\bar{A} \bar{B} \overline{C_{n}}$. Rewriting the equation for $\bar{C}_{n+1}$ to introduce $\bar{A} \bar{B} \bar{C}_{n}$ and eliminate $A B C_{n}$,

$$
\bar{C}_{n+1}=A \bar{B} \overline{C_{n}}+\bar{A} B \overline{C_{n}}+\bar{A} \bar{B} C_{n}+\bar{A} \bar{B} \overline{C_{n}}
$$

increases the number of product terms by one, but now $\overline{\mathrm{C}}_{\mathrm{n}+1}$ and $\Sigma$ have three terms in common. Therefore, since the FPLA allows multiple use of product terms, it is sufficient to program each of the common terms only once; thus, the original seven product terms are effectively reduced to five.

To fill in the programming table (Table 1), first allocate inputs and outputs.


Figure 3. Single-Bit Full Adder in TTL (e.g. 74LS80)


Inputs: $A=I_{0}$
Outputs: $\bar{C}_{n+1}=B_{7}$ $B=I_{1}$ $C_{n}=I_{2}$
$\begin{array}{ll}\Sigma & =B_{8} \\ \Sigma & =B_{9}\end{array}$
Next, enter the product terms of $\Sigma$ in the product-matrix (AND) part of the table, using $H$ to indicate a true input and $L$ a false one.

- Term 0 is $A \bar{B} \overline{C_{n}}$ : mark $H, L, L$ in columns $l_{0}, l_{1}, l_{2}$ of row 0
- Term 1 is $\bar{A} B \overline{C_{n}}$ : mark $L, H, L$ in columns $l_{0}, l_{1}, l_{2}$ of row 1
- Term 2 is $\bar{A} \bar{B} C_{n}$ : mark $L, L, H$ in columns $l_{0}, l_{1}, l_{2}$ of row 2
- Term 3 is $A B C_{n}$ : mark $H, H, H$ in columns $I_{0}, I_{1}, I_{2}$ of row 3 .

Fill the rest of rows $0,1,2$, and 3 with dashes to indicate that all other inputs are to be disconnected from Terms $0,1,2$, and 3 (fuses blown).

The product terms of $\Sigma$ must be added to form the sum-of-products required at output

Bg. Indicate the required addition by putting an A (for Attached, i.e. fuse unblown) in the Term $0,1,2$, and 3 spaces of column $B(O)_{9}$; Term 4 is not required for $\Sigma$, so put a dot in the Term 4 space to indicate that it is to be disconnected (fuse blown). To indicate that the output is to be Active-High, put an H in the polarity square above the $\mathrm{B}(\mathrm{O})_{9}$ column. Finally, fill row $D_{9}$ with dashes to indicate that all fuses on line $D_{9}$ of the control matrix are to be blown and $\mathrm{B}_{9}$ is to be a dedicated output. This completes the programming of $\Sigma$.
The $\bar{\Sigma}$ output on $\mathrm{B}_{8}$ is programmed in just the same way, except that the polarity square above the $\mathrm{B}(\mathrm{O})_{8}$ column is marked L to indicate Active-Low. (Note that in the FPLA, the $\Sigma$ and $\bar{\Sigma}$ outputs change simultaneously, because all output signals traverse the exclu-sive-OR array ( D ), whether they are ActiveHigh or Active-Low. In the TTL full adder shown in Figure 3, the output inverter delays the change of $\Sigma$ with respect to $\bar{\Sigma}$.)

## Introduction To Signetics Programmable Logic

Table 1. FPLA Programming Table Filled in for the Full Adder of Figure 2

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ARIT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | H | L] | L |  |  |  |  |  |
|  | T |  |  |  |  |  |  |  | AN |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | OR |  |  |  |
|  | E |  |  |  |  | 1 |  |  |  |  |  |  |  |  | (1) |  |  |  |  |  |  |  |  |  | (0) |  |  |  |
|  | M | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 |  | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 4 | 32 | 1 | 0 |
| 피 | 0 | - | - | - | - | - | L | L | H | - | - | - | - | - | - | - | - | - | - | - | A | A | A |  |  |  |  |  |
|  | 1 | - | - | - | - | - | 1 | H | L | - | - | - | - | - | - |  | - | - | - | - | A | A | A |  |  |  |  |  |
| - ⿹ㅓ으응 | 2 | - | - | - | - | - | H | L | L | - | - | - | - | - | - |  | - | - | - | $\square$ | A | A | A |  |  |  |  |  |
| 主 ${ }^{1}$ | 3. | - | - | - | - | - | H | H | H | - | - | - | - | - | - |  | - | - | - | - | A | A | $\cdot$ |  |  |  |  |  |
|  | 4 | - | - | - | - | - | L | L | L | - | - | - | - | - | - | - | - | - |  | - | - | - | A |  |  |  |  |  |
| ¢ ${ }^{\circ}$ | 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| - ${ }_{0}$ 츤 | 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 돈 이피 | 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ¢- $0_{0}$ | 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| - | 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D9 | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - |  | - |  | - |  |  | + | $\bigcirc$ |  | - | - |  |
|  | D8 | - | - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - | - |  |  |  |  |  |  |  |  |
|  | D7 | - | - | - | - | H | - | - | - | - | - | - | - | - | - |  | - | - | - |  |  |  |  |  |  |  |  |  |
|  | D6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | PIN. <br> NO. | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 19 | 18 | 17 | 16 | 15 | 14 |  | 13 | 12 | 11 | 9 |  |  |  |  |  |  |  |  |
| $11$ |  |  |  |  |  | [E <br>  <br> $A$ <br> $A$ <br> $B$ <br> $L$ | $\mathrm{C}_{n}$ | B | A | $\Sigma$ | $\bar{\Sigma}$ | ${ }_{-}^{+}{ }_{+}^{+}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

The output $\mathrm{C}_{n+1}$ on $\mathrm{B}_{7}$ contains three of the same terms as $\Sigma$, plus the term $\bar{A} \bar{B} \overline{C_{n}}$. Only this last term needs to be additionally programmed in the product matrix: mark $L, L, L$ in columns $l_{0}, l_{1}, I_{2}$ of the Term 4 row. Indicate the addition

$$
A \bar{B} \overline{C_{n}}+\bar{A} B \overline{C_{n}}+\bar{A} \bar{B} C_{n}+\bar{A} \bar{B} \overline{C_{n}}
$$

by putting an $A$ in rows $0,1,2$, and 4 of column $\mathrm{B}(\mathrm{O})_{7}$, and show that Term $3\left(\mathrm{~A} \mathrm{~B}_{\mathrm{n}}\right.$ ) is not required by putting a dot in the Term 3 row to indicate disconnection (fuse blown). Put an L in the $\mathrm{B}(\mathrm{O})_{7}$ polarity square to indicate Active-Low.

Identifying $B_{7}$ as a dedicated output by indicating that all the fuses to control term $D_{7}$ are to be blown, would now complete the programming of the full adder. However, a useful supplementary feature would be a Carry Enable function to keep the $\mathrm{B}_{7}$ output buffer in the high-impedance state except when the enable input $i_{3}$ is true. The output buffer is enabled when both the fuses of a control term are blown, or when one is blown and the term that controls the output buffer is true. Thus, a Carry Enable can be provided via the $t_{3}$ input by leaving intact the fuse for ActiveHigh operation of the enable signal to control term $D_{7}$. To indicate this, put an H in the $\mathrm{I}_{3}$ column of row $\mathrm{D}_{7}$ and fill the rest of the row with dashes.
The full adder with output Carry Enable uses only four of the eight dedicated inputs, three of the ten programmable I/O pins, and five of the 32 AND gates. The remaining capacity can be used for programming other functions which may, if required, also make use of AND-gate outputs already programmed for the full adder.

All fuses not indicated as blown in the programming table are normally left intact to preserve capacity for later program revisions or the addition of supplementary functions. If it is essential to minimize propagation delay, however, the finalized program should include instructions for blowing all unused fuses to minimize load capacitance.

## FPLS PLS155 - PLS157 - PLS159

## Architecture

The FPLS (Figure 5) is the most complex of the Series 20 PLD devices. Like the FPLA, it has a 32 -term product matrix followed by an OR matrix. In the FPLS, however, the OR matrix is larger and comprises three distinct parts, with architecture differing in detail from type to type. In the PLS155, for instance, the first part consists of eight 32-input gates coupled, like those of the FPLA, to an output-polarity-controlling exclusive-OR array. The
second consists of twelve additional gates which control four flip-flops. These are what give the FPLS its sequential character, enabling it to dictate its next state as a function of its present state. The third part is the deceptively simple Complement Array (I in Figure 5): a single OR gate with its output inverted and fed back into the product matrix. This enables a chosen sum-of-products to become a common factor of any or all the product terms and makes it possible to work factored sum-of-products equations. it is also useful for handshaking control when interfacing with a processor and for altering the sequence of a state machine without resorting to a large number of product terms.
PLS155 has four dedicated inputs and eight programmable I/O pins that can be allocated in the same way as in the FPLA. It also has four shared I/O pins (L) whereby the flip-flops can be interfaced with a bidirectional data bus. Two product terms, $L_{A}$ and $L_{B}$ in the control matrix F , control the loading of the flip-flops, in pairs, synchronized with the clock.
Figure 6 shows the architecture of the flip-flop circuitry in the PLS155. The flip-flops are positive-edge-triggered and can be dynamically changed to J-K, T, or D types according to the requirements of the function being performed; this considerably lessens the demands on the logic. The Tri-state inverter between the J and K inputs governs the mode of operation, under the control of the product term $F$ :

- When the inverter is in the highimpedance state, the flip-flop is a J-K type, or a $T$ type when $J=K$.
- When the inverter is active, $\mathrm{K}=\mathrm{J}$ and the flip-flop is a D type; the $K$ input must then be disconnected from the OR matrix.
All the product terms from the product matrix ( $T_{0}$ to $T_{31}$ in Figure 5) are fuse-connected to the $J$ and $K$ input OR gates. if both fuses of any one product term are left intact. $J=K$ and the flip-flop is a $T$ type.
The flip-flops of the PLS155 have asynchronous Preset and Reset controlled by terms in the OR matrix that take priority over the clock. Their three-state output buffers can be controlled from the enable pin OE or permanently enabled or disabled by blowing fuses or leaving them intact in the enable array ( $K$ in Figure 5).
The PLS157 and PLS159 sequencers have, respectively, six and eight flip-flops. The architecture differs in detail but is similar in principle to that of PLS155.


## Programming

The FPLS is programmed in much the same way as the FPLA, using a table to instruct the machine that blows the undesired fuses. It is not necessary to work with a circuit diagram; in fact, it is even undesirable to do so, since applying the necessary logic reduction techniques would in most cases make the diagram difficult to read and more a hindrance than a help. An example of how to program the FPLS as a universal counter/shift-register is given in the Appendix.

## DEVELOPMENT AND PRODUCTION ECONOMY WITH PLD

Underlying the design philosophy of the Signetics Series 20 PLD is the concept of programmable arrays whose architecture emulates logic equation formats rather than mere aggregations of gates. The unique combination of features which support this philosophy includes:

- double-buffered true and complement inputs
- programmable-polarity outputs
- programmable I/O for internal teedback and maximum freedom in allocating inputs and outputs
- truth-table programming format

These features are common to all the PLD devices. In the field-programmable logic sequencers they are further supported by:

- flip-flops with dynamically alterable operating modes
- a complement array for simplified handshaking control
From the development engineer's point of view an important advantage of PLD is that it eliminates breadboarding. Once the functions required in terms of minimized logic equations are worked out, a PLD can be programmed accordingly. Once programmed, it will perform those functions.
Loading the instructions into the programming machine usually takes no more than a couple of hours; after that, the machine can program the devices at a rate of 100 an hour. Moreover, since any PLD can be programmed in many different ways, PLD has considerable potential for simplifying purchasing and stock control. One type of device can be programmed to perform a diversity of tasks for which it would otherwise be necessary to purchase and stock many different devices.

Series 20 PLD is second-sourced by Harris Semiconductor.

## Introduction To Signetics Programmable Logic

AN8



LD01350s
b- denotes wire-OR

- denotes fixed connection

Figure 6. Architecture of the PLS155 Flip-Flop Circuitry

## APPENDIX

## Programming an FPLS as a Counter/Shift-Register

Objective: to program a PLS155 FPLS as a count-up, count-down, shift-right, shift-left machine governed by three control terms-COUNT/SHIIFT, RIGHT/UP, LEFT/ DOWN. Direct implementation would result in a machine with 64 state transitions (see Table A-1), which is beyond the scope of the PLS155 or even the 28 -pin PLS105. Logic reduction is therefore necessary.

As there are only four feedback variables ( D , $\mathrm{C}, \mathrm{B}, \mathrm{A})$, you can do the reduction by hand, one mode at a time; the control terms need not be included till the summary equations are written. Using the transition mapping method suggested here, you can examine the excitation equations for all types of flip-flops
(R-S, J-K, D, T) and choose those types that will perform the required functions using the fewest product terms. Table A-2 summarizes the rules for flip-flop implementation using transition maps; the transition symbols used in the table mean:

| PRESENT <br> STATE | NEXT <br> STATE | TRANSITION <br> SYMBOL |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | $a$ |
| 1 | 0 | $\beta$ |
| 1 | 1 | 1 |

Using these symbols, construct Table A-3 from Table A-1 to enable you to examine the excitation equations for all types of flip-flops. Proceeding one mode at a time, transfer the state conditions from Table A-3 to Karnaugh maps, as in Figure A-1. Following the rules in

Table A-2, derive the excitation equations for the different types of flip-flops (the examples shown in Figure A-1 omit the T type because it is the same as the $J-K$ type when $J=K$ ). In deciding which types of flip-flop to use, remember that logic minimization with PLD is different from logic minimization with 'random logic': with random logic you seek to reduce the number of standard packages required; with PLD you seek to reduce the number of product terms.

From Figure A-1 it is evident that you should choose J-K or T flip-flops for the counter mode and D flip-flops for the shift mode, for you then require only one product term per flip-flop per mode. Table A-4 summarizes the number of product terms per mode the various types of flip-flops would require.

Table A-5 shows the completed programming table for the counter/shift-register. The programming of Terms 0 to 15 reflects the flipflop excitation equations and illustrates the value of being able to switch the flip-flops dynamically from one type of operation to another. Terms 16, 17 and 18, respectively, provide for INITIALIZE, asynchronous RESET, and STOP functions.
The programming of the two additional inputs HALT and BUSY illustrates the value of the complementary, which is made active when HALT and $\overline{B U S Y}$ are Low (A in the Complement square of Term 18) and propagated into all the other terms (dot in the Complement squares of Terms 0 to 17). This means that unless the $\overline{\mathrm{HALT}}$ and $\overline{\mathrm{BUSY}}$ inputs are High, none of the product terms will be true and the state of the machine will not change. If the Complement Array were not used, twice the number of product terms would be required, even if one of the additional inputs were omitted.

As it is, the design uses only 19 of the 32 product terms available, so there is ample capacity for extending its capabilities. For example, the shift-left function can be augmented by a-binary multiplication capability, using a $D$ type flip-flop to make it shift one, two, or three places according to the state of two extra inputs, X and Y . Table A-6 shows the revised programming table. The binary multiplication function occupies nine additional product terms.

## ACKNOWLEDGEMENT

Electronic Components and Applications; Vol. 4, No. 2, February 1982. Reprinted with the permission of PHILIPS.

## Introduction To Signetics Programmable Logic

Table A-1. Present-State/Next-State Table for Counter/Shift-Register

| STATE NO. | PRESENT STATE |  |  |  | NEXT STATE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Count Down |  |  |  | Count Up |  |  |  | Shift Left |  |  |  | Shift Right |  |  |  |
|  | D | C | B | A | D | C | B | A | D | C | B | A | D | C | B | A | D | C | B | A |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| 2 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| 3 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 |
| 4 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 5 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| 6 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| 7 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| 8 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 |
| 9 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 |
| 10 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 11 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |
| 12 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 |
| 13 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 |
| 14 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| 15 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| CONTROL TERMS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| COUNT/SHITT |  |  |  |  | 1 |  |  |  | 1 |  |  |  | 0 |  |  |  | 0 |  |  |  |
| RIGHT/UP |  |  |  |  | 0 |  |  |  | 1 |  |  |  | 0 |  |  |  | 1 |  |  |  |
| LEFT/DOWN |  |  |  |  | 1 |  |  |  | 0 |  |  |  | 1 |  |  |  | 0 |  |  |  |

Table A-2. Rules for Flip-Flop Implementation Using Transition Maps

| FLIP-FLOP TYPE | INPUT | MUST INCLUDE | MUST EXCLUDE | REDUNDANT |
| :---: | :---: | :---: | :---: | :---: |
| R-S | S | $a$ | $\beta, 0$ | 1,x |
|  | R | $\beta$ | a, 1 | 0,x |
| D | D | $a, 1$ | $\beta, 0$ | $x$ |
| T | T | $a, \beta$ | 0,1 | x |
| J-K | $J$ | $a$ | 0 | 1, $\beta$, x |
|  | K | $\beta$ | 1 | $0, a, x$ |

Table A-3. Transition Table for Counter/Shift-Register

| $\begin{aligned} & \text { STATE } \\ & \text { NO. } \end{aligned}$ | PRESENT STATE |  |  |  | TRANSITION |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Count Down |  |  |  | Count Up |  |  |  | Shift Left |  |  |  | Shift Right |  |  |  |
|  | D | C | B | A | D | C | B | A | D | C | B | A | D | C | B | A | D | C | B | A |
| 0 | 0 | 0 | 0 | 0 | $a$ | $a$ | $a$ | $a$ | 0 | 0 | 0 | $a$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | $\beta$ | 0 | 0 | $a$ | $\beta$ | 0 | 0 | $a$ | $\beta$ | $a$ | 0 | 0 | $\beta$ |
| 2 | 0 | 0 | 1 | 0 | 0 | 0 | $\beta$ | $a$ | 0 | 0 | 1 | $a$ | 0 | $a$ | $\beta$ | 0 | 0 | 0 | $\beta$ | $a$ |
| 3 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | $\beta$ | 0 | $a$ | $\beta$ | $\beta$ | 0 | $a$ | 1 | $\beta$ | $a$ | 0 | $\beta$ | 1 |
| 4 | 0 | 1 | 0 | 0 | 0 | $\beta$ | $a$ | $a$ | 0 | 1 | 0 | $a$ | $a$ | $\beta$ | 0 | 0 | 0 | $\beta$ | $a$ | 0 |
| 5 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | $\beta$ | 0 | 1 | $a$ | $\beta$ | $a$ | $\beta$ | $a$ | $\beta$ | $a$ | $\beta$ | $a$ | $\beta$ |
| 6 | 0 | 1 | 1 | 0 | 0 | 1 | $\beta$ | $a$ | 0 | 1 | 1 | $a$ | $a$ | 1 | $\beta$ | 0 | 0 | $\beta$ | 1 | $a$ |
| 7 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | $\beta$ | $a$ | $\beta$ | $\beta$ | $\beta$ | $a$ | 1 | 1 | $\beta$ | $a$ | $\beta$ | 1 | 1 |
| 8 | 1 | 0 | 0 | 0 | $\beta$ | $a$ | $a$ | $a$ | 1 | 0 | 0 | $a$ | $\beta$ | 0 | 0 | $a$ | $\beta$ | $a$ | 0 | 0 |
| 9 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | $\beta$ | 1 | 0 | $a$ | $\beta$ | $\beta$ | 0 | $a$ | 1 | 1 | $a$ | 0 | $\beta$ |
| 10 | 1 | 0 | 1 | 0 | 1 | 0 | $\beta$ | $a$ | 1 | 0 | 1 | $a$ | $\beta$ | $a$ | $\beta$ | $a$ | $\beta$ | $a$ | $\beta$ | $a$ |
| 11 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | $\beta$ | 1 | $a$ | $\beta$ | $\beta$ | $\beta$ | $a$ | 1 | 1 | 1 | $a$ | $\beta$ | 1 |
| 12 | 1 | 1 | 0 | 0 | 1 | $\beta$ | $a$ | $a$ | 1 | 1 | 0 | $a$ | 1 | $\beta$ | 0 | $a$ | $\beta$ | 1 | $a$ | 0 |
| 13 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | $\beta$ | 1 | 1 | $a$ | $\beta$ | 1 | $\beta$ | $a$ | 1 | 1 | 1 | $a$ | $\beta$ |
| 14 | 1 | 1 | 1 | 0 | 1 | 1 | $\beta$ |  | 1 | 1 | 1 | $a$ | 1 | 1 | $\beta$ | $a$ | $\beta$ | 1 | 1 | $a$ |
| 15 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | $\beta$ | $\beta$ | $\beta$ | $\beta$ | $\beta$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Table A-4. Number of Product Terms Required for Counter/Shift-Register
Flip-Flop Excitation

| FLIP-FLOP <br> TYPE | COUNT <br> UP | COUNT <br> DOWN | SHIFT <br> RIGHT | SHIFT <br> LEFT | TOTAL |
| :--- | :--- | :--- | :--- | :--- | :---: |
| SR only | 8 | 8 | 8 | 8 | 32 |
| JK only | 4 | 4 | 8 | 8 | 24 |
| D only | 10 | 10 | 4 | 4 | 28 |
| FPLS | $4(\mathrm{~J}-\mathrm{K})$ | $4(\mathrm{~J}-\mathrm{K})$ | $4(\mathrm{D})$ | $4(\mathrm{D})$ | 16 |



Figure A-1 Karnaugh Maps and Flip-Flop Excitation Functions for the Counter/Shift-Register

Table A-5. PLS155 FPLS Programming Table for the Counter/Shift-Register


Table A-6. Modified PLS155 FPLS Programming Table for the Counter/Shift-Register With the Addition of a Binary Multiplier


## Signetics

Application Specific Products

## INTRODUCTION

Using the PLS153 or PLS153A, a 4-bit binary-to-7 segment decoder may be easily constructed. This paper will cover Hex-to-7 segment decoder, BCD-to-7 segment decoder, decoder with latches, and decoder with multiplexer. The architecture of PLS153/153A is basically an AND-OR matrix. The large number of inputs of each AND term is ideal for decoder applications, and the ability to drive the entire OR array makes possible the efficient use of AND terms such that, together with the programmable output polarity, a minimum number of AND terms is needed to implement the decoder function. Another important feature of the PLS153/153A architecture is the 10 bidirectional $1 / 0$ pins. The bidirectionality of these pins provides internal feedback to the AND matrix, which eliminates the need for externai wiring and, more importantly, it saves $1 / O$ pin requirements. All I/O pin's of the PL.Si53/153A have tii-state output buffers, each may be enabled or disabled by its own controlling AND terms. In applications where high current drive is necessary but low power consumption is still desirable, the AND term controlled tri-state buffers are ideal for multiplexing. The LED display may be driven at a higher current and lower duty cycle to get better brightness/current efficiency and reduce the overall power dissipation.

## Application Note

## DESCRIPTION

## Hex-To-7 Segment Decoder

A 7 segment display (Figure 1) may be used to represent a hexadecimal number as shown in Table 1. The format serves merely as an example. Some designers may prefer other configurations, particularly for letters B and D. Before implementing the truth table with programmable logic devices, one has to decide whether the outputs should be Active-High or Active-Low. If a moderate drive current of 15 mA or less is needed, and if a common anode LED
display is used, then an Active-Low output configuration is sufficient. On the other hand, if only a common cathode LED display is available and the current drive requirement is not very critical, an Active-High output configuration may be used. The change of output polarity may be easily affected by putting in the POLARITY section ' H ' for Active-High and 'L' for Active-Low. Since the output polarity is programmable, one may choose to describe the logic in terms of outputs equal to '1's or outputs equal to 'O's.


Figure 1. 7 Segment Decoder Driving a Common Anode LED Display


Figure 2. Pin List of Binary-to-7 Segment Decoder
NOTE:
PLSXXX and 82SXXX are interchangeable part numbers.

Table 1. Truth Table of Hex-to-7-Segment Decoder


| 2 | 4 | $x$ | $u$ | $a$ | $b$ | $c$ | $d$ | $e$ | $f$ | $g$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |
| 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |

## 4-Bit Binary-To-7 Segment Decoder

Table 2. H/L Programming Table for Binary-to-7-Segment Decoder


## 4-Bit Binary-To-7 Segment Decoder

Table 3. H/L Programming Table for Binary-to-7 Segment Decoder


TR010115

```
EDEVICE TYPE
82S153
EDRAWING
************************ BINARY-TO-7 SEGMENT DECODER
MPEVISION
*********************** REV. -
ODATE
*********************** OCT 1, 1984
CSYMBOL
*********************** FILE ID: 7deco
RCOMPANY
************************** SICNETICS
ENAME
```



```
CDESCRIPTION
**************************************************************************
* This circuit converts a 4-bit binary code (HEX ) into
    a 7-segment display. The display is a common anode 7-segment LED.
* The output of the 825153 goes LOW for each segment that is ON.
**************************************************************************
```


truth table

| $z$ | $\gamma$ | $x$ | $w$ | $a$ | $b$ | $c$ | $d$ | $e$ | $f$ | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $i$ |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |  | 0 | 1 | 1 | 1 | 0 | 0 |

aCOMPIDN PRODUCT TERM


Figure 3. Boolean Equation for Binary-to-7 Segment Decoder


Figure 3 (Continued)

In this example, an Active-Low output goes Low when a segment is to be turned on. The truth table shown in Table 1 is translated into an $\mathrm{H} / \mathrm{L}$ programming table as shown in Table 2. Since the LED display used here is common anode, the output polarity of each output pin is programmed " L " so that an output goes low when a segment is to be turned on. The decoder takes 16 AND terms. Notice that all outputs go Low when input equals ' 8 '. If
the logic is written for " $0 s^{\prime}$ " instead of " 1 s ", one AND term could be saved. Table 3 shows that the same circuit may be implemented by using only 15 AND terms. Notice that the polarity is the reverse of that of Table 2. The outputs may be turned on and off by $\mathrm{I}_{7}, ~$ IOE, which controls the 7 tri-state output buffers through control terms (AND terms $D_{1}$ to $D_{7}$ ). The same design is also implemented using Boolean equations with AMAZE. Figures 2
through 4 are, respectively, pin list, logic equations, and logic simulation results of the hex-to-7 segment decoder circuit generated by AMAZE. Table 4 is the $\mathrm{H} / \mathrm{L}$ table generated by AMAZE. In the process of generating Boolean equations for the decoder, common product terms are used to economize the usage of AND terms.

Table 4. H/L Table Generated by AMAZE for Binary-to-7 Segment Decoder


```
825153 A:7deco153.5TD
" 4-bit binary to 7-segment decoder simulation
" INPUTS <=B(I/D)=> TRACE TERMS
"76543210 9876543210
*
    00000000 ..LLLLLLH. #
    00000001 .. HLLLHHHH. 
    00000010 =.LLHLLHL. ;
    00000011 =.LLLLHHL.
    00000100 ..HLLHHLL.
    00000101 -.LHLLHLL. 
    00000110 ..LHLLLLL.
    00000111 ..LLLHHHH.
    00001000 .. LLLLLLL. ;
    00001001 ..LLLLHLL.
    00001010 .-LLLHLLL.
    00001011 ..HHLLLLL.
    00001100 ..LHHLLLH.
    00001101 ..HLLLLHL.
    00001110 ..LHHLLLL. *
    00001111 ..LHHHLLL.
    10001111 ..........
    10000000 ............
"
```



```
" IIBEBBBEBEI DESIGNATED I/O USAGE
. PIN LIST..
"OB}0700
```

Figure 4


| W LABEL | ** FNC | **PIN |  |  | PIN** FNC |  |  | ** | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | * I | ** | 1-1 |  | : -20 | ** | +5V | **VCC |  |
| X | ** I | ** | 2-: |  | ;-19 | ** | B | **N/C |  |
| V | ** I | ** | 3-: |  | 1-18 | ** | B | **N/C |  |
| Z | ** I | ** | 4-1 | 8 | 1-17 | ** | B | **/SEG | 日_A |
| N/C | ** I | ** | 5-1 | 2 | 1-16 | ** | B | **/SEG | G_B |
| N/C | ** I | ** | 6-: | 5 | :-15 | \#\# | B | **/SEG | -C |
| N/C | ** I | ** | 7-: | 1 | 1-14 | ** | /B | **/SEG | G_D |
| fOE | ** I | ** | 8-i | 5 | :-13 | ** | /B | **/SEG | G_E |
| N/C | ** B | ** | 9-: | 3 | :-12 | ** | /B | **/SEG | G_F |
| GND | ** OV | ** | 10-1 |  | :-11 | ** | /B | **/SEG | G_G |

Figure 5. Pin List of Binary-to-7 Segment Decoder Generated by AMAZE

BCD-To-7 Segment Decoder
Using the same principle as in the previous example, a BCD input may be converted to a 7 segment display. If the input will always be within the range of 0000 B to 1001 B , the design will take ten AND terms to implement the decoding function. But if the display of an error message is desired when input exceeds 1001B, the design shown in Figures 5 and 6 and Table 5, may be used. Alternatively, the error message " $E$ " will be displayed if the input does not equal anything between 0000B and 1001B inclusively. The circuit used to detect that none of the ten AND terms being true is shown in Figure 7 where if the input is outside of the range of 0000 B to 1001 B , none of the terms ZER to NIN will be active, which in turn causes the output of the NOR term to be High. The High output then causes the " $E$ ' term to be active and thus an output " $E$ " is displayed. This scheme takes two propagation delays before " $E$ " is displayed but only one delay for " 0 " to " 9 " to be displayed. The circuit shown in Figure 7 is implemented as shown in Table 4, column $\mathrm{B}(\mathrm{O})_{0}$ of terms 0 to 9 , and term \#11. The output $\mathrm{B}(\mathrm{O})_{0}$ becomes High when terms 0 to 9 are inactive, $\left(T_{0}+T_{1}+T_{2}+T_{3}+T_{4}+T_{5}+T_{6}+T_{7}+T_{8}\right.$ $\left.+T_{9}\right)=0$ where $T_{0}$ is term \#0, $T_{1}$ is term $\# 1, T_{2}$ is . ., etc. $B(O)_{0}$ is then fed back to the input of term \#11 which, when active, causes outputs $B$ and $C$ to be High, segments $B$ and $C$ to turn off and the other segments to turn on. Term \#10 is left blank to separate the main decoding function and the feedback function for the sake of clarity of this demonstration. A similar feature the COMPLEMENT ARRAY) may be found in PLS155/157/159 where the feedback path is buried inside the chip without having to use up one I/O pin. Notice that this feature greatly reduces the number of AND terms needed. But for device architectures which do not allow common AND terms, this logic minimization will not be possible. Figure 8 and Table 6 implement design with AMAZE. The circuit is then simulated as shown in Figure 9.

## 4-Bit Binary-To-7 Segment Decoder

```
N@DEVICE TYPE
825153
@DRAWING
************************ SCD-TO-7 SEGMENT DECODER
GREVISIDN
*********************** REV. -
@DATE
************************* OCT 1, 1984
eSYMBOL
************************ FILE ID: BCD-7153
CCOMPANY
************************ SIGNETICS
GNAME
************************ DAVID K. WONG
@DESCRIPTION
```



```
* This circuit converts a 4-bit BCD code into a 7-segment display.
* The display is a common anode 7-segment LED.
* The output of the 8251S3 goes LOW for each segment that is ON.
*****************************************************************************
```


d

```
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Z & Y & X & & TRUT
\(a\) & \(b\) & c & d & e & \(f\) & \(g\) \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\
\hline 0 & 0 & 0 & 1 & 1 & 0 & o & 1 & 1 & 1 & 1 \\
\hline 0 & 0 & 1 & 0 & 0 & 0 & 1 & 0 & 0 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & - & 0 & 1 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 1 & 0 & - & i & 1 & - & 0 \\
\hline 0 & 1 & o & 1 & 0 & 1 & 0 & 0 & 1 & 0 & 0 \\
\hline 0 & 1 & 1 & 0 & 0 & 1 & o & 0 & 0 & 0 & 0 \\
\hline \(\bigcirc\) & 1 & 1 & 1 & \(\bigcirc\) & 0 & \(\bigcirc\) & 1 & , & 1 & 1 \\
\hline 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline 1 & 0 & \(\bigcirc\) & 1 & 0 & 0 & 0 & 0 & 1 & \(\bigcirc\) & 0 \\
\hline
\end{tabular}
\begin{tabular}{lllllllllllcl}
1 & 0 & 1 & 0 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & Display E (error) \\
1 & 0 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & \("\) & \\
1 & 1 & 0 & 0 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & \("\) & \\
1 & 1 & 0 & 1 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & \("\) & \\
1 & 1 & 1 & 0 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & \("\) & \\
1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 & 1 & 1 & 1 & \("\)
\end{tabular}
```

ECDMMON PRODUCT TERM


Figure 6. Boolean Equations for BCD-to-7 Segment Decoder for AMAZE

```
@LOGIC EQUATION
SEG_A = ONE + FDU + AAA
/SEG_B = FIV + SIX
/SEG_C = TWO
/SEG_D = /( ZER + TWQ + THR
/SEG_E = /( ZER + TWO + SIX
/SEG_F = /( ZER + FOU + FIV
/SEG_G = /( TWO + THR + FDU
EI/O DIRECTION 150/1, 152/3,
"
******************************
* OUTPUTS ARE ENF
* THEREFORE, D1..
*****************************
"
D1 = OE ;
D2 = DE
D3 = DE ;
D4 = DE ;
D5 = DE
DG = DE :
D7 = DE ;
#
*****************************
* END
*****************************
!
```

Figure 6 (Continued)


LDO1160S
Figure 7. Complement Array - "None of the Above" Detection Circuit

Table 5. H/L Table for BCD-to-7 Segment Decoder Generated by AMAZE


## 4-Bit Binary-To-7 Segment Decoder

```
EDEVICE TYPE
************************ 825153
@DRAWING
*********************** BINARY-TO-7 SEGMENT DECODER
@REVISION
************************ REV. -
@DATE
*********************** OCT 1, 1984
@SYMBOL
************************ FILE ID: BCD77153
ecOMPANY
************************ SIGNETICS
@NAME
*********************** DAVID K. WIONG
EDESCRIPTION
*******************************************************************************
    This circuit converts a 4-bit BCD code into a 7-segment display. *
    The display is a common anode 7-segment LED.
    The output of the 82S153 goes LOW for each segment that is ON.
```





Figure 8. Boolean Equation for BCD-to-7 Segment Decoder

```
gLOGIC EQUATION
n
```



```
* When input is greater than 9, QVR ( Over Range ) will go HIGH, WHICH *
* will be fed-back to the AND array to control the segments.
* Here the OVR pin and the feedback loop is used as COMPLEMENT ARRAY.
* The COMPLEMENT ARRAY saves 5 P-terms but loses one I/O pin.
******************************************************************************
#
OVR = /( ZER + ONE + TWO + THR + FOU + FIV + SIX + SEV + EIG + NIN ) !
/SEG_A = ONE + FOU ;
/SEG_B = FIV + SIX + OVR
/SEG_C = TWO + QUR ;
/SEG_D = ONE + FOU + SEV ;
/SEG_E = /( ZER + TWO + SIX + EIG + OVR ) ;
/SEG_F = ONE + TWO + THR + SEV ;
/SEG_G = ZER + ONE + SEV
@I/O DIRECTION 150/1, 152/3, 154-9
"
***************************************************************************
* OUTPUTS ARE ENABLED WHEN /OE GOES LOW.
* THEREFORE, D1 ...D7 = /(/OE) = OE ;
***************************************************************************
"
D1 = DE ;
D2 = प्0E ;
D3 = DE ;
D4 = DE ;
DS = DE :
DG = DE :
D7 = OE ;
"
****************************************************************************
* END OF LOGIC EQUATIONS
*
***************************************************************************
"
```

Table 6. H/L Table of BCD-to-7 Segment Decoder Generated by AMAZE


```
825153 A:bcd77153.STD
    " yhgfikuhyfouiy
* INPUTS <=B(I/G)=> TRACE TERMS
:76543210 9576543210
    00000000 ..LLLLLLHL;
    00001111 ..LHHLLLLH;
    10001111 .........H;
    00000000 ..LLLLLLHL
    01000001 ..HLLHHHHHL
    01000010 ..LLHLLHLL
    01000011 ..LLLLHHLL
    01000100 .. HLLHHELL;
    01000101 .. LHLLHLLL ;
    01000110 =-LHLLLLLL ;
    01000111 ..LLLHHHHL
    01001000 ..LLLLLLLL
    01001001 * =LLLLHLLL
    01001010 ..LHHLLLLH
    01001011 ..LHHLLLLH;
    01001100 ..LHHLLLLHH ;
    01001101 ..LHHHLLLH;
    01001110 ..LHHLLLLH
    01001111 *.LHHRLLLH
    11001111 ..........H
    10000000 .........L;
"
! X--m-n------------ I/O CONTROL LINES
" IIBERBBBEO DESIGNATED I/O USAGE
" IIBBBBBBBO ACTUAL I/O USAGE
* PIN LIST...
```



```
                                    TB01130S
```

Figure 9. Simulation Results of H/L Table

## BCD-To-7 Segment Decoder with Output Latches

Output latches may be constructed by using the bidirectional I/Os of PLS153/153A as shown in Figure 10. When /LE (latch enabie) is High, the output equals the input. But when /LE is Low, the output is latched. Changing the input will not effect the output. Segments $a$ and $e$ are used to illustrate the decoding and latch circuit as shown in Figures 11 and 12 which are expressed in H/L format as shown in Table 8. The complete design of the decoder is shown in Figures 13 and 14 and Table 7. With the output latches, the circuit cannot be tri-stated since the tri-state condition will interrupt the feedback path. An alternative approach is shown in Figure 15 where the display is a common cathode, the segment drivers are always on and the duty cycling is implemented with a digit driver which pulls the common cathode of the display to ground as the input "Duty Cycle" goes High. A common practice is to drive the segments with 10 time the desired DC current and drive the digit with a $10 \%$ duty cycle puise. The $\mathrm{H} / \mathrm{L}$ implementation is as shown in Tables 9 and 10. The "Duty Cycle" control input is generated externally.

## 4-Bit Binary-To-7 Segment Decoder




LDO1180S
Figure 11. Segment-A Latch Circuit


Figure 12. Segment-E Latch

## \#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\# F I N L I S T \#\#\#制\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#

LABEL
** FNC **PIN
PIN** FNC **
LABEL
W
$X$
$Y$
$Z$
$N / C$
$N / C$
LLE
N/C
OUR
GND
**PIN
$4-20 * *+5 \mathrm{~V} * * V C C$
** $1 \quad$ ** $2-1 \quad 1-19 * * B \quad * * N / C$
** I $\quad$ ** $3-1 \quad i-18 * * B \quad * * N / C$

* I $\quad$ ** $4-1 \quad 8 \quad i-17 * * 0 \quad * * / S E G \_A$
** I ** 5-i 2 i-16 ** $\quad 2 \quad * * /$ SEG_B $^{*}$
** $\quad$ ** 6-1 S $1-15 * * 0$
$1-15 * * 0$
**/SEG_C
* I **
$1-14 * * 0 \quad * * / S E G_{-}$
** I $\quad * *$ 8-1 $5 \quad 1-13 * * / 0 \quad * * /$ SEG_ $_{-}$
** 10 $\quad$ ** $9-1 \quad 3 \quad i-12 * * 0 \quad * * /$ SEG_F
** OV ** 10-i i
**/SEG_G

Figure 13. Pin List of BCD-to-7 Segment Decoder with Latches

GDEVICE TYPE
825153
edrawing
*********************** BCD-TO-7 SEGMENT DECODER
GREVISIUN
***********************REV. -
gDATE
*********************** OCT 1, 1984
esYMBOL
*********************** FILE ID: BCD7L153
QCOMPANY
*********************** SIGNETICS
ename
*********************** DAVID K. WONG
@DESCRIPTION
*************************************************************************

* This circuit converts a 4-bit BCD code into a 7 -segment display.
* The display is a common anode 7 -segment LED.
* The output of the 825153 goes LOW for each segment that is ON.
* The outputs are latched when /LE goes LOW.



"
* Feedback circuits to form D-iatches.

Figure 14. Boolean Equation of BCD-to-7 Segment Decoder with Latches

```
AL = LE*/SEG_A ;
    "Note that in LOGIC EQLATION definition, SEG_E is
    inverted. Therefore, the feedback for E has to
    be inverted too."
FL = LE */SEG_F ;
GL = LE * /SEG_G
GLOGIC EQUATION
******************************************************************************
* When input is greater than 9, OVR ( Qver Range ) will go HIGH, WHICH
* will be fed-back to the AND array to control the segments.
* Here the QUR pin and the feedback loop is used as COMFLEMENT ARRAY
* The COMPLEMENT ARRAY saves 5 F-terms but uses up one I/O pin.
******************************************************************************
OVF = /( ZER + ONE + TWO + THR + FDU + FIV + SIX + SEV + EIS + NIN + LE ) ;
/SEG_A = ONE + FOU + AL
SEG_B = FIV + SIX - OVR + EL
/SEG_C = TWO + OVR + CL
SEG_D = ONE + FOU + SEV + DL
/SEGE = /(ZER + TWO + SIX + EIG + QVR + EL % )
SEGFF= ONE + TWO + THR + SEV + FL
ISEG_F = ONE + TWO + THR + SEV + FL
/SEG_G = ZER + ONE + SEV + GL
@I/O DIRECTION
******************************************************************************
* END OF LOGIC EQUATIONS
END OF LOGIC EQUATIONS *
****************************************************************************
" Tr01605
Figure 14 (Continued)
```

Table 7. H/L Table of BCD-to-7 Segment Decoder with Latches



Table 8. BCD-to-7 Segment Decoder Using Complement Array


Table 9. Segments A and E with Latches


Table 10. H/L Table of BCD-to-7 Segment Decoder with Latches with Outputs Active-High


# AN11 <br> PLD Programmable Retriggerable One-Shot 

Application Note

## Application Specific Products

## Author: David Wong

FEATURES

- Programmable pulse-width/delay
- Maximum 256 clock cycles
- Asynchronous TRIGGER input
- Active-High and Active-Low outputs
- Asynchronous RESET
- 20-pin package


## THEORY OF OPERATION

The one-shot consists of an FPLS PLS159 and an external clock which may be part of the system in which this one-shot is to work. As shown in Figure 1 and Table 1 the FPLS is configured to have a latch and an eight-bit binary up counter which is presettable by input data to any number less than 256 . Since the input data is inverted before it is loaded into the registers, counting from the comple-
ments of the input to FF will give the correct number of counts as counting from the input down to 00 .

Pulse-width/delay inputs may be the outputs of another device or switches. When /RESET goes Low, flip-flops are set to all 1's (terms $P B$ and PA). At the rising edge of the next clock, data is latched into the registers (terms LB and LA). When /TRIG goes Low, it is latched into the input latch formed by term \# $0,1,2$ and 13. The output $O_{1}$ of the latch goes High and $\mathrm{O}_{2}$ goes Low which enables the 8 -bit counting cycle. The $\mathrm{O}_{1}$ and $/ \mathrm{O}_{1}$ will maintain their output levels until the end of the counting cycle at which time the counter reaches the count $F F$, resets the latch by term \# 13, and sets $\mathrm{O}_{2}$ High. At the rising edge of the next clock, terms LA and LB cause data to be loaded again into the registers, and the device is ready for another /TRIG input. The output wave-forms are illustrated in Figure 2.

If the /TRIG pulse-width is longer than the desired pulse-width of the one-shot, the device will react as mentioned above, and at the end of the count cycle new data will be loaded, another count cycle begins while the outputs remain set by the /TRIG input without changing throughout the change-over of one count cycle to another. $O_{1 a}$, on the other hand, will go Low for one clock period at the change-over. As long as the /TRIG is Low, $\mathrm{O}_{1 \mathrm{a}}$ will continue to pulse Low for one clock period at the change-over of one count cycle to another. The output $\mathrm{O}_{2}$ will pulse High for one clock cycle at the change-over. Figure 2 illustrates output wave-forms for both cases. The output wave-forms are as illustrated in Figure 2.

The one-shot is implemented by programming the PLS159 as shown in Table 1. The logic representation of the program is shown in Figure 3.


Figure 1. Programmable Retriggerable One-Shot

Table 1. PLS159 FPLS Program Table


This one-shot will load data at the end of the count cycle. If TRIG pulse-width is longer than the count cycle, output B3 will go Low for one clock period and go High again for another count cycle. Outputs $B_{2}$ and $B_{0}$ stay Low and High respectively until TRIG goes High and count cycle is completed without interruption.


Figure 2. Timing Diagram of Programmable Retriggerable One-Shot


## Signetics

## Application Specific Products

## INTRODUCTION

The Low Cost Programmer (LCP) is designed to provide the user with a low cost alternative to program Signetics' PLD 20 -pin series programmable logic devices. This system is a peripheral device which is to be controlled by a computer running Signetics software, AMAZE, or by a terminal. The LCP is connected to the host computer via the RS232 interface and will accept ASCII codes. The data transfer rate can be either 9600 or 4800 baud. The LCP system clock is 4800 baud. The basic measure of time in the system is in units of $13 \mu \mathrm{~s}$. After every fuse is programmed, the LCP will automatically perform a verification cycle and feed data back to the computer. The system can be set to TEST mode which causes the outputs to cycle through the fusing sequence in an endless loop.

## THEORY OF OPERATION

A block diagram of the LCP is shown in Figure 1. U1 generates the 9600 baud clock for U3 (UART) and the 4800 baud clock for the rest of the system. When data is transferred into U3, it is put on the system bus. U1 generates IDAV which enables the rest of the system to react to the input. Since each device can decode the input instruction, very few controls are necessary.
Figure 2 shows the system instruction set. Each consists of seven bits with the upper 3 bits being the instruction code and the lower 4 bits being data or finer resolution of the instruction code. Figures 2 and 3 of Appendix 1 show the fuse address tables of PLS153 and PLS159, respectively. Note that the Variable Addresses have seven bits ( 3 upper bits and 4 lower bits), whereas the Term Addresses have six bits ( 2 upper bits and 4 lower bits). Therefore, it takes up to four nibbles to define a fuse address. Once an address is defined, the Variable Address generator will increment automatically to generate the subsequent fuse addresses for the same Term Address. Loading a Term Address in the Term Address generator will always reset the Variable Address generator. Therefore, the Term Address should be entered first and then the Variabie Address. The last entry is the fusing data in a 4-bit nibble. The system will automatically increment the Variable Address generator to program four fuses. Once the 4 -bit fusing data is loaded, the system goes into an internal mode until

## Application Note



Figure 1. Block Diagram

| C2 <br> (D6) | C1 <br> (D5) | C0 <br> (D4) | D3 | D2 | D1 | D0 | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | X | X | X | X | System internal use |
| 0 | 0 | 1 | X | X | X | X | System internal use |
|  |  |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | System reset |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | Set system ON-LINE |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | Set system OFF-LINE |
|  |  |  |  |  |  |  |  |
| 0 | 1 | $\mathbf{i}$ | 4-bit data |  |  |  | Load fusing data |
| 1 | 0 | 0 | 4-bit data |  |  |  | Load 4-bit lower TERM ADD. |
| 1 | 0 | 1 | 2-bit data |  |  |  | Load 2-bit upper TERM ADD. |
| 1 | 1 | 0 | 4-bit data |  |  |  |  |
| 1 | 1 | 1 | Load 4-bit upper VAR ADD. |  |  |  |  |

NOTE:
The upper and lower VARIABLE ADDRESSES will be reset to zero if upper or lower TERM ADDRESS is loaded into the LCP.

Figure 2. LCP Instruction Set
the fusing cycle for the four fuses are completed.
The following illustrates the sequence of programming operation:

1. Switch LCP to ON-LINE
2. Input 0100000 -reset LCP
3. Input 0100001 -put LCP 'ON-LINE'

## Low Cost Programmer for PLD 20-Pin Series

4. Input 100 - -load 4-bit lower TERM ADDRESS
5. Input 101 00--load 2-bit upper TERM ADDRESS
6. Input 110- - load 4-bit lower VARIABLE ADDRESS
7. Input 111 0-- load 3-bit upper VARIABLE ADDRESS
8. Input 011--load 4-bit fusing data, a " 1 " causes a fuse to be blown
9. U6, the fusing sequencer, causes the system to go into INTERN mode
10. Fusing sequence starts. See Figures 3 and 4
11. Fusing cycle completed. Input next address:
a. If next TERM ADDRESS is different from the previous one, go to (4)
b. If next address is in sequence with the previous VARIABLE ADDRESS and in the same TERM, go to (8)
c. The Variable Address generator will always reset to 0 if TERM ADDRESS is loaded.

Figure 3 shows the sequence of fusing operation while the system is in internal mode. Figure 4 shows the timing diagram and voltage waveform of the fusing sequence of four consecutive fuses.

## Analog Drivers:

$\mathbf{V}_{\mathbf{P}}$ - This signal is current limited to 325 mA . It is 1.25 V to 1.75 V when not fusing (idle). During the fusing cycle it takes on a value of 14.25 V to 14.75 V for a short time. The leading edge is slew rate limited to about $10 \mu \mathrm{~s}$.
$V_{\text {CCP }}$ - This signal is the programming power supply. It can source up to 1A. It has a value of 1.1 V to 1.3 V when not fusing (idle).


## NOTES:

1. State numbers in hex.
2. State changes on every clock.
3. $13 \mu \mathrm{~s}$ cycle time.

Figure 3. State Diagram Fusing Sequence and Control PLD U6


During the fusing cycle it assumes a value of 8.25 V to 8.75 V for the duration of the entire cycle (four fusing pulses - See Figure 4).
$V_{P}$ Driver Circuitry - The $V_{P}$ signal is toggled by the Fusing Sequencer, U6, Pin 15. This TTL signal is buffered up by the switching transistor, Q3, and its associated resistors, R6 and R9. Transistor Q4 inverts the signal to achieve the correct phase relationship. It also performs the following circuit functions:

1. It clamps the base of the Darlington transistor, Q5, to near ground through the R10 resistor.
2. Transistor Q4 discharges the slew rate time constant capacitor, C 1 , through the resistor, R10, and shunts the current from the current source, VR2, to near ground. This prepares the circuit for the next controlled slew rate edge at the beginning of the next fuse blowing cycle.
3. It provides a current sinking path to pull current out of the fusing socket enable line, thus creating a rapidly falling $V_{C C P}$ trailing edge. The diode, D2, provides sourcing isolation while the resistor, R11, limits inrush currents. A ferrite bead on the R11 lead slows down this path. This prevents large currents from flowing through transistor Q4 at the low level switching transition time.
The voltage regulator, VR1, forms the 325 mA current limit circuit in conjunction with the voltage dropping resistor, R8.
The controlled slew rate of the leading edge and the final level of the enable high output voltage $V_{P}$ are generated in the following mañier:
4. A 10 mA current source is formed by the voltage regulator, VR2, and the dropping resistor, R7.
5. This current is shunted to ground through Q4 when the enable pulse is low.
6. At the instant when Q4 turns off, the 10 mA current is diverted into the slew rate control capacitor, C1. The capacitor, C 1 , will continue to charge linearly until the voitage across it reaches the value of the zener diode stack D1A and D1B.
7. The current is then shunted down the zener diodes until Q4 is turned back on.
8. The base of the Darlington transistor, Q 5 , follows the voltage across the capacitor, C 1 , and draws very little current due to its very high current gain. Since the Q5 transistor is configured as an emitter foilower, the voilage seen on the fusing socket enable line will be about 1 V lower than the base of transistor Q5. Resistor R12 stabilizes the value of the $V_{B E}$ on transistor $Q 5$ by pulling a small amount of current early in the ramp.
$\mathrm{V}_{\mathrm{CCP}}$ Driver Circuitry $-\mathrm{V}_{\mathrm{CCP}}$ is toggled by the internal/external signal from the Fusing Sequencer, U6. Again, the signal is buffered and inverted twice by transistors Q1 and Q2 along with resistors R4 and R3.

## Low Voltage (Idle)

Resistor R2 is shorted to ground through transistor Q2 in order to generate the 1.1V to 1.3V low output level. This is an intrinsic value generated by the internal reference of the voltage regulator.

## High Voltage ( $\mathrm{V}_{\mathrm{CPP}}$ )

When transistor Q2 is turned off, the output voltage ramps to the 8.25 V to 8.75 V level. This value is determined by the ratio of resistors R1 and R2 in conjunction with the actual value of the voltage regulator's internal reference.

## Power Supply Consideration

1. The Low Cost Programmer circuitry draws about 1A.
2. The Enable and $V_{C C P}$ currents may reach about 1.4A.
3. The Enable signal is about 15 V and needs at least 5 V of head room.
4. The RS232 drivers require $\pm 12 \mathrm{~V}$ at about ర̂̂mA.

In a bridge circuit, a rule of thumb says that the transformer's current rating should be from 1.2 to 1.6 times the load current. Using this rule, the secondary of the transformer that supplies $V_{C C}$ and $\pm 12 \mathrm{~V}$ should be rated at 18 V center tapped at about 1.6 A .

The transformer that supplies the Enable and $V_{\text {CCP }}$ circuits should have an 18 V secondary at about 2.2A.

## PROGRAMMING THE LCP

The addresses and fusing data can be generated by the host computer using AMAZE or a terminal nibble by nibble. The fuse address of each PLD 20 -pin device is available in the Signetics PLD data manual. Copies of the fuse address tables of PLS153 and PLS159 are included in Appendix A Tables A-1 and A2. These fuse addresses, together with the 3bit instruction code, form a 7 -bit instruction which can be represented by a single ASCII character. Table 1 is a table of ASCII characters.

The following example illustrates the conversion of program table entries into fuse addresses and fusing data. Table 2 shows a simple entry in an PLS153 program table. To keep things simple, only four entries are made. The first entry is term 3, variable 17. The fuse of the non-inverting buffer is to remain intact, whereas the fuse to be blown is the inverting buffer, 17. For this entry, from Table A-1 of Appendix A, the Term Address is 03 hex or 000011 b, the Variabie Addresses of the two buffers are 0Ehex or 000 1110b, and 0 Fhex or 0001111 . The fusing data is 01. The second entry is Term 3, 16. The fuse of the inverting buffer is to be kept intact while that of the non-inverting buffer will be blown. The Term Address is the same as the previ-

Table 1. ASCII Character Table

|  |  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0000 | 0 | NUL | DLE | SP | 0 | - | P | - | p |
| 0001 | 1 | SOH | DC1 | ! | 1 | A | Q | a | q |
| 0010 | 2 | STX | DC2 | " | 2 | B | R | b | r |
| 0011 | 3 | ETX | DC3 | \# | 3 | C | S | c | s |
| 0100 | 4 | EOT | DC4 | \$ | 4 | D | T | d | t |
| 0101 | 5 | ENQ | NAK | \% | 5 | E | U | e | $u$ |
| 0110 | 6 | ACK | SYN | \& | 6 | F | V | f | $v$ |
| 0111 | 7 | BEL | ETB | ' | 7 | G | W | g | w |
| 1000 | 8 | BS | CAN | $($ | 8 | H | X | h | x |
| 1001 | 9 | HT | EM | ) | 9 | 1 | Y | i | $y$ |
| 1010 | A | LF | SUB | * | : | J | $z$ | j | $z$ |
| 1011 | B | VT | ESC | $+$ | ; | K | [ | k | I |
| 1100 | C | FF | FS | , | $<$ | L | $\wedge$ | 1 | : |
| 1101 | D | CR | GS | - | = | M | ] | m | 1 |
| 1110 | E | So | RS | . | $>$ | N |  | n | $\sim$ |
| 1111 | F | SI | us | 1 | ? | 0 | $\div$ | o | DEL |

Table 2. FPLA Program Table

ous entry; the Variable Addresses of the two buffers are 0Chex or 0001100 b and ODhex or 000 1101b. The fusing data is 10 . The four fusing data can be combined into one nibble ( 0110 ) since the two entries are in sequence. Only the first address has to be loaded (Term Address 03hex and Variable Address 0F). The next two entries are in sequence with the first two, therefore only fusing data nibble 1111 has to be loaded.

The instruction and data nibbles can be loaded into the LCP in ASCII characters (see Table 1).

## LCP CHECK OUT AND CALIBRATION

This section deals with the check out and calibration of the Low Cost Programmer.
The voltage regulator, VR4, dissipates a lot of heat. It should be mounted on a metal chassis with an isolation mount.

Notice that the fusing socket, P1, has three columns of pads. Use the left set if the socket is to be mounted on the component side of the PCB. Use the right set if the socket is to be piaced on the biank side of the PCB. The LEDs may also be mounted on the blank side, allowing for very easy panel mounting of the finished LCP.

## Power Supplies

1. $+10 V_{D C}$ to $+14 V_{D C}$ at the positive side of C4.
2. $-10 V_{D C}$ to $-14 V_{D C}$ at the negative side of C3.
3. $+4.75 \mathrm{~V}_{D C}$ to $+5.25 \mathrm{~V} D C$ at the $+5 \mathrm{~V}_{D C}$ input pad of the PCB.
4. $+20 V_{D C}$ to $+26 V_{D C}$ at the positive side of C 2 .
Turn off the LCP and insert ICs U1 through U5, U7 and U8. Do not insert U6 yet.

Turn on the LCP and repeat steps 1 through 4 above.

## Driver Calibration

The Fusing Sequencer, U6, must not be in the LCP for the following steps:

Measure $1.25 \mathrm{~V}_{D C}$ to $1.75 \mathrm{~V}_{D C}$ at Pin 18 of P1. (The fusing socket.)
2. Place a clip lead from the U6 Pin 15 end of resistor $R 6$ to $V_{C C}\left(+5 V_{D C}\right)$.
3. Measure $14.0 V_{D C}$ to $15.0 V_{D C}$ at Pin 18 of P1.
4. Momentarily place a $75 \Omega 3 \mathrm{~W}$ resistor from Pin 18 of P 1 to ground and observe the voltage to still read $14.0 V_{D C}$ to $15.0 V_{D C}$.
5. Disconnect the clip lead between R6 and $\mathrm{V}_{\mathrm{CC}}$.
6. Measure the voltage at Pin 18 of P1 to once again be 1.25 to $1.75 \mathrm{~V}_{\mathrm{DC}}$.
7. Place a jumper from the U6 Pin 19 side of resistor R4 to ground.
8. Measure the voltage at Pin 20 of P1. it should be $1.10 V_{D C}$ to $1.30 V_{D C}$.
9. Place a jumper from the $\cup 6$ Pin 19 side of resistor R4 to $V_{C C}$.
10. The voltage should be from $8.25 \mathrm{~V}_{\mathrm{DC}}$ to $8.75 \mathrm{~V}_{\mathrm{DC}}$ at Pin 20 of P1.
11. Place a $30 \Omega 3 W$ load resistor momentarily from Pin 20 of P1 to ground and measure the voltage. It should remain within the $8.25 V_{D C}$ to $8.75 V_{D C}$ range. The value of R2 may have to be selected in order to give the correct voitage reading.
12. Reconnect the jumper from R4 to ground.
13. The voltage at Pin 20 of P1 should be $1.10 \mathrm{~V}_{D C}$ to $1.30 \mathrm{~V}_{D C}$.
14. Turn off power and insert U6 into its socket.

## Baud Rate Generation

1. Using an oscilloscope, look at the waveform on Pin 17 of the Baud Rate Generator, U1. This signal should swing from $<450 \mathrm{mV}$ to $>2.4 \mathrm{~V}$ and have about a $50 \%$ duty cycle.
2. The frequency at this pin should be 153.6 kHz . This results in a period of $6.51 \mu \mathrm{~s}$.
3. Repeat Steps 1 and 2 for Pin 18 of U1. The frequency should be 76.8 kHz , resulting in a period of $13.0 \mu \mathrm{~s}$.

## Control Functions

Connect an ASCII RS232 terminal to the computer connector, C1, on the LCP. The set up should be:

1. 9600 baud
2. 8 bits.
3. 1 Stop bit.
4. No parity.
5. Terminal $T x$ to Pin 3 of the LCP C1 connector.
6. Terminal Rx to Pin 2 of the LCP C1 connector.

The following steps send ASClI characters to the LCP, which it should interpret as instructions. It will not echo the characters sent, but it should perform the instructions. Refer to Figure 5 for the ASCII equivalent instruction characters.

1. Turn on the LCP.
2. Set the ON-LINE/OFF.LINE switch to ON-LINE.
3. Type ' '.
4. Type!. The ON-LINE LED should illuminate. If the ON-LINE LED does not light at this point, check for the correct inter-
facing of Pins 2 and 3 on the RS232 terminal connector.
5. Type ''. The ON-LINE LED should go back off.

## TERM ADDRESS GENERATION

The purpose of this section is to test the ability of the LCP to uniquely load the bits of the term address. This is done by sending ASCII characters to the LCP and then checking the term address pins of P1.
Send the following lines of characters and check the P1 pins after each.

| CHAR | 1 | 2 | 3 | 4 | 5 | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ! | On-Line - Address at Previous State |  |  |  |  |  |
| SO | H | H | H | H | H | H |
| space | L | L | L | L | L | L |
| A | L | L | L | L | L | L |
| B | L | L | L | L | H | H |
| D | L | L | L | H | L | L |
| H | L | L | H | L | L | L |
| @Q | L | H | L | L | L | L |
| R | H | , | L | L | L | L |
| SO | H | H | H | H | H | H |
| N | H | H | H | H | H | L |
| M | H | H | H | H | L | H |
| K | H | H | H | L | H | H |
| G | H | H | L | H | H | H |
| OR | H | L | H | H | H | H |
| Q | L | H | H | H | H | H |
| S | H | H | H | H | H | H |
| (a) P | L |  | L | L |  | L |
|  |  |  | Line Not | - Ado Itered |  |  |

## VARIABLE ADDRESS GENERATION

The purpose of this section is to test the ability of the LCP to uniquely load and increment the bits of the Variable Address. This is done by sending the appropriate ASCll characters to the LCP and then checking the Term Address pins of P1.
Send each line of characters and check the specified P1 pins after each.

## Low Cost Programmer for PLD 20-Pin Series

AN12

| CHAR | 7 | 8 | 9 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ! | On-Line-Address Same as Previous |  |  |  |  |  |  |
| wo | H | H | H | H | H | H | H |
| space | L | L | L | L | L | L | L |
| a | L | $L$ | L | L | L | L | H |
| b | L | L | L | L | L | H | L |
| d | L | L | $L$ | L | H | L | L |
| h | L | L | L | H | L | L | L |
| space q | L | L | H | L | L | L | L |
| $r$ | L | H | L | L | L | L | L |
| t | H | L | L | L | L | L | L |
| ow | H | H | H | H | H | H | H |
| n | H | H | H | H | H | H | L |
| m | H | H | H | H | H | L | H |
| k | H | H | H | H | L | H | H |
| g | H | H | H | L | H | H | H |
| ov | H | H | L | H | H | H | H |
| u | H | L | H | H | H | H | H |
| s | L | H | H | H | H | H | H |
| w | H | H | H | H | H | H | H |
| A | L | L | L | L | L | L | L |
| owQ | L | L | , | L | L | L | L |
| 1 | L | L | L | L | H | L | L |
| 1 | $L$ | L | L | H | L | L | L |
| 2 | L | L | L | H | H | L | L |
| 2 | L | L | H | L | L | L | L |
| 12 | L | H | L | L | L |  | L |
| Is2 | H | L | L | L | L |  | L |
|  | Off-Line - Address Not Altered |  |  |  |  |  |  |

## Fusing Cycle/Test Mode

Place a jumper from U1 Pin 3 to ground. This enables test mode. Send any data character and the LCP will continuously loop through the fusing sequence. Verify the voltages and timing per Figure 4.
Remove the jumper.

## Pass Through

Turn the LCP ON-LINE/OFF-LINE switch to OFF-LINE.

Connect the Host Computer to the C 1 connector of the LCP and the Terminal to T1 of the LCP. Make certain the Tx and Rx signals of both are associated with the correct LEP RS232 pins on the respective connectors.


CDO4500
Figure A-1. Programming Pin Functions

Type on the terminal keyboard. The computer should behave normally-usually with an echo.

This completes the LCP calibration and checkout.

## APPENDIX A

## HOW TO PROGRAM PLD 20-PIN

 SERIES DEVICESAn PLD device is basically a group of logic functions interconnected to each other by fuses which can be blown to open a circuit, or left intact to make a connection. Each fuse can be identified by its own unique address which consists of a 7-bit Variable Address (ROW ADDRESS) and a 6 -bit Term Address (COLUMN ADDRESS). The programming pin function is the same throughout the 20 -pin series see Figure A-1). Tables A-1 and A-2 are fuse address tables of the PLS153 and PLS159, respectively.
The programming cycle can be separated into four stages:

## Set-Up

1. Set Program Enable ( $V_{P}$ ) to GND
2. Apply Column and Row Address to pins 1-6 and 7-9, 11-15
3. Set STROBE (STB) to $\mathrm{V}_{\mathrm{IH}}$
4. Set PROGRAM/VERIFY (P/V) to $V_{\mathrm{IL}}$
5. Wait $1-50 \mu \mathrm{~s}$
6. Set $V_{C C P}$ to 8.5 V

## To Blow a Fuse

1. Wait $1-10 \mu \mathrm{~s}$
2. Set $P / V$ to $V_{I H}$
3. Wait $1-50 \mu \mathrm{~s}$
4. Set $V_{P}$ to 14.5 V
5. Wait $1-5 \mu \mathrm{~s}$
6. Pulse STB to $\mathrm{V}_{\mathrm{IL}}$ for $10 \mu \mathrm{~s}$
7. Wait $1-5 \mu \mathrm{~s}$
8. Set $V_{P}$ to GND
9. Wait $1-5 \mu \mathrm{~s}$
10. Set P/V to $V_{\text {IL }}$

## To Verify

1. Wait $1-5 \mu \mathrm{~s}$
2. Pulse STB to $V_{\mathrm{IL}}$ for $1-10 \mu \mathrm{~s}$
3. While STB is LOW, OUTPUT (F) will be $V_{\text {IL }}$ for a fuse intact and $2-8.75 \mathrm{~V}$ for a blown füse (note: $F$ is an open-collector, a pull-up circuit may be needed)

## Go To Set-Up for Next Fuse

## Low Cost Programmer for PLD 20-Pin Series

Table A-1. Program Cycle Row/Column Fuse Addressing

| Variable Select Table ${ }^{1}$ |  |  |  | PLS153 |  |  |  | Term Select Table ${ }^{\mathbf{2}}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROWHEX ADDRESS |  | SELECTED VARIABLE |  | ROW HEX ADDRESS |  | SELECTED VARIABLE |  | COLUMNHEX ADDRESS |  | SELECTED PRODUCT TERM |  |
| $\mathrm{I}_{6} \mathrm{I}_{7} \mathrm{~B}_{0}$ | $\mathrm{B}_{2} \mathrm{~B}_{3} \mathrm{~B}_{4} \mathrm{~B}_{5}$ |  |  | $\mathrm{I}_{6} 17 \mathrm{~B}_{0}$ | $\mathrm{B}_{2} \mathrm{~B}_{3} \mathrm{~B}_{4} \mathrm{~B}_{5}$ |  |  | $\mathrm{I}_{0} \mathrm{I}_{1}$ | $\mathrm{I}_{2} \mathrm{I}_{3} \mathrm{I}_{4} \mathrm{I}_{5}$ |  |  |
| 000000000000000000111111 | 0 |  | $\underline{1}$ | 2 | 4 |  |  | 0 | 0 |  | 0 |
|  | 1 |  | 10 |  |  |  |  | 0 | 1 |  | 1 |
|  | 2 |  | $\mathrm{I}_{1}$ |  |  |  |  | 0 | 2 |  | 2 |
|  | 3 |  | $\overline{I_{1}}$ |  |  |  |  | 0 | 3 |  | 3 |
|  | 4 |  | $\mathrm{I}_{2}$ |  |  |  |  | 0 | 5 |  | 5 |
|  | 5 |  | $\overline{I_{2}}$ |  |  | Empty | ddress | 0 | 6 |  | 6 |
|  | 6 |  | $l_{3}$ |  |  |  |  | 0 | 7 |  | 7 |
|  | 7 |  | $\overline{1}$ | F | 1 |  |  | 0 | 8 |  | 8 |
|  | 8 |  | $\mathrm{I}_{4}$ | 2 | F |  |  | 0 | A |  | ${ }^{9}$ |
|  | 9 |  | $\mathrm{I}_{4}$ | 3 | 0 |  | 9 | 0 | B |  | 11 |
|  | A |  | $\mathrm{I}_{5}$ | 3 | 1 |  | 8 | 0 | C |  | 12 |
|  | B |  | $\overline{1}$ | 3 | 2 |  | 7 | 0 | D |  | 13 |
|  |  |  |  | 3 | 3 |  | 6 | 0 | E | Logic | 14 |
|  | C |  | $\underline{1}$ | 3 | 4 | OR | 5 | 0 | F | Terms | 15 |
|  | D |  | $I_{6}$ | 3 | 5 | Array | 4 | 1 | 0 |  | 16 |
|  | E |  | 17 | 3 | 6 |  | 3 | 1 | 1 |  | 17 |
|  | F |  | $\overline{17}$ | 3 | 7 |  | 2 | 1 | 2 |  | 18 |
|  |  |  | B9 | 3 | 8 |  | 1 | 1 | 3 |  | 19 |
|  | 0 |  | $\underline{B_{9}}$ | 3 | 9 |  | 0 | 1 | 4 |  | 20 |
|  |  |  | B9 | 3 | A | Polarity | nable | 1 | 5 |  | 21 |
|  | 2 | AND | $\mathrm{B}_{8}$ |  |  |  |  | 1 | 6 |  | 22 |
|  | 3 | Array | $\mathrm{B}_{8}$ | 3 | 8 |  |  | 1 | 7 8 |  | 23 24 |
|  | 4 |  | $\mathrm{B}_{7}$ |  |  |  |  | 1 | 9 |  | 25 |
|  | 5 |  | $\overline{B_{7}}$ |  |  |  |  | 1 | A |  | 26 |
|  | 6 |  | $\mathrm{B}_{6}$ |  |  |  |  | 1 | B |  | 27 |
|  | 7 |  | $\overline{B_{6}}$ |  |  |  | ddress | 1 | C |  | 28 |
|  | 8 |  | $\mathrm{B}_{5}$ | I | - |  |  | 1 | D |  | 29 |
|  | 9 |  | $\mathrm{B}_{5}$ | 3 | F |  |  | 1 | F |  | 31 |
|  | A |  | $\mathrm{B}_{4}$ |  |  |  |  | 2 | 0 |  | 0 |
|  | B |  | $\overline{B_{4}}$ |  |  |  |  | 2 | 1 |  | 1 |
|  |  |  | $B_{3}$ |  |  |  |  | 2 | 2 |  | 2 |
|  | D |  | $\frac{B_{3}}{}$ |  |  |  |  | 2 | 3 |  | 3 |
|  |  |  | $\mathrm{B}_{3}$ |  |  |  |  | 2 | 4 | Control | 4 |
|  | E |  | $\underline{B_{2}}$ |  |  |  |  | 2 | 5 | Terms | 5 |
|  | F |  | $\mathrm{B}_{2}$ |  |  |  |  | 2 | 6 |  | 6 |
|  |  |  |  |  |  |  |  | 2 | 7 |  | 7 |
|  | 1 |  | $\frac{B_{1}}{B_{1}}$ |  |  |  |  | 2 | 8 |  | 8 |
|  |  |  | B1 |  |  |  |  | 2 | 9 |  | 9 |
|  | 2 |  | $\mathrm{B}_{0}$ |  |  |  |  |  |  |  |  |
|  | 3 |  | $\mathrm{B}_{0}$ |  |  |  |  | 2 | A |  | 0 |
|  |  |  |  |  |  |  |  | 2 | C |  | 2 |
|  |  |  |  |  |  |  |  | 2 | D |  | 3 |
|  |  |  |  |  |  |  |  | 2 | E | Polarity | 4 |
|  |  |  |  |  |  |  |  | 2 | F | Terms | 5 |
|  |  |  |  |  |  |  |  | 3 | 0 |  | 6 |
|  |  |  |  |  |  |  |  | 3 | 1 |  | 1 |
|  |  |  |  |  |  |  |  | 3 | 2 |  | 8 |
|  |  |  |  |  |  |  |  | 3 | 3 |  | 9 |
| NOTES: <br> 1. A row address identifies a particular variable coupled to all product terms. <br> 2. With a variable selected by the row address the column address further selects a coupling fuse for each term |  |  |  |  |  |  |  |  |  |  |  |

Table A-2. Program Cycle Row/Column Fuse Addressing (Continued)

| Variable Select Table ${ }^{1}$ |  |  |  | PLS159 |  |  |  | Term Select Table ${ }^{\mathbf{2}}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROWHEX ADDRESS |  | SELECTED VARIABLE |  | $\begin{aligned} & \text { ROW } \\ & \text { HEX ADDRESS } \end{aligned}$ |  | SELECTED VARIABLE |  | COLUMN HEX ADDRESS |  | SELECTED TERM |  |
| $\mathrm{B}_{1} \mathrm{~B}_{2} \mathrm{~B}_{3}$ | $\mathrm{F}_{0} \mathrm{~F}_{1} \mathrm{~F}_{2} \mathrm{~F}_{3}$ |  |  | $\mathrm{B}_{1} \mathrm{~B}_{2} \mathrm{~B}_{3}$ | $\mathrm{F}_{0} \mathrm{~F}_{1} \mathrm{~F}_{2} \mathrm{~F}_{3}$ |  |  | CLKI ${ }_{0}$ | $\mathrm{I}_{1} \mathrm{I}_{2} \mathrm{I}_{3} \mathrm{~B}_{0}$ |  |  |
| 00 | 0 |  | $\bar{B}_{3}$ | 5 | 0 |  |  | 0 | 0 |  | 0 |
|  | 1 |  | $\mathrm{B}_{3}$ | 5 | 1 |  | $\mathrm{F}_{7} \quad \mathrm{~K}$ | 0 | 1 |  | 1 |
| 00 | 2 3 |  | $\bar{B}_{2}$ | 5 | 2 |  | F6 $\begin{array}{ll} & \mathrm{J} \\ \mathrm{K}\end{array}$ | 0 | 2 |  | 2 3 |
|  |  |  |  |  |  |  | K | 0 | 4 |  | 4 |
| 0 | 4 |  | $\bar{B}_{1}$ $\mathrm{~B}_{1}$ | 5 | $\begin{aligned} & 4 \\ & 5 \end{aligned}$ | Flipflop | $\mathrm{F}_{5} \quad \mathrm{~J}$ | 0 | 5 |  | 5 |
| 0 | 6 7 |  | $\bar{B}_{0}$ | 5 5 | 6 7 | Control <br> Terms | F4 $\begin{array}{ll} \\ & \mathrm{J} \\ \end{array}$ | 0 | 7 |  | 7 |
|  | 7 |  |  |  |  |  | K | 0 | 9 |  | 9 |
| 0 | 8 |  | 1 $i_{3}$ $I_{3}$ | 5 | 8 |  | $\mathrm{F}_{3} \quad \begin{array}{ll}\mathrm{J} \\ \mathrm{K}\end{array}$ | 0 | A |  | 10 11 |
| 0 |  |  |  |  |  |  |  | 0 | C |  | 12 |
|  | A |  | $\mathrm{I}_{2}$ $\mathrm{I}_{2}$ | 5 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ |  | $\begin{array}{lll}\mathrm{F}_{2} & \mathrm{~J} \\ \mathrm{~K}\end{array}$ | 0 | D |  | 13 |
|  |  |  |  |  |  |  | $\ldots$ | 0 | E | Transi- | 14 |
| 0 | C |  | $i_{1}$ | 5 | C |  | $\mathrm{F}_{1} \quad \mathrm{~J}$ | 0 | F | tion | 15 |
|  | D |  | $\mathrm{I}_{1}$ | 5 | D |  | $\mathrm{F}_{1} \quad \mathrm{~K}$ | 1 | 0 | Term | 16 |
| 0 | E | AND | $\mathrm{I}_{0}$ | 5 | E |  | For J | 1 | 1 |  | 17 |
|  | F | Array | 10 | 5 | F |  | $\mathrm{F}_{0} \quad \mathrm{~K}$ | 1 | 2 |  | 18 |
| 2 | 0 |  | $\bar{F}_{0}$ | 6 | 0 |  | $\mathrm{F}_{7}$ | 1 | 4 |  | 20 |
|  | 1 |  | $\mathrm{F}_{0}$ | 6 | 1 |  | $\mathrm{F}_{6}$ | 1 | 5 |  | 21 |
| 2 | 2 |  |  | 6 | 2 |  | $\mathrm{F}_{5}$ | 1 | 6 |  | 22 |
|  | 3 |  | $\mathrm{F}_{1}$ | 6 | 3 | J-K/D | $\mathrm{F}_{4}$ | 1 | 7 |  | 23 |
| 22 |  |  |  | 6 | 4 | Option | $\mathrm{F}_{3}$ | 1 | 8 |  | 24 |
|  | 4 |  | $\mathrm{F}_{2}$ | 6 | 5 |  | $\mathrm{F}_{2}$ | 1 | 9 |  | 25 |
|  | 5 |  | $\mathrm{F}_{2}$ | 6 | 6 |  | $\mathrm{F}_{1}$ | 1 | A |  | 26 |
| 2 | 6 |  |  | 6 | 7 |  | $\mathrm{F}_{0}$ | 1 | B |  | 27 |
|  | 7 |  | $\mathrm{F}_{3}$ | 7 | 1 |  | $\mathrm{B}_{3}$ | 1 | C |  | 28 |
| 2 | 8 |  |  | 7 | 2 | OR | $\mathrm{B}_{2}$ | 1 | D |  | 29 |
|  | 9 |  | F $\mathrm{F}_{4}$ | 7 | 3 | Array | $\mathrm{B}_{1}$ | 1 | E |  | 30 |
|  |  |  |  | 7 | 4 |  | $\mathrm{B}_{0}$ | 1 | F |  | 31 |
| 2 | A |  | F $\mathrm{F}_{5}$ | 7 | 5 | C-Array | $\mathrm{C}_{\mathrm{N}}$ | 2 | 1 | Control Term | PA |
|  |  |  |  | 7 |  | OE |  | 2 | 2 |  | PB |
| 2 | C |  |  |  | 6 |  | EA | 2 | 3 |  | RA |
|  | D |  | $\mathrm{F}_{6}$ | 7 | 8 | Polarity <br> Terms |  | 2 | 4 |  | RB |
| 2 | E |  | $\bar{F}_{7}$ | 7 | A |  | $\mathrm{B}_{1}$ | 2 | 6 |  | LB |
|  | F |  | $\mathrm{F}_{7}$ | 7 | D |  | $\mathrm{B}_{2}$ $\mathrm{~B}_{3}$ | 2 | 7 |  | FC |
|  | F |  | $\mathrm{C}_{\mathrm{N}}$ |  |  |  |  | 2 | 89 | Out- | EA |
|  |  |  |  |  |  |  |  |  |  |  | EB |
|  |  |  |  |  |  |  |  | 2 | C | put |  |
|  |  |  |  |  |  |  |  | 2 | A |  | A EB |
|  |  |  |  |  |  |  |  | 2 | D |  | Polarity |
|  |  |  |  |  |  |  |  | 2 | E | Direc- | $\mathrm{D}_{0}$ |
|  |  |  |  |  |  |  |  | 2 | F | tion | $\mathrm{D}_{1}$ |
|  |  |  |  |  |  |  |  | 3 | 0 | Con- | $\mathrm{D}_{2}$ |
|  |  |  |  |  |  |  |  | 3 | 1 | trol | $\mathrm{D}_{3}$ |
|  |  |  |  |  |  |  |  | 2 | 0 |  | Test Col. 2 |
| NOTES: <br> 1. A row address identifies a particular variable coupled to all product terms. <br> 2. With a variable selected by the row address the column address further selects a coupling fuse for each term. |  |  |  |  |  |  |  | 3 | 2 |  | Test Col. 1 |
|  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |



Figure B-1. PLD 20 Programmer

Table B-1. Baud Rate Generation and UART Control PLD U1 Revision "B" Adds Test Mode

| CODE NO. |  |  | U1 |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  |  |  |  | POLARITY |  |  | REMARKS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{array}{\|l\|} \hline \mathbf{T} \\ \mathbf{E} \\ \mathbf{R} \\ \mathbf{M} \\ \hline \end{array}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 1 |  |  |  | (1) |  | Q(P) |  |  |  |  |  |  |  |  | Q(N) |  |  |  |  |  |  | B(0) |  |  |  |  |
|  | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 |  | 32 | 21 | 0 |  | 7 | 6 | 5 | 4 |  |  |  | 312 | 11 | 0 |  |  | 3 | 21 | 0 |
| 0 | - | - | - |  | - | - | - | - | - |  | - | - | - | - - | - - | - |  | - | - |  | - | - - | - | 0 | - | - - | - |  |  |
| 1 - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | H |  | - | - | - | - | - - | 0 | - | - | $\cdot$ |  |  |  |
| 2 - |  | - | - | - | - | - | - | - | - | - | - | - |  | - | H | H |  |  | - | - | - | 0 | 0 | - |  | - | - | Ggin. | - |
| 3 - | - | - | - | - | - | - | - | - | - | - | - | - | - | - H | H H | H H |  | - | - | - | 0 | 0 | - | - | - | - | - | " | 4 |
| 4 - | - | - | - | - | - | - | - | - | - | - | 2 | - | H | H H | H H | H |  | - | - | 0 | - | -- | - | - | - | - | - | " | * |
| 5 | - | - | - | - | - | - | - | - | - | - | H | 4 |  | H | H H | 4 |  | - | - | - | 0 | - - | - | - | - | - $\cdot$ | - | * | " |
| 6 A | - | - | - | - | - | - | - | - | - | - | H | 4 | L | L 2 | L L | L |  | - | 0 | 0 | 0 | - - | - | - | - | - | - | " | " |
| 70 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | $\bigcirc$ | 0 |  | 0 | 010 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A | A A | A | * | * |
| 8 - | H | - | H | - | L | H | H |  |  | H H | H | H | L | L | L L | L |  | $\llcorner$ | - | - | - | - - | - | - |  | - - | - | " | " |
| 9 | - | - | - | - | L | - | - | - | L | H | H | H | L | L L | L L | $L$ |  | H | - | - | - | - - | - | - | - | - - | - | ser Io | Av (ExT) |
| $10-$ | - | - | - | - | L | - | - | - | L |  |  | - |  | - - | - - | - |  | - | - | - | - | - - | - - | - |  | - $\cdot$ | A | reset | ronu (EXT |
| 110 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 |  | 00 | 00 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | - | A A | A A | A |  |  |
| 12 - | - | - | - | L | H | - | - | - - | H | 4 | H | 1 H |  | $L$ | LL | - 4 |  | $L$ | - |  | - | - - | - | - | - | - | - | Gen I | den (ind.) |
| 13 | - | - | - | H | H | - | - | - | L | H | H | H |  | 22 | しL | $L$ |  | H | - | - | - | -- | - | - | - | - $\cdot$ | - | Reser | Som (int |
| 14 - | - | - | - | H | H | - | - - | - | - | - | - | - |  | - | -- | - |  | - | - | - | - | - - | - | - | - | A | - |  |  |
| 150 | 0 | 0 | $\bigcirc$ | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 00 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A | A A | 4 | test | MODE |
| 16. | - |  | $L$ |  | L | H | H- | - | H | + H | H | H |  | $L$ | $L$ | L |  | $L$ | - | - | - | - | - | - |  | - | - |  |  |
| 170 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | O | 0 | 0 | 0 | $0 \cdot$ | 0 |  | 0 | 0 | 0 | 0 | 010 | 0 | $\bigcirc$ | A $A$ | A A | A |  |  |
| 180 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | 0 | - |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A | A A | A |  |  |
| 19.0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | 010 | 0 |  | 0 | 0 | 0 | $\bigcirc$ | 00 | 0 | 0 | A | $A \cdot A$ | A |  |  |
| 20.0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  | 0 |  | 0 | 0 | 0 | $\bigcirc$ | 00 | 0 | 0 | A $A$ |  | a |  |  |
| 210 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 00 | 0 |  | 0 | 0 | 0 | 0 | 010 | 0 | 0 | A | A A | A |  |  |
| 220 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 00 | 0 | 0 |  | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | A | A A | A |  |  |
| 230 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0.0 |  | 0 | A | A $A$ | A |  |  |
| 240 | 0 | $\bigcirc$ | 0 | 0 | 01 |  | 0 | 0 | $\bigcirc$ | 0 |  | 0 |  | $\bigcirc 0$ | 0 | 010 |  | 0 | 0 | 0 | 0 |  | 0 | 0 | 4 | A A | $A$ |  |  |
| 250 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 |  | 0 | 0 | 0 | 0 | 00 |  | 0 | A | $A \cdot A$ | $\square$ |  |  |
| 260 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | 0 |  | 00 |  | 0 | 0 | 0 | 0 | 010 | 0 | 0 | A | A $A$ | A 0 |  |  |
| 270 | 0 | $\bigcirc$ | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 |  | $\bigcirc$ | 00 | 0 |  | $\bigcirc$ | 0 | 0 | 0 |  |  | 0 | A | A $A$ | $A$ |  |  |
| 28 O | $\bigcirc$ |  | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 |  | 0 | 00 | 0 |  | 0 | 0 | 0 | 0 | 010 | 0 | 0 | A | $A A$ | A |  |  |
| 290 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 |  | 0 | 0.0 | 0 |  | 0 | 0 | 0 | 0 | 00 |  | 0 | A | $A \cdot A$ | A |  |  |
| 300 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 |  |  | 0 |  | 0 | 0 | 0 |  | 0 | 0 | 0 | A | AA | A |  |  |
| 310 | 0 | 0 |  | 0 |  |  | 0 | 0 |  | 0 | 0 | 0 |  |  | 0 | 0 |  | 0 | 0 | 0 | 0 |  | 0 | 0 | A | $A A$ | A |  |  |
| FC O | 0 | 10 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 |  | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  | 1 |  |  |
| PB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | 0 | 0 |  |  |  |  | $11$ |  |  |  | 11 |  |  |  |  |
| RB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | 0 | 00 | 0 |  |  |  |  | , | 1 |  | 11 | 11 | 1 | 1 |  |  |
| LB | 0 | 0 |  | 0 | 0 |  |  | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 |  |  |  |  |  |  |  |  | 11 | 11 | 1 |  |  |  |
| PA | 0 | 0 |  | 00 | 0 |  |  | 20 | 0 | 0 |  | 0 | 0 |  |  | 0 |  | 11 |  | 1 | 11 |  |  | 11 | 11 | 1 | 1 |  |  |
| RA | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 |  | 1 | 1 | 1 | 1 | 1 |  | 1 | 11 | 1 | 1 |  |  |
| LA | 0 | 0 | 0 | 0 | $\bigcirc$ | $\bigcirc$ | 0 | 0 | $\bigcirc$ | 0 |  | $0 \cdot$ |  | 0 | 00 | 0 |  | 11 | 1 | 1 | 11 | 1 | , | 1 | 1 | 1 | 1 |  |  |
| D3 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | $0 \cdot$ |  |  | 11 | 1 | 1 | 1 | , | 1 | 1 |  | 1 | 1 |  |  |
| D2 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 00 | 010 |  | 11 | 1 | 1 | 11 | 1 |  | 1 | 11 |  | 1 |  |  |
| D1 - | - | - | - | - | - | - | - | - |  | - | - | - |  | - |  |  |  |  |  |  | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |
| D0 - | - | - | - | - | - | - | - | - | - | - |  | -- |  | - - | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN | 5 | 4 | 3 | 2 | 9 | 8 | 7 | 6 |  |  |  | 716 |  | 151 |  |  |  |  |  |  |  |  |  | 12 | 9 | 87 | 6 |  | 19 |
|  | $\frac{\overrightarrow{2}}{\mathbf{a}}$ |  | $\frac{1}{2}$ | $8$ | $3$ | $\left\lvert\, \begin{aligned} & \stackrel{\rightharpoonup}{\sum_{\infty}} \\ & \infty \\ & F \end{aligned}\right.$ |  | $\hat{\Delta} \left\lvert\, \begin{aligned} & \overrightarrow{2} \\ & \dot{\alpha} \\ & \hline \end{aligned}\right.$ | $\left.\begin{array}{\|l} \vec{~} \\ \stackrel{\rightharpoonup}{n} \\ \vec{n} \end{array} \right\rvert\,$ |  |  |  |  |  | $\begin{array}{l\|r} 0 & \gamma \\ \cdots & \cdots \end{array}$ |  |  |  |  |  |  |  |  |  |  |  |  |  | 3 |

## Low Cost Programmer for PLD 20-Pin Series

Table B-2. Low Cost Programmer PLD \#U4 Variable Address Generator

| CODE N |  |  |  | U4 |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  | $E_{A}$ |  |  |  | POLARITY |  |  |  | REMARKS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  | - |  |  |  |  |  |  | , |  |  |  |  |  | H | H\| H |  |  |  |  |
| $\begin{aligned} & \hline \mathbf{T} \\ & \mathbf{E} \\ & \mathbf{R} \\ & \hline \end{aligned}$ | AnND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |  |
|  | $c$ | 1 |  |  |  |  | B(1) |  |  |  | $Q(P)$ |  |  |  |  |  |  |  | Q(N) |  |  |  |  |  |  | B(0) |  |  |  |  |  |
|  |  | 3 | 2 | 1 | 0 |  | 3 | 2 |  | 0 | 76 | 65 | 54 | 43 | 32 | 21 | 10 |  | 7 | 6 | 54 |  | 2 | 1 | 10 | 32 | 21 |  | 0 |  |  |
| 0 | - | H | L | 2 |  |  | - | H | - | - | H- | - - | - - | - | - | - | - |  | - | - | - - | - | - | - | 0 | - $\cdot$ | - |  | - | int mode cown |  |
| 1 | - | H | L | L |  |  | - H | H | - | - | H- | - - | - - | - | - | - | L |  | - | - | -- | - | - | 0 | 0 | - | - |  | - | " | " |
| 2 | - | H | L | L |  | - | - | H | - | - H | H- | - | - - |  | - - | L | L L |  | - | - | - - | - | 0 | - | - | A | - |  | - | * | * |
| 3 | - | H | L | L |  |  |  | H | - | - | H- | -- | - - | - | $L$ | LL | L L |  | - | - | - | 0 | 0 | - | - | - |  |  |  | * | * |
| 4 | - | H | L | L | - | - | - | H | - | - H | H- | - - | - - | L | L L | LL | LL |  | - | - | -0 | 0 | - | - | - | - | - |  | - | * | * |
| 5 | - | H | L | L | - | - | - | H | - | - H | H- | - - | -L | $L$ | L L | L2 | L L |  | - | - | 0 - | - | - | - | - | - | - |  | - | " | $\sim$ |
| 6 | - | H | L | L |  | - | - 4 | 4 | - | - | H- | -L | LL | -L | L L | LL | L L |  | - | 0 | -- | - | - | - | - | - • | - |  | - | * | - |
| 7 | - | H | L | $L$ | - | - | - | H | - | - H | HL | L L | L L | $L$ | LL | L L | L L |  | - |  |  | - | - | - | - | - | - |  | A | TERM | OONT |
| 8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 00 | 00 | 00 | 0 | 0 | 00 | 0 |  | 0 | 0 | 00 | 0 | 0 | 0 | 0 | A $A$ | A $A$ |  | A |  |  |
| 9 | - | H | H | H | L | L | - | - | H | H | H- | - | - |  | - | - | - |  | - | - | - - | - | - | - | - L | - $\cdot$ | - |  |  | LOAD | 5075 |
| 10 | - | H | H | H | L | L | - | - | H | - | H- | -- | - - |  | - | - | - |  | - | - | - - |  | - | L | L | . | - |  |  | " | " |
| 11 | - | H | H | 4 | L | L | - | H | - | - | H- | - | -- | - | - - | - - | - |  | - | - | - - | - | L | - | - - | -• | - |  | - | " | " |
| 12 | - | H | H | H | L | L | H | - | - | - H | H- | - - | - - |  | - - | - | - - |  | - | - | - - | - | - - | - | - |  |  |  | - | " | " |
| 13 | - | H | H | H | H | + | - | - | H | H | H- | - | - - | - | - | - - | - |  | - | - | -L | L | - | - | - | - | - |  | - | " | " |
| 14 | - | H | H | H | H | H | - | - | H | - H | $\mathrm{H}_{-}$ | - | - - |  | - | - - | - |  | - | - | L- | - | - | - | - | - | - |  | - | " | " |
| 15 | - | H | H | H | H | - | - | H | - | - H | H- | - - | - - | - | -- | - - | - - |  | - | L | - | - | - | - | - | $\cdot \cdot$ | - |  | - | " | " |
| 16 | 0 | 0 | 0 | $\bigcirc$ | 0 | - | 0 | 0 | 00 | 0 | 0.0 | 0.0 | 00 | 0 | 0 | 00 | 0 |  | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 4 | A A |  | A |  |  |
| 17 | - | H | L | H | $L$ | - | L | L |  | H | - - | -- | - - |  | -- | - | - |  | H | - | -1- | - | - | - | - | - | - |  |  | ONL |  |
| 18 | $=$ | H | L | 1 | $L$ | - | L | L | H: | L | - = | $=$ | $=1$ | - | - | -- | -- |  | 1 | = | -- | - | - | - | - | $\cdots=$ | $=$ |  | = | AFF |  |
| 19 | 0 | 0 | 0 | O | 0 |  | 0 | 0 | 010 | 010 | 00 | 00 | 00 |  | 00 | 00 | 0 |  | 0 | 0 | 0.0 | 0 | 0 | 0 | 0 | $A$ A | AA |  | A |  |  |
| 20 | - | H | H | H | L | L | - | - | -L | L H | H | -- | - - |  | - - | - - | - |  | - | - | -- | - | - |  | H | - $\cdot$ | - |  | - | LOAD | J/K |
| 21 | - | H | H | H | L |  | - | - | L, |  | H- | - | - - | - | - | - - | - |  | - | - | -- | - | - | H | H | - | . |  |  |  | " |
| 22 | - | H | H | H | L | L | -L | L | - | - H | H | - - | -- |  | - | -- | - |  |  |  | - - |  | H | - | - | - |  |  | - | * | " |
| 23 | - | H | H | H | L | L | L | - | - - | H | H- | - - | - - | - | -- | -- | - |  | - | - | -- | H | H- | - | - | - | - |  | - | " | * |
| 24 | - | H | H | H | H | H | - | - | 2 | L | 4- | - | -- |  | - | - | -- |  | - | - | - H | H | - | - | - | - $\cdot$ | - |  | - | " | " |
| 25 | - | H | H | H | H | H | - | - | L | - H | H- | - | - |  | - - | - - | - - |  | - - | - | H- | - | - | - | - | - $\cdot$ | - |  |  | " | " |
| 26 | - | H | H | H | H | 4 | - 1 | L | - | H | H- | -- | - - |  | - | -- | - - |  | - | H | - - |  | - | - | - | $\cdot \cdot$ | - |  | - | " | " |
| 27. | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 010 | 0 | 00 | 00 | 00 | 0 | 0 | 00 | 00 |  | 0 | 0 | 0 O | 0 | 0 | 0 | 0 | $A$ A | $A A$ | A | A |  |  |
| 28 | - | H | H | L | L | - | - | - | - | H | H- | - | - - | - | - - | - - |  |  | - H | H | H H | H | H | H | H | $\cdots$ | - |  |  | TERM | \% ${ }^{\text {a }}$ |
| 29 | - | H | H | L | H | H | - | - | - | - H | H1- | - - | -- |  | -- | - - | - - |  | - H | H | H. H |  | H |  | H | - | - |  |  | term | uppe |
| 30 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 00 | 0 | 00 | 00 | 00 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 |  | 0 | 0 | 0 | A A | A A | A | A |  |  |
| 31 | - | H | L | H | L | - | $L$ | $L$ | L L | L | H- | - - | - |  |  |  |  |  |  | H | H'H |  | H | H | H |  | - |  |  | SYNC | ESET |
| FC | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 00 | $\bigcirc$ | 0 | 00 | 00 |  | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB | $\cdot$ | 0 | 0 | , 0 | 10 |  |  | 0 | 0 |  |  | 00 | 010 |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |
| RB | - | 0 | 0 | $\bigcirc$ | $\bigcirc$ | 0 |  | 0 | 00 | 0 |  | 00 | 010 |  | 0 | 0 | 0 |  |  |  |  | 1 | 1 |  |  | 11 | 1 |  |  |  |  |
| LB | - | 0 | 0 | 0 | 0 | 0 |  | 0 | 00 | 00 | 00 | 00 | 010 | 0 | 0. | 00 | 00 |  | 1 । |  | 1 | 1 |  |  |  | 1 | 1 |  |  |  |  |
| PA | - | 0 | 0 | 0 | - | $\bigcirc$ |  | 0 | 0. | 0 | 00 | 0,0 | 0.0 |  | 0.0 | 0 | 0 |  | 1 | , | 1 | 1 | 1 |  | , | 1 | 1 |  |  |  |  |
| RA | - | 0 | 0 | 0 | 0 |  |  | 0 | 00 |  |  | $0 \cdot$ | 0.0 |  |  | 0 | 00 |  |  |  |  |  | 1 |  | I | 11 | 1 | 1 |  |  |  |
| LA | - | 0 | 0 | 0 | T 0 |  |  |  | 0 |  |  | 0,0 | 0.0 |  | 0 | 00 |  |  | 11 | 1 | 1 | 1 | 1 |  | 1 | 11 | 1 | 1 |  |  |  |
| D3 | - | H |  |  | 4- |  |  |  | - |  |  | - | - |  |  |  |  |  | 1 | T | 1 | 1 | 1 |  |  |  |  |  |  |  |  |
| D2 | - | O | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc 0$ | 0,0 | 00 | 010 | 0 | 0.0 | 00 |  |  | 11 | 1 | 1 | I | 1 | 1 | 1 | $T$ |  |  |  |  |  |
| D1 | - | 0 | 0 | 0 | 0 |  | 0, |  |  | 0 |  | 0,0 | 0,0 |  | 0, | 00 | , 0 |  | 11 | 1 | 1 | 1 | 1 |  | 1 | 11 |  |  |  |  |  |
| D0 | - | H | $L$ |  |  |  | -- |  | - - |  |  | -- | - |  |  |  |  | $\square$ | 19118 |  | 17116 | $15141$ |  |  |  |  |  |  |  |  |  |
| PIN |  | 5 | 4 | 3 | 2 | 9 |  | 8 | 7619 |  | 19181716 |  |  | 15\|14 13112 |  |  |  |  |  |  | 312 |  |  |  | 98 | 87 | 6 |  |  | 10 |
|  |  | $\begin{aligned} & \vec{X} \\ & H \end{aligned}$ |  | $j-u$ |  |  |  |  |  |  | $\begin{aligned} & 3 \\ & 4 \\ & 2 \\ & 25 \end{aligned}$ | $\frac{s}{5} \left\lvert\, \frac{10}{5}\right.$ |  |  |  | $\stackrel{N}{8}$ | $\frac{s}{5} \stackrel{0}{>}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 8 |

Table B-3. Low Cost Programmer PLD \#U4 Variable Address Generator

| CODE NO. |  |  |  | 05 |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS |  | $\frac{E_{B}}{}$ |  |  | $\mathbf{E}_{\mathbf{A}}$ |  |  | POLARITY |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  | - | - | $\bullet$ | $\bullet$ |  |  |  | - |  |  |  |  |  | H |  | H |  |
| $\mathbf{T}$$\mathbf{E}$$R$$\mathbf{R}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $Q(N)$ |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 |  |  |  | B(1) |  |  |  | $Q(P)$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{B}(\mathrm{O})$ |  |  |  |
|  |  | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  | 7 | 6 | 5 | 4 |  |  |  | 3 | 21 | 0 |  | 3 | 21 | 0 |
| 0 | - | H | L | L | - | - | - | - | H | H | - | - | - | - | - | - | - |  | - | - | - | - | - | - | 0 | - | - | - | NTT. MODE CNT. |
| 1 | - | H | L | L | - | - | - | - | - | H | - | - | - | - | - | - | L |  | - | - | - | - | - | - | - | - | $\bullet \cdot$ | - | NOT USED |
| 2 | - | H | L | $L$ | - | - | - | - | - | H | - | - | - | - | - | L | L |  | - | - | - | - | - | - | - | - | - | - | " ${ }^{\circ}$ |
| 3 | - | H | L | L | - | - | - | - | - | H | - | - | - | - | L | L | L |  | - | - | - | - | - | - | - | - | - | - | $\cdots$ |
| 4 | - | H | $L$ | $L$ | - | - | - | - | - | H | - | - | - | $L$ | L | L | L |  | - | - | - | - | - | - | - | - | - | - | * * |
| 5 | - | H | L | L | - | - | - | - | - | H | - | - | L | L | L | $L$ | L |  | - | - | - | - | - | - | - | $\bullet$ | $\bullet$ | - | $\mu$ |
| 6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | A | A | A |  |
| 7 | - | H | H | L | L | - | - | - 1 | H | H | - | - | - | $\cdot$ | - | - | - |  | - | - | - | - | - | - | 4 | - | $\bullet$ | - | LOAD SET |
| 8 | - | H | H | L | $L$ | - | - | H | - | H | - | - | - | - | - | - | - |  | - | - | - | - | - | $-2$ | - | - | - | - | $\sim$ |
| 9 | - | H | H | $L$ | L | - | H | - | - | H | - | - | - | - | - | - | - |  | - | - | - | - | - | L | - | - | $\bullet$ | - | " |
| 10 | - | H | H | L | L | H | - | - | - | H | - | - | - | - | - | - | - |  | - | - | - | - | L | - - | - | - | - | - | $\cdots$ |
| 11 | - | H | H | L | H | - | - | - H | H | H | - | - | - | - | - | - | - |  | - | - | - | L | - | - | - | $\bullet$ | $\bullet$ | - | $*$ |
| 12 | - | H | 4 | L | H | - | - | H | - | H | - | - | - | - | - | - | - |  | - | - | L | - | - | - | - | - | $\bullet$ | - | 4 |
| 13 | 0 | 0 | O | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | A | A | A |  |
| 14 | - | H | L | H | L | $L$ | $L$ | L $H$ | H | - | - | - | - | - | - | - | - |  | H | - | - | - | - | - | - | - | - | $\bullet$ | ON LINE |
| 15 | - | H | L | H | L | $L$ | $L$ | H. | L | - | - | - | - | - | - | - | - |  | L | - | - | - | - | - | - | - | - | - | OFF LINE |
| 16 | O | $\bigcirc$ | O | 0 | 01 | 0 | 0 | 0 | 0 | 0 | 10 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 010 | 0 | A | A | A |  |
| 17 | - | H | H | L | L | - | - | - | L | H | - | - | - | - | - | - | - |  | - | - | - | - | - | - - | H | - | - | - | LOAD RESE |
| 18 | - | H | H | $L$ | L | - | - | L | - | H | - | - | - | - | - | - | - |  | - | - | - | - | - | - H | - | - | $\bullet$ | - | " * |
| 19 | - | H | H | L | L | - | L | - | - | H | - | - | - | - | - | - | - |  | - | - | - | - | - | +1- | - | - | - | - | " " |
| 20 | - | H | H | L | L | L | - | - | - | H | - | - | - | - | - | - | - |  | - | - | - | - | H | - | - | - | $\bullet$ | - | " |
| 21. | - | H | H | L | H | - | - | -L | L | H | - | - | - | - | - | - | - |  | - | - | - | H | - | - | - | - | $\bullet$ | - | " |
| 22 | - | H | H | L | H | - | - | L | - | H | - | - | - | - | - | - | - |  | - | - | H | - | - | - - | - | $\cdot$ | $\bullet$ | $\bullet$ | $\cdots$ |
| 23 | 0 | 0 | 0 | 0 | 0 | 010 | 0 | 00 | 0 | 0 | 0 | 0 | 01 | 0 | 0 | 0 | 0 |  | 01 | 0 | 0 | 0 | 0 | 00 | 0 | A | A | A |  |
| 24 | - | H | L | $L$ | - | - | - | - H | H | H | - | - | - | - | - |  | L |  | - | - | - | - | - | -0 | - | - | - | - | INT. MODE COWN |
| 25 | - | H | L | $L$ | - | - | - | - | H | H | - | - | - | - | - | L | $L$ |  | - | - | - | - | - | O- | - | - | - | - | $\cdots$ |
| 26 | - | H | L | $L$ | - | - | - | - 1 | H | H | - | - | - | - | L | $L$ | $L$ |  | - | - | - | - | 0 | - | - | - | - | $\bullet$ | $\cdots$ |
| 27 | - | H | L | L | - | - | - | - H | H | H | - | - | - | L | L | L | $L$ |  | - | - | - | 0 | - | - | - | - | - | - | $\because *$ |
| 28 | - | H | L | $L$ | - | - | - | $-\mathrm{H}$ | H | H | - | - | L | L | L | $L$ | L |  | - | - | 0 | - | - | - | - | - | - | - | $"$ |
| 29 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | O | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | A | A | A | * $\quad 4$ |
| 30 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0. | $\bigcirc$ | 0 | 0 | 0 | 00 | 0 | A | $A$ A | $A$ |  |
| 31 | - | H | L | H | L | $L$ | L | L L | $L$ | H | - | - | - | - | - | - | - |  |  | H | H | H | H | H H | H | - | - | - | SYAC. RESET |
| FC | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |
| PB | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  | $1$ | 11 |  |  | 1 |  |  |  |
| RB | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\bigcirc$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  | $1$ |  | $11$ | 1 | 1 |  |  |
| LB | - | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  | 11 | 1 |  |  |  |
| PA | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 1 | 1 |  | 1 | 11 |  | $11$ | $1$ |  | 1 |  |
| RA | - | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  | $11$ | $1$ | $11$ | $1$ |  | 1 |  |
| LA | - | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  | $1$ |  | 1 |  |
| D3 | - | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  | 1 |  |
| D2 | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | 1 |  |  |  |  | $1$ |  |  | 1 |  |
| D1 | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 1 | 1 |  | 1 | 11 |  | 1 |  |  |  |  |
| D0 | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  | - |
| PIN |  | 5 | 4 | 3 | 2 | 9 | 8 | 76 | 6 | 19 | 18 | 17. | 16 | 15 | 14 | 13 | 12 |  | 19 | 18 |  | 16 | 15 | 1413 | 12 | 9 | 8 | 6 | 19 |
|  |  | $\underset{H}{\underset{\sim}{\underset{~}{2}}}$ | $\begin{aligned} & N \\ & U \end{aligned}$ | $\bar{U}$ | $\mathrm{C}^{\mathrm{N}}$ | $\underset{\sim}{N}$ | $\begin{aligned} & N \\ & \mathbf{N} \end{aligned}$ |  |  | $\begin{aligned} & \dot{3} \\ & \frac{4}{3} \\ & \frac{3}{3} \end{aligned}$ | $\frac{ \pm}{2}$ | $\stackrel{10}{5}$ | $\pm$ | $\stackrel{M}{2}$ | $\stackrel{N}{\sim}$ | ¢ | $\frac{8}{8}$ |  |  |  |  |  |  |  |  |  |  |  |  |

Table B-4. Low Cost Programmer PLD \#U2B Revision '3' Data Register

| CODE NO. |  |  |  | U2B |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  | $\frac{E_{\mathbf{A}}}{\mathbf{A}}$ |  |  | POLARITY |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | A $A$ | A $A$ | A $A$ \| |  |  | A\|A |  |  | H | H\|H |  |  |  |  |  |  |  |  |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |
|  | c |  |  |  |  |  | 1 |  | B(1) |  |  |  |  | Q(P) |  |  |  |  |  |  | O(N) |  |  |  |  |  |  | B(0) |  |  |
|  | c | 3 | 2 | 21 | 10 | 3 | 2 | 21 | 0 | 07 | 716 | 65 | 54 | 3 | 2 | 1 | 0 |  | 7 | 6 | 54 | 43 | 32 | 21 | 1 | 3 | 21 | 0 |  |
| 0 | - | - | - | - | - | - | - | - | - - | - | - | - | - | L | - | - | - |  |  | - | - | - | - | - - | - - | - |  | - |  | A | 81+ $\phi$ OUT |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 010 | 00 | 00 | 0 | A | A A | A |  |
| 2 | - | H |  | L L | L |  | - | H | H- | - | - H | H | - - | - | - | - |  |  | H | - | - | - - | -- | - - |  | - | - | - | SHIFT Down |
| 3 | - | H |  | L L | L | - | - | - | H- | - | - - | - H | H- | - | - | - | - |  | - | H | - | - - | - - | - - | - | - | - | - | " |
| 4 | - | H |  | $L$ | $L$ | - | - | H | H- | - | - - | - - | - H | - | - | - | - |  | - | - | H | - | - - | - | - | - | - | - | " |
| 5 | - | H. | L | L L | L |  | - | - H | H- | - H | H - | - | - | - | - | - | - |  | - | - | H | H | - - | - - | - | - | - | - | " |
| 6 | - | H |  | $L L$ | L |  |  | - H | H- | - | - | - | - | - | H | - | - |  | - | - | - | H | H | - - | - |  | - | - | * * |
| 7 | - | H | L | LL | L |  | - | - H | H- | - | -- | - | - - |  | - | H | - |  | - | - | - | - | - H | H- | - |  | - | - | " ${ }^{\prime}$ |
| 8 | - | H |  | LL | L | - |  | H | H- | - | - | - | - | - |  | - | H |  | - | - | - - | - | - | H | - | - | - | - | - |
| 9 | - | H |  | LL | - - | - | - | - H | H- | - | - | -- | - | H | - | - | - |  | - | - | -- | - - | - - | $-1-$ | - H | - | - - | - | " |
| 10 | 0 | $\bigcirc$ |  | 00 | 00 | 0 | 0 | 0 | 00 | 0 | 010 | 00 | 00 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 00 | 00 | 00 | 0 | A | $A A$ | A | - " |
| 11 | - | H |  | L | L- | H | H | HL | L- | - | - | - | - - |  | - - | - | - |  | L | - | -- | - - | - - | - - | - | - | - $\cdot$ | - | VARIFT IN |
| 12 | - | H |  | -L | - - | L | - H | HL | L- | - - | - | - | - | - | - | - | - |  | H | - | - | - - | -- | - - | - | - | - | - | " |
| 13 | 0 | 0 | 0 | 0 | $\bigcirc 0$ | 0 | 0 | 0 | 00 | 0 | 010 | 00 | 0 | 0 | 0 | 0 | 0 |  |  | 0 | 0 | 00 | 00 | 00 | 0 | A | A A | A A |  |
| 14 | A | H | L | L L | L- | - | - | - | H- | - - | - | - - | - | - | - | - | - |  | - | - | - - | - | -- | - - | - | - | - - | - | SHIITTENABLE |
| 15 | 0 | 0 |  | 0 | 0 | 0 | 0 | 00 |  | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 00 | 00 | 0 | 0 | A | A A | A |  |
| 16 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 00 | 00 | 00 | 0 | A | AA | 4 |  |
| 17 | 0 | 0 |  | 0 | 0 | 0 | 0 | 00 | 00 | 00 | 010 | 00 | 010 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 0 | 0 | 010 | 0 | A | $A$ | A |  |
| 18 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 010 | 00 | 0 | 0 | 0 | $\bigcirc$ | 0 |  | 0 | 0 | 00 | 0 | 00 | 00 | 0 | A | A $A$ | 4 |  |
| 19 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 0 | 010 | 00 | 0.0 | 0 | 0 | 0 | 0 |  | 0 | 00 | 00 | 010 | 00 | 00 | 0 | A | $A$ A | $A$ |  |
| 20 | 0 | 0 |  | 010 | 00 | 0 | 0 | 0 | 00 |  | 0 | 00 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 0 | 00 | 0 | 0 | A | $A \cdot$ | A $A$ |  |
| 21. | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 010 | 00 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 00 | 0 | 00 | 00 | 0 | A | A A | A |  |
| 22 | 0 |  |  | 0 | 00 | 0 | 0 | 0 | 00 | 0 | 0.0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 00 | 0 | 0 | A | $A A$ | A A |  |
| 23 | 0 |  | 0 | 0 | 00 | 0 | 0 |  |  | 010 | 0 | 00 | 0 | 0 | 0 |  | $\bigcirc$ |  | 0 | 0 | 0 | 0 | 00 | 00 | 0 | A | $A A$ | A |  |
| 24 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 010 | 0 | 010 | 001 | 0 |  | 0 | 0 | - |  | 0 | 0 | 00 | 0 | 00 | 0 | $\bigcirc$ | A | A A | $A$ |  |
| 25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 00 | 00 | 0 | 0 | 0 | 0 | $\bigcirc$ |  | 0 | 0 | 00 | 0 | 0 | 0 | 0 | A | A A | A |  |
| 26 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 00 | 0 | 0 | 0 | 00 | 0 | 00 |  | 0 |  |  | 0 | 00 | 0 | 00 | 00 | 0 | A | A A | $A$ |  |
| 27 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 |  | 0 | 0 |  | 0 | 00 | 0 | 0 | A | A A | $A$ |  |
| 28 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 010 | 0 | 0 | 00 | 0 | 0 |  | 0 | 0 |  | 0 | 0 | 00 | 0 | 0 | 0 |  | $A$ | AA | A |  |
| 29 | 0 |  |  |  | 00 | 0 | 0 | 0 | 00 | 0 | 0 | 01 | 00 | 0 | 0 | 0 | 0 |  |  | 0 | 0 | 010 | 0 | 00 | 0 | A | A A | $A$ |  |
| 30 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 00 | 0 | 0 | 000 | 0 | 0 | 0 |  | 0 |  | 0 | 0 | 00 | 0 | 00 | 00 | 0 | A | A $A$ | A $A$ |  |
| 31 | - | H | L | L | HL | - | - | - | - - | - | - | - - | - | - | - |  | - |  | H | H | H H | H | H H | H | H |  | - $\cdot$ |  | Syne reser |
| FC | - | - | - | - | - | - | - | - | - - | - | - | - - | - | - | - | -1 |  |  |  |  |  |  |  |  |  |  | 1 |  |  |
| PB | - |  | 10 |  | 010 | 0 | 0 | 0 | 010 |  | 00 | 001 | 010 | 0. | 0 | 010 | 0 |  |  |  |  |  |  |  | , |  | 1 |  |  |
| RB | - | 0 |  | 0 | 0 |  | 0 |  |  |  | 0 | 00 | 00 |  |  | 0 |  |  |  |  |  | 1 |  |  | 1 |  | 1 | 1 |  |
| LB | - | 0 | 0 |  | $0 \cdot$ | 0 | 0 | 0 | 00 | 0 | 00 | 0.0 | 00 |  | 0 | 010 |  |  | 11 | I | 1 | 1 |  |  |  | 11 | 1 | 1 |  |
| PA, | - | 0 | , 0 | 0 | 0 |  |  |  | 0,0 | $\bigcirc$ | 010 | 00 | $00^{0}$ |  | 0 | 0 | 0 |  | 11 | 1 |  |  |  |  |  | 1 | 1 | 1 |  |
| RA | $\bullet$ | 0 | 0 | 0 | 0 | 0 | 0 | 010 | 00 | 0 | 0 | 00 | 0 | 0 | 0 | 00 |  |  |  | 1 |  | 1 | 1 |  | 1 | 11 | 1 | 1 |  |
| LA | - | H |  | H | H | - | - | - | - | - - | - | - | - | - | - |  |  |  | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |
| D3 | - | 0 | 10 | 0 | 0 | 0 | 0 |  | 00 | 0 | 0 | 0.010 | 010 |  |  |  |  |  | 11 | 1 | , | 1 | 1 | 1 | 1 |  | 1 | 1 |  |
| D2 | - | 0 | 0 |  | - 0 | 0 | 0 | 0 | 00 | 0 | 0 | 0. | 0 |  |  |  |  |  | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  | 1 |  |
| D1 | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 0 |  |  | 0 |  |  | 11 | 1 |  |  |  |  |  |  |  |  |  |
| DO |  | H | L | L | -- | - |  | - | -- | - | - | - - | - | - | - - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN |  | 5 | 4 | 3 | 32 | 9 | 8 | 3 | 76 | 619 | 918 | 81171 | 7161 | 151 |  |  | 12 |  |  |  |  | 16.15 |  |  |  | 9 | 87 | 6 | 18 |
| 号 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Table B-5. Low Cost Programmer PLD \#U6 Revision "B' Results in New Timing Figures


## Low Cost Programmer for PLD 20-Pin Series

Table B-6. Low Cost Programmer Parts List

| REF. DES. | QUANT. | DESCRIPTION | RADIO SHACK\# |
| :---: | :---: | :---: | :---: |
| Resistors |  |  |  |
| R1 <br> R2 <br> R3, R5 <br> R14, R15 <br> R4, R6 <br> R7 <br> R8 <br> R9 <br> R10 <br> R11 <br> R12* <br> R13 <br> RN1 | 1 1 2 2 2 1 1 1 1 1 1 1 1 | 100 1 1/4W 5\% 620 ${ }^{1 / 4 W} 5 \%$ $1 \mathrm{~K} \Omega 1 / 4 \mathrm{~W} 5 \%$ 270 $1 / 4 \mathrm{~W} 5 \%$ $1.8 \mathrm{~K} \Omega 1 / 4 \mathrm{~W} 5 \%$ 39 (1/4W 5\% $3.3 \Omega 1 / 4 \mathrm{~W} 5 \%$ 120 $1 / 4 \mathrm{~W} 5 \%$ 75 $\Omega$ 1/4W 5\% 47 $\Omega$ 1/4W 5\% 1K $\Omega$ 1/4W $5 \%$ $10 \mathrm{~K} \Omega 1 / 4 \mathrm{~W} 5 \%$ $10 \mathrm{~K} \Omega 1 / 4 \mathrm{~W} 5 \% 8$-Pin SIP | $\begin{gathered} 271-1421 \\ 271-1324 \\ \\ 271-1307 \\ 271-023 \end{gathered}$ |
| Capacitors |  |  |  |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2, \mathrm{C} 4 \\ & \mathrm{C} 3 \\ & \mathrm{C} 6, \mathrm{C} 7 \\ & \mathrm{C} 5, \mathrm{C} 8-\mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \\ & 1 \\ & 2 \\ & 7 \end{aligned}$ | ```0.047\mu\textrm{F} 4700\mu\textrm{F}\mathrm{ Elec. 35V Axial} 220\muF Elec. 35V Axial 470\muF 0.01\muF``` | $\begin{aligned} & 272-1022 \\ & 272-1017 \end{aligned}$ |
| Diodes |  |  |  |
| $\begin{aligned} & \text { D1A } \\ & \text { D1B } \\ & \text { D2 } \\ & \text { D3, D4 } \\ & \text { DB1, DB2 } \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 2 \\ & 2 \end{aligned}$ | 6.2V Zener 1N4735 <br> 9.1V Zener 1N4739 <br> 1N4001 <br> 10mA Red LED <br> 1.4A Full-Wave Bridge | $\begin{gathered} 276-561 \\ 276-563 \\ 276-1101 \\ 276-041 \\ 276-1151 \end{gathered}$ |
| Voltage regulators |  |  |  |
| $\begin{aligned} & \text { VR1 - VR3 } \\ & \text { VR4 } \end{aligned}$ | $\begin{aligned} & 3 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { LM317 TO-220 } \\ & 7805 \text { TO-3 } \end{aligned}$ | 276-1778 |
| Integrated circuits |  |  |  |
| U1, U2, U3 | $\begin{aligned} & 5 \\ & 1 \end{aligned}$ | PLS1591FL — Codes Req'd AY-3-1015 UART | 276-1794 |
| Transformers |  |  |  |
| $\begin{aligned} & \mathrm{T} 1, \mathrm{~T} 2 \\ & \mathrm{FB} 1 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { 18.0VAC CT, 2A } \\ & \text { Ferrite Bead FB-75B-01 } \\ & \text { Amidon Associates } \end{aligned}$ | 273-1515 |
| Transistors |  |  |  |
| $\begin{aligned} & \mathrm{Q} 1-\mathrm{Q} 4 \\ & \mathrm{Q} 5 \end{aligned}$ | $\begin{aligned} & 4 \\ & 1 \end{aligned}$ | 2N2222 Transistors <br> TIP 120 Power Dar. | 276-2009 |

## APPENDIX C




# Signetics 

Application Specific Products

## INTRODUCTION

The Field-Programmable Logic Sequencer PLS159 may be a self-contained system except that it requires a system clock which is generally provided by an external source. Using a simple R-C network, two bidirectional I/O pins, one can make a simple oscillator which can provide a clock frequency up to 7 MHz (typical) with a pulse width of about 75 ns . The frequency of oscillation is set by adjusting the RC network, or by adjusting a reference voltage, V . The circuit is shown in Figure 1. This circuit may be used to clock the flip flops on the same chip, or provide a clock for a bigger system. While this circuit uses only two AND-terms and one control term, the rest of the chip may be used for other circuits.

Initially, the capacitor has zero charge and thus is at zero volt. Output is also at a Low, which disables the tri-state buffer. As the capacitor is being charged up, its voitage increases. At about 1.6 V , the non-inverting input buffer begins to turn on. One propagation delay later, the output goes High, which enables the tri-state buffer after another propagation delay. Since the tri-state buffer is unconditionally programmed to a Low, it be-
gins to discharge the capacitor at a fast rate. As the input voltage to the non-inverting buffer drops below 1.6 V , the buffer begins to change state. One propagation delay later, output goes Low, which disables the tri-state buffer after another propagation delay. The R-C network is ready to start all over again.

To implement this circuit, we first choose $B_{1}$ to input voltage from the RC network and $B_{0}$ to be the output pin. As shown in Table 1, we enable the output $\mathrm{B}(\mathrm{O})_{0}$ by "dashing out" the AND-term $D_{0}$, make the output non-inverting by programming POLARITY " H " and connect it to term-0 by entering an $A$ in column $B(O)_{0}$ term- 0 . We then program an H in $\mathrm{B}\left(\mathrm{I}_{1}\right.$, term-0 to connect the non-inverting input of $\mathrm{B}_{1}$ to term-0. Since we don't need the rest of the inputs and outputs, we "dash out" all other input entries and "dot out" all unused outputs in term-0. To create a Low output on $\mathrm{B}(\mathrm{O})_{1}$, we may either have a Low input on the OR and have the output non-inverted, or have a High on the input of OR and have the output inverted to produce a Low. We will arbitrarily use the second method. Here we dash out all inputs and outputs in term-1 except $\mathrm{B}(\mathrm{O})_{1}$ which is programmed an $A$. We then program the POLARITY of $B(O)_{1}$ " $L$ " to be inverting.


Figure 1. R-C Network Circuit

Finally we program an $H$ in $B()_{0}$ and term- $D_{1}$ and dash out all unused inputs so that when $\mathrm{B}(\mathrm{O})_{0}$ becomes High, $\mathrm{D}_{1}$ will enable the output buffer $\mathrm{B}(\mathrm{O})_{1}$. The program is further illustrated by Figure 2.
Since the High output pulsewidth is about two propagation delays of $B_{1}$ to $B_{0}$, it is wide enough to drive the clock input of the PLS159. If a square wave is desired, one of the flip flops may be programmed to toggle, as shown in Table 1, term-4, in which case the output frequency of the square wave is half that of $\mathrm{B}(\mathrm{O})_{0}$.
The stability of the output frequency can be controlled by:

1. Making V a stable voltage source,
2. making the charging current of the RC network much greater than the input current of $\mathrm{B}(1)_{1}$ (see Figure 4 for input current characteristics),
3. making the period of oscillation mich greater than four times the internal propagation delay (typical $t_{P D}=35 \mathrm{~ns}$ ).
Recommendations:
a) Use capacitance less than 500pf.
b) Choose $R$ such that $V / R \gg I_{\text {IL }}$ (since $I_{L L}=-100 \mu \mathrm{~A}$, worst case, over temperature range, V/R may be 1 mA , for example).
The recommendations above put a limit to the range of frequency winich the PiSi59 may operate in exchange for stable operating frequency. One may extend its range by reducing $C$ to zero (remove the capacitor) and thus operate the circuit at its maximum frequency, or increase the resistance to infinite (remove the resistor), and let the external capacitor be charged by the input current $\mathrm{I}_{\mathrm{L}}$, which gives a much lower frequency.

## Table 1. PLS 159 FPLS Program Table



## COMMENTS:

1. $D_{1}$ is controlled by $B(1)_{0}$, which enables $B(O)_{1}$ when $B(O)_{0}$ outputs a High. 2. $Q(N)_{-0}$ is programmed as $J-K$ flip-flop, and will toggle automatically at each rising-edge of the clock. NOTE:
2. In order for the flip-flop to work the clock out ( $\mathrm{B}_{\mathrm{O}}$ ) must be externally connected to pin 1.


Figure 2. Logic Diagram of Oscillator Circuit

[^22]


# Latches and Flip-Flops With PLS153 

Application Note

## Application Specific Products

## DESCRIPTION

Using the simple AND, OR and INVERT logic functions of the PLS153, memory functions such as latches and edge-triggered flip-flops may be implemented with a relatively small part of the chip and without external wiring. In this application note, we will discuss the implementation of two R-S latches, a D-latch, an edge-triggered R-S flip-flop, and an edgetriggered D flip-flop.

## INTRODUCTION TO PLS153

To implement this function, let's first take a look at the PLS153 logic diagram and its programming table as shown in Appendices A and $B$. On the left side of the logic diagram (Appendix $A$ ) are eight dedicated inputs, $l_{0}$ to $\mathrm{I}_{7}$, each of which has a true and a complement output. Each output is connected to the inputs of 32 AND functions (we will call them AND-terms from now on), the outputs of which are, in turn, connected to the inputs of ten OR functions. The output of each OR function is connected to one input of an Exclusive-OR function, which is in turn connected to a non-inverting output buffer. The function of the XOR is to control the output polarity. The output, in its virgin state, is noninverting, since one side of the XOR is
connected to ground by the fuse $X_{n}$, where $\mathrm{n}=0,1,3 . .9$. To have the output inverted, one needs only to blow fuse $X_{n}$ open so that the $X_{n}$ input is unconditionally High. The output buffers are ail three-state buffers which may be enabled or disabled by their corresponding AND gates. The output buffers are disabled in their virgin state. All pins labeled " B " are bidirectional. Input buffers of the " $B$ '. pins are identical to those of the " $I$ " pins.
The programming table shown in Appendix B emulates a truth table. All the inputs to the device are positioned on the left side, and all the outputs are on the right side. Each row in the table corresponds to an 18 -input ANDterm with up to ten outputs. On the left side, or the input side of the table, each column represents an input. The 18 columns represent input buffers $I_{0}$ to $I_{7}, B_{0}$ to $B_{9}$. To distinguish between inputs and outputs of the bidirectional pin, $\mathrm{B}(\mathrm{I})$ is used for input and $B(O)$ is used for outputs as shown in the programming table. On the right side of the table, each column represents an output circuit $\left(B(O)_{0-9}\right)$ which consists of an OR gate, an XOR, and a non-inverting three-state buffer. The output buffers are controlled by AND-terms $D_{0}$ to $D_{9}$, the inputs of which may be connected to any number of the 18 inputs.

The polarity of the outputs is defined by the POLARITY entries which are on the upper right corner of the programming table.

To program the inputs to the AND-terms, an " H " will cause the fuse of the inverting input buffer to be blown, leaving the non-inverting buffer connected to the AND-term; an 'L'" will do the opposite. A " - " will cause both fuses to be blown, and therefore the programmed input is a "Don't care". A " 0 ", the virgin state of the device, has both fuses intact, which causes the output of the ANDterm to be unconditionally Low.

To program the outputs, a "." causes the fuse that connects the output of AND-term to the input of an OR to be blown and thus renders the output inactive. $A n$ " $A$ " causes the fuse to remain intact and thus the output is active.

The output polarity of each output buffer may be programmed by entering an " H " or an " L " in the POLARITY section. An "L" causes the XOR to blow its grounding fuse and become inverted, whereas an " H " leaves the fuse intact and the output is non-inverted.

To AND several inputs, we put them in a row; to OR several inputs, we put them in different rows, as shown in illustrations in Appendix B.

## SIMPLE R-S LATCH

A simple R-S latch may be formed by crosscoupling two NAND functions together as shown in Figure 1.

As an illustration, let's assign the input $R$ to $I_{0}$ of the PLS153, input $S$ to $I_{1}$, output $Q$ to $B_{0}$, and output $\bar{Q}$ to $B_{1}$. As shown in Table 1, to form the NAND gates we need to program the POLARITY Low on $\mathrm{B}(\mathrm{O})_{0}$ and $\mathrm{B}(\mathrm{O})_{1}$. To unconditionally enable the output buffers, we "dash" out all inputs to $D_{0}$ and $D_{1}$. As for the inputs, we put an " H " on $\mathrm{I}_{0}$, term-0 for the input R, non-inverted; another " H " on $\mathrm{B}(\mathrm{I})_{1}$, term- 0 for the feedback from $Q$. In the same manner, we program $1_{1}$, term-1 and $B(O)_{0}$ " H '". The POLARITY, rows $0,1, \mathrm{D}_{0}$ and $\mathrm{D}_{1}$, forms a "truth table" with which one can analyze his own or someone else's design. The program in Table 1 may be illustrated as shown in Figure 2.


## Latches and Flip-Flops With PLS153

Table 1. PLS153/153A Programming Table

| CODE NO. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REMARKS | POLARITY |  |  |  |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | L $/ 2$ |  |
| $\begin{array}{\|c\|} \hline T \\ E \\ R \\ \hline \end{array}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | OR |  |  |  |  |  |  |  |
|  |  |  |  | 1 |  |  |  | B(1) |  |  |  |  |  |  |  |  |  | B(0) |  |  |  |  |  |  |  |
|  | 7 | 6 | 5 | 43 | 32 |  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 10 |  | 9 | 87 | 6 | 514 | 312 | 21 | 10 |  |
| 0 | - | - | - | -1- | - | - - | - H | - | -1 | - | - | - | $-1$ | - | - | H- |  |  | - | - | - | - | 10 | - $\bullet$ | - A | $Q=/(R \cdot \bar{Q})$ |
| 1 | - | - | - | $-1-$ | - - | - H | H- | - | - | - | - | - | - | - | - | - H |  | - | ${ }^{-1}$ | $\cdot$ | - $\cdot$ | ${ }^{\circ}$ | A | A $\cdot$ | $\bar{Q}=/(S \cdot Q)$ |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  | , |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  | , |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |
| D88 |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 11 1 | 11 | $1 \begin{array}{lll}1 & 1 \\ 1\end{array}$ | 111 | 1 | 1 |  |
| D7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 T | 1 | 11 | 1 | 1 |  |
| D6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 | 11 | 1 | 1 |  |
| D5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 11 |  | 11 | 11 |  | 1 |  |
| D4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 |  |  | 1 |  |
| D3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 | 11 |  |  |  |
| D2 | - | - | - |  |  | - - | - - | - |  |  | - | - |  |  | - | - |  |  | 11 | 11 | 11 | 11 | 1 |  |  |
| D0 | - | - | - |  |  | - | -- | - |  |  | - | - |  |  |  |  |  |  | 11 | 11 | 11 | 11 | 1 |  |  |
| PN | 8 | 7 | 6 | 54 | 43 | 32 | 21 | 119 | 18 | 17 | 16 | 15 |  |  |  | 119 |  |  | 1817 | 716 | 1514 | 1312 | 211 | 119 | 4 |
|  |  |  |  |  |  |  | $\infty \times$ |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  | (1) | \% |

## ANOTHER SIMPLE R-S LATCH

Another way to implement a simple latch is shown in Figure 3, in which two NOR functions are cross-coupled to form a latch.

As with the previous example, we first define the input and output pins. For this example, we use $I_{2}$ for the $R$ input, $I_{3}$ for the $S$ input, $B_{2}$ for the $Q$ output, and $B_{3}$ for the $\bar{Q}$ output. We program $B_{2}$ and $B_{3}$ to have inverted outputs by programming POLARITY of $B_{2}$ and $B_{3}$ Low, as shown in Table 2. Terms 6 and 7 are ORed together by $\mathrm{B}(\mathrm{O})_{2}$, rows 6 and 7. In the same manner $\mathrm{B}(\mathrm{O})_{3}$ ORs Terms 8 and 9 . The programmed table of this design may be represented as shown in Figure 4.

Since each AND-term of the PLS153 can accommodate up to 18 inputs (true or inverting inputs of eight from $I_{0}$ to $I_{7}$ and ten from $\mathrm{B}_{0}$ to $\mathrm{B}_{9}$ ), and each OR circuit can be connected to up to thirty-two AND-terms, we can add additional features such as those shown in Figure 5.

The programming of this design is left to the reader as an exercise


Figure 3. RS Latch


Figure 4. RS Latch


LS01740S

Figure 5. RS Latch

Table 2. PLS153/153A Programming Table


## D-LATCH

A simple D-latch can be constructed with an PLS153 as shown in Figure 6.

This circuit may be easily programmed into the PLS153 as shown in Tabie 3. The program may, in turn, be represented as shown in Figure 7.
This circuit may be expanded to have multiple D-latches using the same latch enable (LE).


Figure 6. D Latch

## R-S FLIP-FLOP

Two R-S latches may be combined to form a master-save flip-flop that is triggered at the rising-edge of the clock (or the falling-edge of the clock, if the designer so desires). Figure 8 shows a combination of two sets of crosscoupled NOR gates concatenated to form the flip-flop. The implementation of this circuit using PLS153 is as illustrated in Table 4 and Figure 9.


LS01770S
Figure 8. RS Flip-Flop


Figure 9. RS Flip-Flop

Latches and Flip-Flops With PLS153

Table 3. PLS153/153A Programming Table


Table 4. PLS153/153A Programming Table


## D FLIP-FLOP

An edge-triggered master-slave $D$ flip-flop may be constructed with two D-latches in the manner shown in Figure 10.

An PLS153 may be programmed as shown in Figure 11 to implement the $D$ flip-flop which is equivalent to the circuit shown in Table 5 in the PLS153 logic representation.


Figure 10. D Flip-Flop


Figure 11. D Flip-Flop

Table 5. PLS153/153A Programming Table


## Latches and Flip-Flops With PLS153



NOTES:
All programmed "AND" gate locations are pulled to logic "1"
All programmed "OR" gate locations are pulled to logic " 0 "
3. Programmable connection.

Figure A-1. FPLA Logic Diagram

Appendix B. PLS153/153A Programming Table


## APPENDIX C

R-S LATCH (Cross-Coupled NOR)
See Figures 3 and 4 and Table 2


D-LATCH
See Figures 6 and 7 and Table 3

R-S LATCH (Cross-Coupled NAND)
See Figures 1 and 2 and Table 1


Typical set-up time $\cong$ Ons
Typical hold time $\cong 0-5 n s$
Typical propagation delay $\cong \mathbf{2 0 n s}$


EDGE-TRIGGERED R-S Flip-Flop
See Figures 8 and 9 and Table 4


NOTE: Timing requirements/performances are the same as the R-S latches


NOTE: Timing requirements/performances are the same as the D-latch

Figure C-1. Timing Photos

## AN15

PLS159 Primer

## Application Note

Application Specific Products

## INTRODUCTION

The PLS159 is a field programmable logic sequencer which consists of four dedicated inputs, four bidirectional I/O's, eight flip-flops, thirty two 16 -input AND gates, twenty 32 -input OR gates, and a complement array. Each flipflop has a bidirectional I/O and may be individually programmed as J-K or D flip-flop, or switch between the two types dynamically. The flip-flops will accept data from the internal logic array or from the bidirectional I/O, or they may be set or reset asynchronously from the AND array. The output polarity of the four bidirectional I/O's are programmable and the direction is controlled by the AND array. Figure 1 is the logic diagram of PLS159.

## PROGRAMMING THE PLS159

The programming table is shown in Table 1 where there is a place for everything that is
shown in Figure 1. The program table is basically divided into two main sections. The left hand side of the table, section A, represents the input side of the AND gates, while the right hand side, section B , represents the OR gates sections which includes the flipflops and the combinatorial outputs $\mathrm{B}(0)$ to $\mathrm{B}(3)$. The flip-flops modes are defined in section C and the output polarities of the combinatorial outputs are defined in section $E$. The programming symbols are detailed in Figure 2

As shown in Table 1, the programming table is very similar to a truth table. Each column in section A represents an input to the 32 AND gates, and each row represents an AND gate connecting to 17 inputs. Columns $I_{0}$ to $I_{3}$ represent the 4 dedicated inputs, $I_{0}$ to $I_{3}$. Columns $\mathrm{B}\left(\mathrm{I}_{0}\right.$ to $\mathrm{B}\left(\mathrm{I}_{3}\right.$ represent the inputs of the 4 bidirectional $1 / O, \mathrm{~B}_{0}$ to $\mathrm{B}_{3}$. Columns
$Q(P)_{0}$ to $Q(P)_{7}$ represent the feedback, $F_{0}$ to $F_{7}$, from the flip-flops (the present state). Column ' C ' represents the complement array.

As shown in Figure 1, the outputs of the AND gates are connected to an array of OR gates which, in turn, are connected to either flipflops or output circuits. Columns $Q(N)_{0}$ to $Q(N)_{7}$ represent the next state which the flipflops will be in. Columns $\mathrm{B}(\mathrm{O})_{0}$ to $\mathrm{B}(\mathrm{O})_{3}$ represent the combinatorial outputs $\mathrm{B}_{0}$ to $\mathrm{B}_{3}$.
Each row represents an AND gate with 17 inputs each of which may be true and/or complement and is, therefore, a perfect decoder. Referring to the programming symbois in Figure 2, to implement the equation

$$
Z=A * B * C * D,
$$

all one has to do is to enter one line as shown in Table 2, term-0.

## PLS159 Primer



## NOTES:

1. All OR gate inputs with a blown link float to logic " 0 "
2. All other gates and control inputs with a blown link fioat to logic "1".
3. $\oplus$ denotes WIRE-OR.

Figure 1. FPLS Logic Diagram

## PLS159 Primer

Table 1. FPLS Program Table


The FPLS can be programmed by means of Logic Programming equipment.
With Logic programming, the AND/OR-EXOR input connections necessary to imple-
ment the desired logic function are coded directly from the State Diagram using the Program Tables on the following pages.

In these Tables, the logic state or action of all $1 / O$, control, and state variables is assigned a symbol which results in the proper fusing pattern of corresponding links defined as follows:

"AND" ARRAY - (I), (B), (Qp)

"COMPLEMENT' ARRAY - (C)

"COMPLEMENT" ARRAY (cont.)
"'OR"' ARRAY - (MODE)

"OR" ARRAY - ( $\mathbf{Q}_{\mathrm{N}}=\mathrm{D}$-Type $)$
Figure 2

'" $\overline{O E}$ ' ARRAY - (E)

## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates.
2. Any gate ( $\left.T, F_{C}, L, P, R, D\right)_{n}$ will be unconditionally inhibited if any one of the $I, B$, or $Q$ link pairs is left intact.
3. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}, F_{C}$.
4. $E_{n}=0$ and $E_{n}=$ are logically equivalent states, since both cause $F_{n}$ outputs to be unconditionally enabled.
5. These states are not allowed for control gates ( $L, P, R, D)_{n}$ due to their lack of "OR" array links.

Figure 2 (continued)

Table 2. FPLS Program Table

| CODE NO. |  |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  | $E_{A}$ |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | H | H |  |
| $\begin{array}{\|l\|} \hline \mathbf{T} \\ \mathbf{E} \\ \mathbf{R} \\ \hline \end{array}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |
|  | 1 |  |  |  |  | B(1) |  |  |  | Q(P) |  |  |  |  |  |  |  |  | O(N) |  |  |  |  |  |  | B(O) |  |  |  |  |
|  | 3 |  | 21 | 1 | 0 | 3 | 2 | 1 | 0 | 7 | 65 | 54 | 43 | 3 | 2 | 1 | 0 |  | 7 | 6 | 5 | 4 | 3 | 21 | 10 | 03 | 32 | 1 | 0 |  |
| 0 - | H | H | $\mathrm{H}^{\mathrm{H}}$ | ${ }^{1} \mathrm{H}$ | H | - | - | $\rightarrow$ | - | - | - | $-1$ | - | - | - | - | - | $A * B * C * D$ | - | - | - | - | - | - - | - - | - | - | - | A | $2=A * B * C * D$ |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 - | L | H | + 1 | L | - | - | - | - | - | - | - - | - - | - | - | - | - | - | IA* B*/C | - | - | - | - | - | - | - | - | - | A | - | $Y / A * B * / C$ |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 | - |  | - - | - - | - | - | - | - | - | - | - | -- | - - | - | - | - | - | "1" | - | - | - | - | - | -- | - - | - | - A | - | - | $x=1$ |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 0 <br> 7  | 0 |  | 00 | 0 | 0 | 0 | 0. | 0 | 0 | 0 | 0.0 | 010 | 0 | 0 | 0 | 0 | 0 | * 0 " | 0 | 0 | 0 | 0 | 0 | 0 | 00 | $\bigcirc$ A | 4 A | A | A | VIRGİTION |
| 7 7- | - | - | - 0 | O- | - | - | - | - | - | - | - | - | - | - | - | - |  | ${ }^{\circ} 0^{\prime \prime}$ |  | - | - | - | - | - | - - | - A | A. | - | A | $w=0$ |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 - | H | L | - - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | $A * / B$ | - | - | - | - | - | - | - | - A | A | - | - | $W=A * / B$ |
| 10 - | - |  | - H | HL | L | - | - | - | - | - | - | - | - | - | - | - | - | $C * / D$ | - | - | - | - | - | - | - - | - A | 4 | - | $\bullet$ | $W=C * / 0$ |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RBE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 |  |  |  | 1 | 1 |  |  |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 |  |  |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 | 11 | 11 |  |  | 1 | 1 |  | 1 |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 | 11 |  |  |  |  |  |  |  |  |
| DOL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN | 5 |  | 43 | 3 | 2 | 9 | 8 | 7 | 6 | 191 | 181 | 171 | 161 | 151 | 14 | 13 | 12 |  | 19 | 18 | 17 | 16 | 151 | 1413 | 1312 | 29 | 98 | 7 | 6 | 19 |
| 号 | A |  |  | C | D |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $w x$ | $Y$ | Z |  |

## PLS159 Primer

Notice that only $\mathrm{I}_{0}$ to $\mathrm{I}_{3}$ on the left hand side and $B(O)_{4}$ on the right hand side have entries to implement the equation. All unused columns are dashed out or dotted out.

To implement the equation

$$
Y=/ A * B * / C \text {, }
$$

enter one line as shown in Table 2, term-2 where the entry " $H$ " represents the noninverting input buffer while the entry " $L$ " represents the inverting buffer. To have the AND gate to be unconditionally "High", dash out all the inputs of that particular AND gate as shown in Table 2, term-4. The virgin condition of the device, as shipped from the factory, has all connections intact, which means that the inverting and the non-inverting buffers of the same inputs are connected together. Such connection will cause the AND gate to be unconditionally "Low" as shown in Table 2, terms 6 and 7. The unconditional High and Low states are normally useful only internally and seldom brought out to the output pins.
To implement the equation

$$
W=A * / B+C * / D
$$

enter one line for $A * / B$ and another line for C * /D as shown in Table 2, terms 9 and 10. Use one line to AND something together; use different lines to OR something together one line per item to be OR'ed.

All the pins which are labelled B 's are bidirectional I/O pins. Their input buffers are represented by the $B(I)$ columns on the left hand side of the programming table. An " H " entry represents the non-inverting buffer and an "L" entry represents the inverting buffer. Their output buffers are represented by the $B(O)$ columns on the right hand side of the table. An " A " entry means that the output is active (connected to the AND gates); a ".:"
entry means that the output is inactive (not connected). The outputs may be programmed to be inverting or noninverting. The polarity of each output is determined by its exclusive OR gate (Figure 1 and Figure 2). To have a noninverting output, enter an "H" in t̀ne section labelled 'POLARITY' (Table 1, Section E). To have an inverting output, enter an "L". For example, Table 3, terms-0 and-2 implement the equation

$$
\mathrm{Z}=/\left(\mathrm{A}^{*} \mathrm{~B}\right) \text { and } \mathrm{Y}=\mathrm{A} * \mathrm{~B}
$$

respectively. The above two equations may also be implement by term- 4 which uses the same AND gate to drive two OR gates.
Besides being able to have programmable Active-High or Active-Low output, the programmable output polarity feature also low output, the programmable output polarity feature also allows the user to minimize his AND term utilization by converting his logic equation into other forms such as conversion by De Morgan Theorem.

For example, the equation

$$
X=A+B+C+D
$$

takes four AND terms to implement as shown in Table 3, terms 6 to 9 . By using De Morgan Theorem, the same equation is changed to

$$
/ W=/ A * / B * / C * / D
$$

The result is as shown in term 11 - a saving of three AND terms. The output buffers are disabled in their virgin states so that they all behave as inputs. The buffers are enabled or disabled by their corresponding Control AND terms $D_{0}$ to $D_{3}$ (see Figure 1). The Control AND terms are represented in the programming table on the last four rows on the left hand side. Dashing out all the inputs will
cause the output buffer to be unconditionally enabled, whereas a " 0 " (zero) will cause the buffer to be unconditionally disabled. The buffers may also be controlled by a logical condition, e.g. $A * / B * / C$, etc.
There are eight flip-flops on the chip each of which may be programmed as a $\mathrm{J} / \mathrm{K}$ or a D flip-flop, or they may be programmed to switch dynamically. As shown in Figure 1, each flip-flop is a $\mathrm{J} / \mathrm{K}$ to begin with. A tri-state inverter is connected in between the J and K inputs of each flip-flop, which when enabled by the AND gate $F_{C}$, will cause the flip-flop to function as a D flip-flop. The inverters are enabled by $F_{C}$ through fuses $M_{0}$ to $M_{7} . A$ ' ${ }^{\prime}$." in the F/F Mode entry of the programming table means that particular fuse is to be disconnected and that particular flip-flop is to be $J / K$. An "A" entry will leave the $M$ fuses intact, which allow the flip-flop to be D or J/K as controlled by the output of $F_{C}$ (see Figure 2, "OR" ARRAY - (MODE)). The inputs to the flip-flops are represented by the programming table as the next state, $Q(N)_{0}$ to 7 since their inputs are from the OR array. The outputs of these registers are connected to their respective tri-state inverting output buffers, four of which are controlled by EA and the other four by $E B . A^{\prime \prime}: "$ in EA wiil enabie outputs $F_{0}$ to $F_{3}$, whereas a "-"" will disable them. An "A" will allow the output buffers to be controlled by /OE, pin 11. Table 4, terms 0,1 and 3 represent the following equations

$$
\begin{array}{ll}
Q_{0}: J=A * C+/ B * / E & \text { eq. } 1 \\
Q_{0}: K=A * / C & \text { eq. } 2
\end{array}
$$

Notice that the $J$ input in equation 1 is represented by the " H " entry in terms-0 and 1, column $\mathrm{Q}(\mathrm{N})_{0}$ while the K input in equation 2 is represented by the " L " entry in term-3, column $Q(N)_{0}$. An undefined input, $J$ or $K$, is considered 'Low'.

Table 3. FPLS Program Table


Table 4. FPLS Program Table

| CODE NO. |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  | $E_{\mathbf{A}}$ |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  | - | * | * |  |  |  | A |  |  | * |  |  |  |  |  |  |  |  |  |  |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |
|  | 1 |  |  |  | B(1) |  |  |  | Q(P) |  |  |  |  |  |  |  |  | Q(N) |  |  |  |  |  |  | B(0) |  |  |  |  |
|  | 3 | 2 | 1 | 10 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  | 7 | 6 | 54 | 43 | 32 | 21 | 0 | 3 | 2 | 1 | 0 |  |
| 0 - | H | - | H | 4- | - | - | - | - | - | - | - | - | - | - | - | - | A*C | - | - | - | - | - - | - - | H |  |  |  |  | $J=A * C$ |
| $1 .-$ | - | L | - | 1 | - | - | - | - | - | - | - | - | - | - | - | - | 13*/E | - | - | - | - | - - | - - | H |  |  |  |  | +/6*/E |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 -1 | H | - | L | - - | - | - | - | - | - | - | - | - | - | - | - | - | A*/C | - | - | -- | - | - - | -- | $L$ |  |  |  |  | $K=A * / C$ |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 - | $L$ | $L$ | $L$ | - - | - | - | - | - | - | - | - | - | - | - | - | - | /A*/B*/C | - | $\bullet$ | $\bullet$ | $\bullet \cdot$ | $\cdots$ | - A | - |  |  |  |  | $D=/ A * / B * / C$ |
| 6 - | - | - | - | - H | - | - | - | - | - | - | - | - | - | - | - | - | E | - | $\bullet$ | $\bullet$ | $\bullet \cdot$ | - - | - A | - |  |  |  |  | +E |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 - | L | L | L | - - | - | - | - | - | - | - | - | - | - | - | - | - | /A*/B*/C | - | - | - | - | -- | $-\mathrm{H}$ | - |  |  |  |  | $D=1 A * / B * / C$ |
| 9 - | - | - | - | $-\mathrm{H}$ | - | - | - | - | - | - | - | - | - | - | - | - | E | - | - | - | - | - - | $-\mathrm{H}$ | - |  |  |  |  | +E |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11, | - | - | - | - - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | 0 | - | - | -- | - |  |  |  |  |  |
| 12 - | - | - | - | - - | - | - | - | - | - | - | H | - | 7 | - | - | - |  | - | 0 | - | - | - | -- | - |  |  |  |  | $T=1$ |
| 13 - | - | - | - | - | - | - | - | - | - | H | H | - | - | - | - | - |  | 0 | - | - | - | - - | - | - |  |  |  |  | $T=Q_{5}$ |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $T=Q_{5} * Q_{6}$ |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC - | - | - | - | -- |  | - | - | - | - | - | - | - | - | - | - | - |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1$ | 1 |  |  | 1 | 1 | 1 | 1 |  |  |
| RB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 |  |  |
| LB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1$ | $1$ | $1$ |  |  |  | 1 | 1 | 1 |  |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | , | 1 | 1 |  |  | 1 | 1 | 1 | 1 | 1 |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1$ | $11$ | $1$ |  |  | $1$ | $1$ | 1 | 1 | 1 |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | । | । | $!$ | ! |  |  | $!$ | 1 | 1 | 1 |  |
| D3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 |  |
| D2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 |  |  | 1 | 1 |  |  |  |  | 1 |  |  |
| D1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 1 | 1 |  |  |  | $\frac{1}{1}$ | $1 T$ |  |  |  |  |
| D0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
| PIN | 5 | 4 | 3 | 3.2 | 9 | 8 | 7 | 6 | 19 | 18 | 117 | 16 | 15 | 14 | 13 | 12 |  | 19 | 18 | 171 | 161 | 1514 | 413 | 12 | 9 . | 8 | 7 | 6 | 19 |
| 号 | A | $B$ | $1$ | $D$ | 1 | ! |  |  |  |  |  |  |  | + |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $8$ |

A D flip-flop may be implemented by first entering an " $A$ " in F/F MODE. Then enter " 0 " in the row $\mathrm{F}_{\mathrm{C}}$, which will unconditionally enable the tri-state inverter between the $J$ and K inputs. The following logic equation may be implemented as shown in Table 4, term 5

$$
Q_{1}: D=/ A * / B * / C+E .
$$

Notice that the entries in term 5 , columns $Q(N)_{0}$ to 7 are " $A$ " and "." instead of " $\mathrm{H}^{\prime}$ and "L" as in the case of J/K flip-flops. The entry " $A$ " will cause the fuse connecting to the " K " input to be disconnected and the " J " fuse to be intact. Whereas the entry "." will cause both fuses to be disconnected. This feature enables the user to quickly recognize the mode in which the flip-flops are operating without having to go through the control terms. Some commercially available device programmers in the market may not have the software capability to implement this feature, in which case an " $H$ " and a "-" may be used in place of " A " and "." respectively as shown in Table 4, terms 8 and 9.

Of course, the term $F_{C}$ may have inputs instead of zeros and dashes, in which case the flip-flop modes are controlled dynamically.
When both the $J$ and $K$ inputs are ' 1 ' $s$ ', the flip-flop will toggle. A simple 3-bit counter may be implemented using only AND terms as shown in Table 4 terms 11, 12 and 13. The logic equations for the three flip-flops are as the following:

$$
\begin{array}{ll}
Q_{5}: T=1 ; & \left(Q_{5}\right. \text { toggles unconditionally) } \\
Q_{6}: T=Q_{5} ; & \left(Q_{6} \text { toggles when } Q_{5}=1\right) \\
Q_{7}: T=Q_{5}{ }^{*} Q_{6} ; & \left(Q_{7} \text { toggles when } Q_{5} *\right. \\
& \left.Q_{6}=1\right)
\end{array}
$$

The above equations represent an octal upcounter. However, since the outputs of the flip-flops are inverted, the counting sequence of the outputs is that of a down-counter.

The flip-flops may be asynchronously set and reset by the Control AND terms PA/PB and


RA/RB respectively. As shown in Figure 1, PA and RA controls flip-flops $F_{0}$ to $F_{3}$, while $P B$ and RB control $F_{4}$ to $F_{7}$.
In order to save the number of input pins, the eight flip-flops may be synchronously loaded directly from their own output pins. To use this feature, $E A$ and/or $E B$ must be programmed "A" or "-" so that the output buffers may be disabled before loading. As shown in Figure 1, every flip-flop has an OR/ NOR gate the input of which is directly connected to the output pin and the outputs of the OR/NOR are connected to the K and J inputs respectively. This OR/NOR gate inverts the input and feeds it to the flip-flop in a "wire-OR" fashion. Therefore, when loading data directly into the flip-flops from the output pins, caution must be exercised to insure that the inputs from the OR array does not interfere with the data being loaded. For example, if the data being loaded is a " 1 " on the output
pin, the $J$ input will be a " 0 " and the $K$ input will be a " 1 ". If, at the same time, a " 1 " is present at the J-input from the OR array, the flip-flop will see " 1 's" in both $J$ and $K$ inputs. It will toggle as a result. The OR/NOR gates are enabled by the Control AND terms LA and LB. LA controls flip-flops $F_{0}$ to $F_{3}$ and LB controls $\mathrm{F}_{4}$ to $\mathrm{F}_{7}$.
All Control AND terms function and are programmed in the same manner as the other AND terms. The only difference is that the Control AND terms are not connected to the OR array.
The outputs of the flip-flops may be fed back into the AND array as the present state, $Q(P)$. The output of the AND array into the OR array and the inputs to the flip-flops is the next state, $\mathrm{Q}(\mathrm{N})$. As an example, Figure 3 is a state machine implemented in a PLS159 as shown in Table 5, terms 0 to 6.

Table 5. FPLS Program Table

| CODE NO. |  |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  | REMARKS | $\mathrm{E}_{\mathrm{B}}$ |  |  |  | $\frac{E_{A}}{}$ |  |  | POLARITY |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  | -1. | -1. | I. |  |  | - |  | * |  |  |  |  |  |  | H1HH1H |  |  |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 |  |  |  | B(I) |  |  |  | Q(P) |  |  |  |  |  |  |  | Q(N) |  |  |  |  |  |  | B(0) |  |  |  |
| c | 3 | 2 | 21 | 10 | 0 | 3 | 2 | 1 | 0 | 76 | 65 | 54 | ] | 32 | 1 | 0 |  |  | 65 | 54 | 43 | 32 | 1 | 0 | 32 | 21 |  |  |
| 0 | H | H | + |  |  |  | - | - | - | L | L L | LL | L | - | L | L |  | LL | L | L | L | -L | - | H | - | - | A |  |
| 1 - | - | - | H |  | - | - | - | - | - | - L | LL | Li | L | - | L | H |  | L L | L | L H | - | LL | L | H |  | A. | - |  |
| 2 | - | - | - |  | - | - | - | - | - | L | LL | L H | L | - | L | H |  | LL | L. | HL | $\mathrm{L}^{\mathrm{H}}$ | iL | H | - | A | $\cdot$. | $\cdot$ |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 - | H | L | - - |  | - | - | - | - | - | 42 | LL | L L | L | L | L | L |  | $4 L$ | LL | LL | L | LL | H | L | - | - A | - |  |
| 5 | - | - | - |  | - | - | - | - | - | LL | L, L | L L | L | L | H | L |  |  | L | L L | - | -L | L | H | - 4 | A | - |  |
| 6 6, | - | - | H |  | L |  | - | - | - | LL | LIL | -L | L | L | H | L |  | LL | 4 | $L$ |  | LL | $L$ | H | - A | A A | - |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | , |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | , |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 |  | 1 |  |
| $\frac{R B}{L B}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 |  |  | , | 1.1 | 1 | 1 |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | + | 1 | 1 | 1 | 1 |  | 11 | 11 | 1 | 1 |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 1 | 1 | 1 | 1 |  | 1 | 11 | 1 | 1 |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 I | 1 | - | 1 | 1 | 1 | 1 | 11 |  | 1 |  |
| LA! |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 |  | 1 |  | $1$ | 1 | 1 | 1 |  |
| D3- |  | - | - | - |  | - | - | - | - | - | - | - | - |  |  |  |  | 1 | 1 | - | 1 | 1 | 1 | 1 | 1 | , | 1 |  |
| D2- |  | - | - |  |  | - | - | -, |  |  | - | - |  |  | - |  |  | 11 | 1 |  | 1 | i 1 | 1 | 1 | + |  | 1 |  |
| D1 ${ }^{\text {- }}$ |  | - | - | - |  |  | - | - |  |  | - | - |  |  |  |  |  | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |
| DO - <br> PIN |  | - | - |  |  | - | - | - |  |  | - - | -- |  |  | - |  |  |  |  |  |  |  |  |  |  |  |  | O) |
|  | 5 | 4 | 4 | 32 | 2,9 | 9 | 8. | 7 | 6 | 19.1 | 18,17 | 17,16 |  | 5.14 | +13 | 12 |  | 191 | 18.17 | 171 | 615 | 514 | 13 | 12 | 98 | 817 | 6 | 10 |
|  |  | B |  | $2 D$ |  |  | , | + |  |  |  | + |  | + | + | 1 |  | 11 |  |  |  | , |  |  | $\int_{x}$ | $\begin{array}{r}1 \\ \times \\ \hline\end{array}$ |  | 5 |

## Application Specific Products

AN16

## PLS159 As Modulo Counters

## Application Note

## DESCRIPTION

The field-programmable logic sequencer (FPLS) PLS159 has eight edge-triggered flipflops which may be individually programmed to be $J / K, D$, or toggle flip-flops. The detail logic diagram of the device is shown in Figure 2.

A counter may be constructed by having individual flip-flops toggle when they are at certain states. Implementing such counters requires one toggle flip-flop per bit and an associating AND gate as a decoder for each flip-flop. Such a method allows the PLS159 to be a counter from modulo 2 to 256 or from one bit to 8 bits.

## MODULO-8 UP/DOWN COUNTER

## The Up-Counter

The PLS159 has an inverting output buffer for each flip-flop. Therefore the counting sequence of the flip-flops is from 7 to 0 so that the outputs will count from 0 to 7 . Table 1 is
the truth table of the internal counting sequence.

## Table 1

| COUNT | $\mathbf{Q}_{\mathbf{2}}$ | $\mathbf{Q}_{\mathbf{1}}$ | $\mathbf{Q}_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 1 | 1 |
| 1 | 1 | 1 | 0 |
| 2 | 1 | 0 | 1 |
| 3 | 1 | 0 | 0 |
| 4 | 0 | 1 | 1 |
| 5 | 0 | 1 | 0 |
| 6 | 0 | 0 | 1 |
| 7 | 0 | 0 | 0 |

From Table 1, logic equations for the flip-flops may be generated as the following:

$$
\begin{array}{ll}
Q_{0}: T=1 ; & \left(Q_{0}\right. \text { unconditionally } \\
Q_{1}: T=/ Q_{0} ; & \begin{array}{l}
\text { toggles) } \\
\left(Q_{1}\right. \text { toggles if } \\
Q_{0}: T=/ Q_{0}^{*} / Q_{1} ;
\end{array} \begin{array}{l}
\left(Q_{2}\right. \text { toggles if both } \\
\\
\left.Q_{0} \text { and } Q_{1}=0\right)
\end{array}
\end{array}
$$

The equations are implemented as shown in Table 2, terms 0,1 , and 2 . $\mathrm{E}_{\mathrm{A}}$ is enabled, and the mode for the three flip-flops is set to $\mathrm{J} / \mathrm{K}$. All unused flip-flops and outputs ( the $B(0)$ 's ) associating to AND-terms are "dashed" or "dotted" out. The event to be counted is connected to the clock input, pin 1 of the device.

## The Down-Counter

The down-counter is constructed in the same manner as the up-counter except that the counting sequence is reversed. The downcounter is implemented in Table 2, terms 4 to 6 with the corresponding flip-flop mode set to $J / K$ and $E_{B}$ enabled.

## Modulo-16 Counter

Expanding the modulo-8 counter to 4-bit, the counter becomes modulo-16, Table 3, terms 0 to 3 and the associating F/F MODE and $E_{A}$ implement a modulo-16 up-counter, while terms 5 to 8 and the associating F/F MODE and $E_{B}$ implement the modulo-16 downcounter.

Table 2

| CODE NO |  |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS |  |  |  |  | E |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  | - | - | - | - | - | - | - | $\bullet$ |  |  | - | - |  |  |  |  |  |  |  |  |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |
|  | C | 1 |  |  |  | B(I) |  |  |  | Q(P) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{B}(\mathrm{O})$ |  |  |  |  |
|  |  | 3 | 2 | 1 | 0 | 3 2 1 |  |  | 10 | 76 |  | 615 | 4 | 3 | 2 | 1 | 0 |  | 7 | 6 | 5 | 4 | 3 | 2-1 | 10 |  | 12 | [ 1 | 0 |  |
| 0 |  |  | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - | - |  | - - | -0 | $\cdot$ | - | - | - |  |
| 1 |  | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | L |  | - | - | - | - | - | - 0 | O- | - | - | - | - |  |
| 2 |  | - | - | - | - | - | - | - | - | - | - | - | - | - | - | $L$ | L |  | - | - | - | - | - 0 | $0-$ | - - | - | - | - | - |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - | 0 | - | - - | -- | $\bullet$ | - | - | - |  |
| 5 |  | - | - | - | - | - | - | - | - | - | - | - | H | - | - | - | 二 |  | - | - | 0 | - | - | - - | - - | - | $\bullet$ | - | - |  |
| 6 |  |  | - | - | - | - | - | - | - | - | - | H | H | - | - | - | - |  | - | 0 | - | - | - | - - | - | - | - | - | - |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 | $\underline{ }$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1$ | $1$ |  | $1$ |  | 1 | 1 |  |  |
| RB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $1$ |  | $1$ | I |  | 11 |  | 1 | 1 |  |  |
| LB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ |  |  | $1$ | $1$ |  |  |  |  |  |  |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $11$ | I | \| | $1$ |  | 11 | 1 | 1 | 1 |  |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $11$ |  | $11$ | $1$ |  | 11 | 1 | 1 | 1 |  |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $11$ |  | I | $1$ |  |  |  | 1 | 1 |  |  |
| D3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $11$ | $1$ | $1$ | $1$ | $1$ | 1 | 1 | 1 |  |  |  |
| D2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 1 | $11$ | $11$ | $11$ |  | $11$ | 1 |  |  |  |  |
| D0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | -) |
| PIN |  | 5 | 4 | 3 | 2 | 9 | 8 | 7 | 61 | 191 | 181 | 171 | 161 | 15 | 14 | 13 | 12 |  | 19 | 18 | 171 | 161 | 151 | 1413 | 312 | 9 | 8 | 7 | 6 | 19 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | , | + |  |  |  |  |  |  | 1 | 1 |  |  |  |  |  |

## PLS159 As Modulo Counters

Table 3


## DECADE COUNTER

The Decade Up-Counter
The truth table of a decade counter is as shown in Table 4.

Table 4

| COUNT | $\mathbf{Q}_{\mathbf{3}}$ | $\mathbf{Q}_{\mathbf{2}}$ | $\mathbf{Q}_{\mathbf{1}}$ | $\mathbf{Q}_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 |
| 2 | 1 | 1 | 0 | 1 |
| 3 | 1 | 1 | 0 | 0 |
| 4 | 1 | 0 | 1 | 1 |
| 5 | 1 | 0 | 1 | 0 |
| 6 | 1 | 0 | 0 | 1 |
| 7 | 1 | 0 | 0 | 0 |
| 8 | 0 | 1 | 1 | 1 |
| 9 | 0 | 1 | $\mathbf{1}$ | 0 |
| 0 | 1 | 1 | 1 | 1 |

Logic equations may be generated from Table 4 as the following:

$$
\begin{aligned}
& Q_{0}: T=1 ; \\
& Q_{1}: T=/ Q_{0} * Q_{3 ;} ; \\
& Q_{2}: T=/ Q_{0} * / Q_{1} * Q_{3} ; \\
& Q_{3}: T=/ Q_{0} * / Q_{1} * / Q_{2} * Q_{3}+
\end{aligned}
$$



The equations are implemented as shown in Table 5, terms 0 to 4 and the associating flipflop mode and $E_{A}$ settings.

## Decade Down-Counter

The decade down-counter is similar to the decade up-counter except that the counting sequence is reversed from 0 to 9 as shown in Table 5, terms 6 to 11 with the associating F/F MODE set to $J / K$ and $E_{B}$ to ENABLE.

## Decade Down Counter

| COUNT | $\mathbf{Q}_{7}$ | $\mathbf{Q}_{6}$ | $\mathbf{Q}_{\mathbf{5}}$ | $\mathbf{Q}_{4}$ |
| :---: | :---: | :---: | :---: | :---: |
| 9 | 0 | 1 | 1 | 0 |
| 8 | 0 | 1 | 1 | 1 |
| 7 | 1 | 0 | 0 | 0 |
| 6 | 1 | 0 | 0 | 1 |
| 5 | 1 | 0 | 1 | 0 |
| 4 | 1 | 0 | 1 | 1 |
| 3 | 1 | 1 | 0 | 0 |
| 2 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 |
| 0 | 1 | 1 | 1 | 1 |
| 9 | 0 | 1 | 1 | 0 |

$Q_{4}: T=1 ;$
$Q_{5}: T=Q_{4} * Q_{5} * Q_{6} * / Q_{7}+$ $Q_{4} * / Q_{5}^{*} / Q_{6} * Q_{7}+$ $Q_{4} * Q_{5} * / Q_{6} * Q_{7}+$ $Q_{4}{ }^{*} / Q_{5}{ }^{*} Q_{6}{ }^{*} Q_{7}$;
$Q_{6}: T=Q_{4} * Q_{5} * Q_{6} * / Q_{7}+$ $Q_{4}{ }^{*} Q_{5}{ }^{*} / Q_{6}{ }^{*} Q_{7}$;
$Q_{7}: T=Q_{4} * Q_{5}^{*} Q_{6}^{*} / Q_{7}+$
$Q_{4}^{*} Q_{5}^{*} Q_{6}^{*} Q_{7}$;

Table 5


Table 6

| CODE NO. |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  | REMARKS | $E_{B}$ |  |  | $E_{A}$ |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  | $\cdot \cdot$ | T | - | $\cdot 1 \cdot$ | $\cdot 1 \cdot$ |  |  |  |  |  |  |  | H |  |
| T | AND |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |
| E ${ }_{\text {R }}$ | , |  |  |  | B(1) |  |  | Q(P) |  |  |  |  |  |  | Q(N) |  |  |  |  |  |  | B(0) |  |  |  |
| C | 3 | 2 | 10 | 0 | 32 | 210 | 0 | 716 | 65 | 4 | 3 | 21 | 10 |  | 76 | 6.5 | 54 |  |  |  | 3 | 21 | 10 | 0 |  | 3 | 1 | 0 |
| 0 |  | - | -L | L - | - - | - - | 6 | -- | -- | - |  | - | - - |  | $=$ | $\cdots$ | - | - | -- | - 0 | 0. | - | - | - |  |
| 1 |  |  | -L | L- | - - | --L | $L$ | - | - |  |  | - | $-\mathrm{H}$ |  |  |  |  | - | -0 | $0-$ | - | - | - | - |  |
| 2 |  |  | -L | L- | - - | - - L | L | - - | - - | - |  |  | H H |  | - | - - | - | - | - - | -- | - | - | . | - |  |
| 3 |  |  | -L | $L$ | - | - -L | $L$ | - | - - | - |  |  | H H |  | - | - | - | 0 | - - | - | - | - | - | - |  |
| 4 |  | - | -L | L | - | - - L | L | -- | -- | - | H |  | H H |  |  | -- | 0 | - | -- | - | - | - | - | - |  |
| 5 |  |  | $-L$ | L- | - - | - - L | L | -- | -- | $\mathrm{H}_{\mathrm{H}}$ | H |  | H H |  |  | - 0 | - | - | -- | - - | - | - | $\cdot$ | - |  |
| 6 |  | - | -L | L- |  | - -L | L | - - | - H | H | H |  | H H |  | -0 | $0-$ |  | - | -- | - - | - | - | - | - |  |
| 7 | - |  | -L | L- | -- | - L | L | - H | - ${ }^{\text {H }}$ | H |  |  | H H |  | $0-$ |  | - | - | -- | - | $\cdot$ | - | - | $\cdot$ |  |
| 8 | - | - | -L | L | -- | -- | - H | H H | H | H | H | HH | H |  |  | -- | - | - | - - | - - | - | - | - | A |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  | , |  |  |  |  |  |  |  |  |  |  |  |  |  | , |  |  | I |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  | I |  |  | 1 | I |  |  |  |  |  | 1 |  |  |  | + |  |  |  |  | 1 |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LB $-(-1-1-\|-\|H\| H\| H\|H\| H \mid H 1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LA $-\infty-\infty-\infty, H^{-1}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN | 5 | 4 |  | 29 | 98 | 3.7.6 | 619 | 19,18 | 817 | 161 |  | 14.13 | 13.12 |  | 1918 | 1817 | 716 | 615 | 14.13 | 1312 | 29 | 98 | 7 | 6 | 10 |
|  |  |  |  | 岗 |  |  | . | 1 |  |  | ! |  |  |  | - |  |  |  |  |  |  |  |  |  | 0 |



NOTES:

1. All OR gate inputs with a blown link float to logic " 0 ".
. All other gates and control inputs with a blown link float to fogic " 1 ".
2. $\oplus$ denotes WIRE-OR.

Figure 2

## Signetics

Application Specific Products

## INTRODUCTION

A combination lock may be opened by entering the correct numbers which match the preset security code that may be of any number of digits. Using a PLS157, an electronic combination lock with user settable security code may be constructed. The security code may be one to five hexadecimal digits that can be preset by the user. The lock takes a 4-bit binary input as the "combination" and a "Data Valid" input, which means that the combination may be five digits long and each digit may be from 0 to $F$. If the input matches the preset digit of the security code, the lock will wait for the next digit. If the input does not match the corresponding digit of the security code, the lock will reset itself to the first digit position again. The user may use as many as five digits for the combination which may be set by using five DIP switches or other means. The lock may be used in conjunction with a 4-bit binary encoded rotary switch, or an encoded push button key pad, or an optical card reader, or a magnetic strip reader. The design takes advantage of the six JK flip-flops of the PLS157, the bidirectional 1/O's, the complement array, and the general architecture of common product terms.

## DESCRIPTION

Figure 1 shows an example of an electronic lock which uses five DIP switches to set the security code (hexadecimal 0 to $E, F$ is reserved for reset), a 4-bit binary encoded rotary switch to enter the combination at $I_{0}$ to $I_{3}$, and a single pole double throw push button switch, 'Data Valid', as the clock which is debounced by the associated circuitry of pin $\mathrm{B}_{5}$. The security code is set with five DIP switches which are connected to a four line
input $\left(B()_{0}\right.$ to $\left.B()_{3}\right)$. The five DIP switches are multiplexed by the outputs of the flip-flops, $F_{0}$ to $F_{4}$. In normal operation, one of the F/F outputs is Low (the content of the register being a "1") while the other five are High. The operation is actually a shift register with a zero bit shifting through five one's. Therefore only one DIP switch is pulled Low (selected) at any one time while the rest is deselected. The pin named "MATCH', $\mathrm{B}(\mathrm{O})_{4}$, is an I/O which outputs a High if the input matches the corresponding digit of the security code, otherwise it outputs a Low. A High output of $\mathrm{B}(\mathrm{O})_{4}$ enables the shift register to shift one position while a Low causes the shift register to reset to the starting position which is a " 1 " in $F / F_{0}$ (flip-flop 0) ( $F_{0}$ is Low due the output inverter) and " 0 's" in the other five ( $F_{1}$ to $\mathrm{F}_{5}=$ High). The state diagram of the design is as shown in Figure 2 where the state numbers are expressed in two hexadecimal digits. The least significant digit consists of $F_{3}, F_{2}$, $F_{1}$, and $F_{0}$; whereas the most significant digit consists of $F_{5}$, and $F_{4}$. At the top of the state diagram, the power-up and reset state is 00 hex. When the outputs have more than one Low, as sometimes happens during powerup, the circuit automatically resets the registers to 00 hex which causes all outputs to be High in order to prevent more than one DIP switch being enabled. After power-up or reset, pushing the 'Data Valid' button will initialize the circuit to have the first digit of the security code enabled. Subsequently, any false entry will cause the circuit to go back to the initialized state of 01 hex. When the first digit is correctly set and the "Data Valid" button pressed, the circuit goes to 02 hex and the second DIP switch is enabled while the first DIP switch is disabled. The circuit is now ready for the second digit. By repeating the process, the circuit keeps shifting the " 1 " in
the shift register until it reaches $\mathrm{F} / \mathrm{F}_{5}$ at which time the Low output may be used to trigger a solenoid. If at any time of the sequence, an incorrect digit is entered, the circuit reverts back to the initialized state of 01 hex.

Notice that any of the five outputs from $F_{1}$ to $F_{5}$ may be used as an output. Therefore, if, for example, a two digit security code is used, only two DIP switches are needed and the output is taken from $F_{2}$ to trigger a solenoid. After the last digit has been entered, all DIP switches are deselected and the inputs $\overline{\mathrm{B}}(\mathrm{I})_{0}$ to $\mathrm{B}\left(\mathrm{I}_{3}\right.$ become 1111 binary, or F hex. Therefore, the hex number $F$ is not used as a valid code but as an initialization input entered at $I_{0}$ to $I_{3}$. When the hex number $F$ is entered, the circuit initializes itself to the 01 hex state. After the last digit of the security code has been entered, if the "Data Valid" button is pressed again, the circuit sees a false entry and reinitializes itself.
The design is implemented using a PLS157 as shown in Table 1, H/L Programming Table of Electronic Lock. P-terms 0 to 14 are programmed as decoders. If an input matches the corresponding digit of the security code, one of the p-terms will be active which causes $\mathrm{B}(\mathrm{O})_{4}$ to output a High which, in turn, enables the registers to shift to the next digit by terms 16 to 20 . In the event that an incorrect input is entered, $\mathrm{B}(\mathrm{O})_{4}$ outputs a Low which, in turn, causes the registers to be set 000001 binary by term 21 . If an input of $F$ is entered, term 15 causes the registers to be 000001. Terms 22 to 29 and RB ensure that no more than one register is " 1 " at a time. Terms 22 to 28 are connected to the complement array, which in turn, drives terms 29 and RB to set the registers to 000000 when terms 22 to 28 are inactive.


NOTES:

1. All diodes are Philips BAT81 Schottky diodes or equivalent.
2. Single pole double throw momentary switch.

Figure 1. Simple Block Diagram of Electronic Lock


Figure 2. State Diagram of Electronic Lock

Table 1. PLS157 H/L Programming Table


## Application Specific Products

## INTRODUCTION

One of the many features of the PLS153 to 159 series is the availability of individually controlled Tri-state I/O pins. Taking advantage of this feature, a Schmitt trigger may be constructed using one input pin, two bidirectional I/O pins and additional components of three resistors. The two threshold voltages, as well as the hysterisis, are determined by the values of the three resistors and the parameters of the PLS153/159 device, which are 1) input threshold voltage, $V_{T H}$, 2) High output voltage, $\mathrm{V}_{\mathrm{OH}}$, and 3) Low output voltage, $V_{O L}$. The circuit may be simplified if Schmitt function is needed only on Low going High or High going Low, and if the hysterisis and threshold voltages are not important.

## DESCRIPTION

A simplified block diagram of a non-inverting Schmitt trigger is shown in Figure 1 where $R_{1}$, $R_{2}$, and $R_{1}, R_{3}$, form two pairs of voltage dividers one of which get into action at input voltage direction of High going Low and the other Low going High. Assuming that input voltage starts at zero volt, the output voltage is therefore at $V_{O L}$ which causes $Q_{2}$ to pull $R_{3}$ towards ground. As the input voltage increases, only a fraction of the voltage is

# AN18 Schmitt Trigger Using PLS153 and PLS159 

Application Note

impressed upon the input buffer due to the dividing network $R_{1}$ and $R_{3}$. As soon as the input voltage reaches a point where $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{TH}}$ ( $\mathrm{V}_{\mathrm{TH}}=1.38 \mathrm{~V}$ typical), the output switches to $\mathrm{V}_{\mathrm{OH}}$ which, in turn, turns off $\mathrm{Q}_{2}$ and turns on $Q_{1} . V_{1}$ will jump to a value greater than $V_{T H}$ and $Q_{1}$ then pulls the input pin, through $R_{2}$, towards $\mathrm{V}_{\mathrm{OH}}$, which in turn locks the output to a High state even if the input voltage fluctuates, as long as it does not fluctuate outside of the designed hysterisis. When the input voltage goes from a High to a Low, the Schmitt function repeats itself except that $Q_{1}$ and $Q_{2}$ reverse their roles.
The triggering voltages, $\mathrm{V}_{\mathrm{H}}$ (Low going High) and $V_{L}$ (High going Low) are:
$V_{H}=V_{T H}\left[\left(R_{1}+R_{3}\right) / R_{3}\right]-V_{O L}\left(R_{1} / R_{3}\right) ;$ $V_{L}=V_{T H}\left[\left(R_{1}+R_{2}\right) / R_{2}\right]-V_{O H}\left(R_{1} / R_{2}\right)$;
where, at room temperature, $V_{C C}=5.0 \mathrm{~V}$, $\mathrm{I}_{\mathrm{OH}} / \mathrm{I}_{\mathrm{OL}}<1 \mathrm{~mA}$. $\mathrm{V}_{\mathrm{TH}}$ is the threshold voltage of the device, typically $1.38 \mathrm{~V} ; \mathrm{V}_{\mathrm{OL}}$ is the output Low voltage of the device, typically 0.36 V at $|\mathrm{loL}|<1 \mathrm{~mA} ; \mathrm{V}_{\mathrm{OH}}$ is the output High voltage of the device, typically 3.8 V at $\left|\mathrm{IOH}_{\mathrm{OH}}\right|<1 \mathrm{~mA}$.

The implementation of Figure 1 using PLS153/153A is as shown in Table 1, and Figure 2a. A scope photo of the operation of the circuit is shown in the Appendix. The
implementation using PLS159 is shown in Table 2 and Figure 2 b . In Tables $1 \& 2, \mathrm{~V}_{1}$ is the input pin, $\mathrm{V}_{0}$ is the output pin, $\mathrm{V}_{2}$ is the output which pulls down $V_{1}$ and $V_{3}$ is the output pin that pulls up $V_{1}$. The Schmitt output is available at pin $\mathrm{B}_{0}$ for external use, and is available internally at the input buffers of $I_{0}$ and $\mathrm{B}\left(\mathrm{I}_{0}\right.$. However, there is a propagation delay between the two signals from the $\mathrm{I}_{0}$ buffer and the B()$_{0}$ buffer.

An inverting Schmitt triggered buffer may be constructed using the same principle. A simple block diagram of such inverter is shown in Figure 3a. The circuit is implemented using H/L programming table as shown in Table 3 for PLS153 and Table 4 for PLS159. Table 3 is also represented in logic symbols in Figure 3b. If the voltage levels ( $\mathrm{V}_{\mathrm{L}}$ and $\mathrm{V}_{H}$ ) and the hysterisis are not critical, one I/O pin may be used to pull the input pin High and Low. Therefore one I/O pin and a resistor may be saved. The drawback is that the range of $\mathrm{V}_{\mathrm{H}}$ and $V_{L}$ is quite limited. The circuit is as shown in Figure 4.
If Schmitt function is needed only in one direction, one of the resistor/output circuit may be eliminated. The circuit is as shown in Figure 5.


BD01700S
Figure 1. Simplified Block Diagram of a Schmitt Trigger

Table 1. PLS153/153A Programming Table


b. Using PLS159

Figure 2. Schmitt Trigger

Table 2. PLS159 FPLS Programming Table

| CODE NO. |  |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  | $\mathrm{E}_{\mathbf{A}}$ |  |  | POLARITY |  |  | REMARKS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | H] |  |  |  |
| $\begin{aligned} & T \\ & \mathbf{E} \\ & \text { R } \\ & \hline \end{aligned}$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 |  |  |  | B(I) |  |  |  | Q(P) |  |  |  |  |  |  |  |  | O(N) |  |  |  |  |  |  | B(0) |  |  |  |  |
| ${ }_{\text {M }} \mathbf{C}$ | 3 | 2 | 1 | 10 | 0 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 21 | 10 | 0 |  | 7 | 6 | 5 | 4 | 32 | 21 | 0 | 3 | 2 | 10 |  |  |
| 0 |  | - | - | - | H | - | - | - | - | - | - | - | - |  | - | - | - |  |  | - |  | - | - - | - - | - | - | - | - A |  | ON-INV. BUFR |
| 10 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | - | - | - | - | - | - - | - | - | - | A 0 |  | OTPUT $\mathrm{VaL}^{\text {a }}$ |
| 2 - |  | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - |  | - | - | - | - | - - | - - | - | - | A | - $\cdot$ |  | UTPT $\mathrm{V}_{\text {OH }}$ |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D0 - |  | - |  | - | - |  | - |  | - - | - | , | - |  |  | - |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
| PIN | 5 | 4 |  | 32 | 2 | 9 | 8 | 7 | 16 | 19. | 18. | 171 |  | 151 | 141 | 1312 |  |  | 19 | 18 | 17 | 16 | 151 | 1413 | 312 | 9 | 8 | 76 |  | 5 |
| 号 |  |  |  |  | $>$ |  | $>$ | $>$ |  |  |  | + |  |  | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  | 5 |



80017105
a. Simplified Block Diagram


10013505
b. Using PLS159

Figure 3. Inverting Schmitt Trigger

Table 3. PLS153/153A Programming Table

| CODE NO. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | REMARKS | POLARITY |  |  |  |  |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | L L | L |  |
| $\square$ | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \mathrm{OR} \\ & \hline \mathrm{~B}(\mathrm{O}) \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |
|  | 1 |  |  |  |  |  |  | B(i) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 7 |  |  | 43 | 2 | 1 | 0 | 9 | 8 | 16 | 5 | 5 | 43 | 2 | 1 | 0 |  | 9 | 817 | 76 | 5 | 4 | 32 |  | 10 |  |
| 0 |  | - | - | -- | - |  | H | - | - | - |  |  | - | - | - | - |  |  |  |  |  |  |  |  | - | A | ANV. BUFFER |
| 1 | 0 | 0 | 0 | 0.0 | 0 | 0 | 0 | - | 0 | 0 | 0 | 0 | 0,0 | 0 | 0 | 0 |  |  |  |  |  |  |  | - A | A $\cdot$ | OUTPUT VOH |
| 2 | - |  |  | + | - |  | - |  |  |  | - |  |  | - | - | - |  |  |  |  |  |  |  | A. | - | OUTPUT Vol. |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  | + |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  | + |  |  |  |  |  |  |  |  | $+$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  | + |  |  |  |  |  |  |  |  | , |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 7 |  |  |  |  |  |  |  |  |  |  |  |  | + |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  | + |  |  |  |  |  |  |  |  | + |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | .-... |  |  |  |  |  |  |  |  |  |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 |  |  | 1 | 1 |  |
| D7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 |  |  |  | 1 | 1 | 1 |  |
| D ${ }^{\text {D }}$ |  |  |  | $+$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 11 |  | 1 | 1 | 1 | 1 |  |
| D D D |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 11 |  |
| D4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 11 | 11 | 11 | 1 | 1 | 1 | 1 |  |
| D ${ }^{\text {D }}$ | - |  |  | - |  | - |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 11 | 11 | 1 | 1 | 1 | 1 |  |
| D2 |  |  |  | - | - |  | - |  |  |  |  |  |  | - | - |  |  | 1 | 1 | 1 | 11 | 1 | 1 | 1 | 1 |  |
| $\frac{D 1}{D 0}$ |  |  |  |  |  | - |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 | 11 | 1 | 1 | 1 | 11 |  |
| PN | 8 | 76 | 65 | 54 | 3 | 2 | 1 |  | 1817 | 16 |  |  | 413 | 12 | 119 |  |  |  | 1817 | 716 | 15 |  |  | 211 |  |  |
|  | - | 1 | , |  |  |  | 5 |  |  |  |  |  |  | - |  | $1$ |  |  |  |  |  |  | $\bigcirc$ | 85 | $\rightarrow$ | $\frac{4}{8}$ |

Table 4. PLS 159 FPLS Program Table

| CODE NO. |  |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $E_{B}$ |  |  |  | $\mathrm{EA}_{\mathbf{A}}$ |  |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | H | H | 2 |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | (OR) |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 1 |  |  |  |  | B(I) |  |  |  | $Q(P)$ |  |  |  |  |  |  |  |  | $\mathbf{Q}(\mathbf{N})$ |  |  |  |  |  |  |  | B(O) |  |  |  |  |
|  | 3 | 2 | 1 | 0 | 0 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |  |
| 0 - | - | - | - | H | H | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - | - | - | - | - | - | $\bullet$ | - | - | A | INV. BUFFER |
| 10 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | - | - | - | - | - | - | - | $\bullet$ | $\bullet$ | A | - | OUTNT VOL |
| 2 - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - |  | - | - | - | - | - | - | - | - | $\bullet$ | A |  | $\bullet$ | OUTPUT Voh |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13 \| 12 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 <br> 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1111$ |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN | 5 | 4 | 3 |  | 2 | 9 | 8 | 7 | 6 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 |  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 9 | 8 | 7 | 6 | 18 |
| O8 |  |  |  |  | 5 |  |  |  | $>0$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## Schmitt Trigger Using PLS153 and PLS159



TC01890S
Figure 4. Schmitt Trigger Using One I/O Pin


TCO1s00s
a. High Going Low Direction


TCO1910S

## b. Low Going High Direction

Figure 5. Schmitt Trigger

APPENDIX A


NOTE:
$\mathrm{R}_{1}=3.9 \mathrm{k} \Omega, \mathrm{R}_{2}=10.8 \mathrm{k} \Omega, \mathrm{R}_{3}=2.0 \mathrm{k} \Omega, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, Ambient temperature $\approx 25^{\circ} \mathrm{C}$
Figure A-1. A Non-Inverting Schmitt Triggered Buffer

## Application Note

## Application Specific Products

## DESCRIPTION

A PLS159 is used to implement a pair of dice. Each die is represented by a series of six different state transitions. Two push button switches are used to "roll' the dice; in other words start/stop the state transitions. Each push button controls one die. When the switches are held low, the state transitions take place for each die and the result is displayed when a push button is released.
Each die is made up of seven LED's which are connected to the outputs of the PLS159. The system also contains its own oscillator which generates the clock cycle necessary for the state transitions.

The random release of the push button provides a random output. The high frequency of the internal oscillator and the fact that the switches are not debounced, add more 'randomness" to each event.

The overall system configuration is shown in Figure 3.

## LOGIC IMPLEMENTATION

The configuration of each die is shown in Figure 1, with each letter representing an LED.

To represent the numbers one through six the LED's are turned on as shown in Figure 2.

Table 1 is the truth table generated from Figure 2.


Figure 1. Dice Configuration


Figure 2. Number Representation

## Table 1. Truth Table for Dice

|  | $\mathbf{A}$ | $\mathbf{B}$ | $\mathbf{C}$ | $\mathbf{D}$ | $\mathbf{E}$ | $\mathbf{F}$ | $\mathbf{G}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| One | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| Two | 0 | 0 | 1 | 0 | 1 | 0 | 0 |
| Three | 0 | 0 | 1 | 1 | 1 | 0 | 0 |
| Four | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
| Five | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| Six | 1 | 1 | 1 | 0 | 1 | 1 | 1 |

The result of Table 1 is the following logic equations:

$$
\begin{aligned}
& \text { A }=\text { Four + Five + Six; } \\
& B=\text { Four + Five + Six; } \\
& C=\text { Two + Three + Six; } \\
& D=\text { One + Three + Five; } \\
& E=\text { Two + Three + Six; } \\
& \text { F }=\text { Four + Five + Six } ; \\
& \text { G }=\text { Four + Five + Six; }
\end{aligned}
$$

As can be seen from the above logic equations:

$$
\begin{aligned}
& A \equiv B \equiv F \equiv G ; \\
& C=E ;
\end{aligned}
$$

Table 2 is the result of Table 1 and the above common terms.

Table 2. Truth Table for PLS159 Outputs

|  | $\mathbf{A}, \mathbf{B}, \mathbf{F}$, <br> $\mathbf{G}$ | $\mathbf{C}, \mathbf{E}$ | $\mathbf{D}$ |
| :--- | :---: | :---: | :---: |
| One | 0 | 0 | 1 |
| Two | 0 | 1 | 0 |
| Three | 0 | 1 | 1 |
| Four | 1 | 0 | 0 |
| Five | 1 | 0 | 1 |
| Six | 1 | 1 | 0 |

For each die, three outputs of the PLS159 are needed to implement the logic in Table 2. These outputs are connected to the LED's as follows:

FO: A, B, F, G;
F1: C, E;
F2: D;
Similarly for the second die:
F3: A', B', F', G';
F4: C', E';
F5: $\mathrm{D}^{\prime}$;


Figure 3: Dice Implementation Using the PLS159

## STATE TRANSITIONS

Figure 4 shows two arbitrary state transition sequences which are used to implement each die.

These state transitions are implemented in the program table of the PLS159.

## INTERNAL OSCILLATOR

An internal oscillator is also implemented for the system. The internal configuration of the oscillator is shown in Figure 5. For a detailed explanation of the implementation of this oscillator see AN13: Oscillator with the PLS159. B0 is connected externally to the clock input of the PLS159.

## EXPLANATION OF PROGRAM TABLE

The program table for the two dice is shown in Table 3.

Terms 0-5 and 7-12 represent the state transitions for each die.

Terms 14-15 and 17-18 reset the flip-flops to HLL and HLH if undefined states occur, such as during power up.
Terms 20 and 21 and output controls terms D1 and D2 are used to implement the internal oscillator (see AN13).

Inputs 10 and 11 are connected to the two push button switches which roll the dice. These inputs are programmed to be ActiveLow. When the push button is closed the state transitions take place, and upon release of the push button, the current states are displayed on the outputs.

The outputs of the PLS159 are inverted and this must be taken into consideration when assigning ' $H$ ' and ' $L$ ''s to the F0, F1, F2, F3, F4, and F5. These assignments are shown in Table 4. All the flip-flops are set to be of the J-K type.

Table 4. H And L Assignment

|  | F2, F5 | F1, F4 | F0, F3 |
| :--- | :---: | :---: | :---: |
| One | H | L | L |
| Two | L | H | L |
| Three | H | H | L |
| Four | L | L | H |
| Five | H | L | H |
| Six | L | H | H |



Figure 5. Oscillator Configuration

Electronic Dice

Table 3．Program Table for 2 Dice

| CODE NO． |  |  |  |  |  |  |  |  | FF MODE |  |  |  |  |  |  |  | REMARKS | $\mathrm{EB}_{B}$ |  |  |  | $\frac{E_{\mathbf{A}}}{\bullet}$ |  |  |  | POLARITY |  |  |  | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  | A | A | － | － | $\bullet$ | － | $\bullet$ | － |  | － |  |  |  |  |  |  |  | L | L H | H | $L$ |  |
|  | AND |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | （OR） |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 |  |  | B（1） |  |  |  | C（P） |  |  |  |  |  |  |  |  | Q（N） |  |  |  |  |  |  |  | $\mathrm{B}(\mathrm{O})$ |  |  |  |  |
|  | 3 | 2 | 11 | 0 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |  |
| 0 － | － | － | － | L | － | － | － | － | － | － | － | － |  | H | $L$ | L | $100 \rightarrow 101$ | － | － | － | － | － | H | 1 | H | － | $\bullet$ | － | $\bullet$ |  |
| 1 | － | － | － | L | － | － | － | － | － | － | －1 | － |  | H | L | H | $101-110$ | － | － | － | － | － | H | 4 | L | ＊ | $\bigcirc$ | － | ${ }_{\square}$ |  |
| 2 | － | － | － | L | － | － | － | － | － | － | － | － |  | H | H | $L$ | $110-011$ | － | － | － | － | － | $L$ | H | H | － | $\bullet$ | － | $\bullet$ | DIEC 1 |
| 3 | － | － | － | L | － | － | － | － | － | － | － | － |  | L | H． | H | $\mathrm{O} / 1 \rightarrow 010$ | － | － | － | － | － | $L$ | H | $L$ | － | － | － | － |  |
| 4 | － | － | － | L | － | － | － | － | 二 | － | － | －1 |  | $L$ | H | $L$ | $010 \rightarrow 001$ | － | － | － | － | － | $L$ | 1 | H | － | $\bullet$ | $\bullet$ | $\bullet$ |  |
| 5 | － | － | － | $L$ | － | － | － | － | － | － | － | － |  | $L$ | L | H | $001 \rightarrow 100$ | － | － | － | － | － | H | $L$ | 4 | － | － | － | $\bullet$ |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 7－ | － | － | L | － | － | － | － | － | － | － | H | L | H | － | － | － | $101 \rightarrow 100$ | － | － | H | $L$ | 2 | － | － | － | － | $\bullet$ | $\bullet$ | $\bullet$ | ） |
| 8 | － | － | $L$ | － | － | － | － | － | － | － | H | L | L | － | － | － | $100-110$ | － | － | H | H | 2 | － | － | － | － | $\bullet$ | － | $\bullet$ | － |
| 9 | － | － | 1 | － | － | － | － | － | － | － | H | H | L | －1 | － | － | $110 \rightarrow 018$ | － | － | 4 | H | H | － | － | － | － | － | － | － | DiE2 |
| 10 | － | － | 1 | － | － | － | － | － |  | － | $L$ | H | H | －1 | － | － | $011 \rightarrow 001$ | － | －1 | $L$ | 2 | H | － | － | － | $\bullet$ | $\bullet$ | － | $\bullet$ | \％ |
| 11 | － | － | $L$ |  |  | － | － | － | $\rightarrow$ | －1 | L | L | H | － | －1 | － | $001 \rightarrow 010$ | － | － | $L$ | H | 2 | － | － | －1 | $\bullet$ | － | $\bullet$ | $\bullet$ |  |
| 12 － | － | － | L | － | － | － | － | － | － | － | $L$ | H | 2 | － | － | － | $010 \rightarrow 101$ | － | － | H | L | H | － | － | － | － | $\bullet$ | $\bullet$ | － | － |
| 13 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 | － | － | － | － | － | －1 | － | － | － | － | － | － | － | $L$ | 2 | 1 | Undelined | － | － | － | － | － | H | $L$ | $L$ | $\bullet$ | $\bullet$ | $\bullet$ | － | Goto 100 |
| 15 | － | － | － | － | － | － | － | － | － | － | － | － | － | $\boldsymbol{H}$ | H | H | ctates for | － | － | － | － | － | H | L | $L$ | － | $\bullet$ | $\bullet$ | $\bullet$ |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 | － | － | － | － | － | －1 | － | － | － | － | L | L1 | 16 | － | － | － | Undefingd | － | － | 二 | H | $L$ | H | － | －1 | $\bullet$ | － | － | $\bullet$ | coto 101 |
| 18 | － | 二 | －1 |  | － | － |  | － | －1 | －1 | 4 | H | H | － | － | － | tstestor | －1 | － | － | H | $L$ | H | － | －1 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 － | － | － | － | － | － | － | － | H | － | － | － | － |  | － | － | － | Qreillatr | － | － | － | － | － | － | － | － | $\bullet$ | － | A | － | $B_{0}=B_{4}$ |
| 21 － | － | － | － | － | － | － | － | － | － | － | － | － | － | － | － | － |  | － | － | 二 | － | － | － | － | － | － | － | $\bullet$ | A | $8 \mathrm{CO})_{1}=$ Low |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FC | － |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  | $1$ |  |  |  |  |
| RB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $1$ | $1$ | 1 |  |  |  |
| LB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\mathbf{i}$ | $i$ | i |  |  |  |
| PA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | \| |  |  |  |  | 1 | $1$ | 1 | 1 |  |  |
| RA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $11$ | $1$ |  | $1$ | $1$ |  |  | $1$ | $1$ | 1 |  |  |
| LA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | I |  |  |  |  |  |  |  |  | 1 |  |  |
| D3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D1－ |  | － | － | － | － | － | － | － | － | － | － | － | － | － | － |  | Enate Ent | 1 | $11$ |  |  |  | $11$ | 1 |  |  |  |  |  |  |
| D0－ |  | － | － | － | － | － | H | － | － | － | － | － | － | － | － |  | $\frac{\text { Enate Beyo }}{\text { firterax } 20}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| PIN | 5 | 4 | 3 | 2 | 9 | 8 | 7 | 6 | 191 | 18.1 | 171 | 16 | 151 | 14 | 13 | 12 |  | 19 | 18 | 171 | 16 | 151 | 14 | 13 | 12 | 9 | 8 | 7 | 6 | 19 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## INTRODUCTION

The 82S159 is a field-programmable logic sequencer which is self-contained as a logic sequencer except for the need of a system clock and/or one or more debounced switches. Generally, most of the debouncers circuits utilize a cross-coupled NAND/NOR to form an RS-latch which takes two input pins. To economize the I/O pin consumption, a single $1 / O$ pin may be used to debounce a single pole double throw switch. This scheme is applicable to all Signetics PLD's (Programmable Logic Devices) that have non-registered bi-directional I/O's, including 82S153/ 153A, and 82S155.

## Application Specific Products

AN20

## Single Pin Debouncer Using 82S153/159

## Application Note

## DESCRIPTION

Figures 1a and 1b are logic diagrams of the circuit which utilizes one I/O pin of the 82S153/153A and 82S159 respectively to form a debouncer. The single pole double throw switch is connected, at one terminal, to $\mathrm{V}_{\mathrm{CC}}$, and, at another terminal, to ground. The blade of the switch is connected to BO. BO is programmed as an output. The input buffer of BO is programmed to drive a p-term which, in turn, drives the output BO. The circuit latches to whichever state it is in . As an example, assuming that the output B0 is connected to $V_{C C}$ through the switch, and its output is a " 1 ". When the switch is flipped from $V_{C C}$ to ground, BO is momentarily short circuited to
ground. After one propagation delay (1530 ns ), BO is set to " 0 " and no more current will flow from BO. If the switch is flipped back to $\mathrm{V}_{\mathrm{CC}}, B 0$ will be shorted to $\mathrm{V}_{\mathrm{CC}}$ for one prop delay and will be set to a "1" and will stay a " 1 " until the switch is flipped again. The switch may bounce while the blade breaks from one terminal and bounce again while it makes contact with the other terminal. As long as the movement of the blade is smaller than the gap which separates the two terminals, the output will remain stable.
The circuit is implemented in an 82S159 using AMAZE as shown in Figures $2 \& 3$, and Table 1.


Figure 1. Single Pin Switch Debouncer Circuit

| LABEL | ** | FNC | **P | IN |  | - PIN | N* FNC | ** | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| N/C | ** | CK. | ** | 1-1 |  | 1-20 | ** +5V | **VCC |  |
| N/C | ** | I | ** | 2-: |  | 1-19 | ** B | **N/C |  |
| N/C | ** | I | ** | 3-1 |  | 1-18 | ** B | **N/C |  |
| N/C | ** | I | ** | 4-1 | 8 | 1-17 | ** B | **N/C |  |
| N/C | ** | I | ** | 5-1 | 2 | :-16 | ** B | **N/C |  |
| SWITCH | ** | 0 | ** | 6-1 | 5 | 1-15 | ** 0 | ** INFU | IT_LATCH |
| N/C | ** | /B | ** | 7-1 | 1 | 1-14 | ** E | **N/C |  |
| N/C | ** | /B | ** | 8-: | 5 | 1-13 | ** B | **N/C |  |
| N/C | ** | /B | ** | 9-1 | 9 | 1-12 | ** B | **N/C |  |
| GND | ** | OV | ** | 10-1 |  | 1-11 | ** /DE | **N/C |  |

Figure 2. Pin List

```
********************** DEBDUNCE
@DEVICE TYPE
82S159
GDRAWING
************ SINGLE FIN DEEDUNCER
@REVISIDN
************ REV -
@DATE
************ 
@SYMEOL
************* DESOUNCE
GCOMPANY
************ SIGNETICS
@NAME
@DESCRIFTION
This circuit accepts a single pole double pole switch which switches between
VCc and GRDUND. EO is used as input, but it is defined in AMAZE as output.
BO may be used to drive the rest of the logic circuit or it may be used
in conjunction with one of the internal flip flops as registered input to
handle asynchronous input to a state machine.
GCOMMON FRODUCT TEFM
@COMPLEMENT AFIFIAY
@I/O DIFECTION
@OUTFUT FOLARITY
@FLIF FLOF CONTROL
@OUTFUT ENAELE
GFEGISTER LDAD
@ASYNCHFIONOUS FRESET/RESET
@FLIF FLOF MODE
GLOGIC EQUATION
SWITCH = SWITCH;
"************************************************
    * BO WITH LATCHED INFUT *
    ****************************************************)
/INFUT_LATCH:D D SWITCH;
```

Figure 3. Boolean Equation File

Table 1. Programming Table


## Signetics

## Application Specific Products

## INTRODUCTION

This application note presents the design of a parity generator using Signetics PLD, 82S153 or 82S153A, which enables the designers to customize their circuits in the form of 'sum-of-products". The PLA architecture and the 10 bi-directional I/O's make it possible to implement the 9-bit parity generator/checker in one chip without any external wiring between pins. A logic diagram of the device is shown in Appendix $A$.

The parity of an 8 -bit word is generated by counting the number of " 1 's" in the word. If the number is odd, the word has odd parity. If the number is even, the word has even parity. Thus, a parity generator designed for even parity, for example, will generate a " 0 " if the parity is even, or a " 1 " if parity is odd. Conversely, an odd parity generator will gengrate a ' 0 " if the parity of the word is odd, or a " 1 " if the parity is even. This bit is then concatinated to the word making it 9 -bits

## 9-Bit Parity Generator/Checker With 82S153/153A

## Application Note

long. When the word is used elsewhere, its parity may be checked for correctness.

## FEATURES

- Generates even and odd parities ( $S_{U M}$ and SUM $_{\mathrm{O}}$ )
- SUM $_{\mathrm{E}}=$ " 1 " for even parity, " 0 " for odd parity
- SUM $_{0}=$ " 1 " for odd parity, " 0 " for even parity
- Generate parity or check for parity errors
- Cascaded to expand word length


## DESCRIPTION

The most straight forward way of implementing the parity generator/checker is to take the 9 -input truth table ( 8 inputs for the 8 -bit word, and 1 input for cascading the previous stage) and put it in a $256 \times 4$ PROM. Since there are $2^{9}$ combinations and half of them is odd,
the other half is even, the circuit will take 256 terms. An alternative is to divide the 9 -bits into 3 groups of 3 -bits as shown in Figure 1. If the sum of the 3 -bits is odd, then the intermediate output SU1, or SU2, or SU3 equals 1. Otherwise it equals 0 . The intermediate results are grouped together and $\mathrm{SUM}_{0}$ becomes " 1 " if the sum is odd, otherwise SUMO equals " 0 ". The circuit is implemented using AMAZE as shown in Figure 3. SU1 is an intermediate output for inputs $l_{0}, l_{1}$ and $I_{2}$. In the same manner, SU 2 and SU 3 are intermediate outputs for $I_{3}, I_{4}, I_{5}$ and $I_{6}, I_{7}, I_{8}$. The design uses up 16 product terms and 5 control terms leaving 16 product terms and 4 bi-directional I/O's to implement other logic designs.

The design is tested by using the logic simulator provided by AMAZE. The input test vector is chosen to exhaustively test for all 8 input combinations at all 4 sections of the circuit.


| $\mathbf{I}_{\mathbf{0}}$ | $\mathbf{I}_{\mathbf{1}}$ | $\mathbf{I}_{\mathbf{2}}$ | $\mathbf{S U 1}$ |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |


| $\boldsymbol{I}_{\mathbf{3}}$ | $\mathrm{I}_{\mathbf{4}}$ | $\mathbf{l}_{\mathbf{5}}$ | SU2 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 |


| $I_{6}$ | $I_{7}$ | $I_{8}$ | SU3 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 |


| SU1 | SU2 | SU3 | SUM $_{\mathbf{0}}$ | SUM $_{\mathbf{E}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 |

Figure 1. Block Diagram of 9-Bit Parity Generator/Checker


```
********************** PAFPGEN ***********************
aDEVICE TYPE
82S153
GDRAWING
```



```
GREVISION
*********************************** FEEV. -
@DATE
********************************* x%/xx/x\timesx\timesx
@SYMBOL
******************************** FILE ID: FARGEN
GCOMPANY
*********************************** SIGNETICS
ENAME
@DESCRIPTION
****************************************************************************
* This circuit is a 9-bit parity generator/checker commonly used *
* for error detection in high speed data transmission/retrieval. *
* The odd parity output (SUMD) is high when the sum of the data
* bits is odd. Otherwise it is low.
* The even parity output (SUME) is high when the sum of the data
* bits is even. It is low otnerwise.
```



```
@COMMON FRODUCT TERM
@I/O DIRECTION
```



```
* StI, SU2 and SUS are outputs which are defined in the PIN LIST *
* and therefore they don't need to be defined here again.
```



```
"
GOUTFUT FOLARITY
```




```
* FIN LIST. They don't have to be defined again here. *
```



```
"
glogic equation
```



```
* SU1, SU2, and SUS are intermediate terms
************************************************************************
```



```
SU1 = /I2 */I1 * IO + /12 * I1 * /IO +
12*/I1 */IO + 12* I1 * 10;
SU2 =/I5 */14**IS +/IIS* I4 */IS
SU3 = /I8 * /17 * 16 +/I8 * 17 */16 +
    18 * /17 * /I6 + 18 * 17 * 16 ;
SUMO = /SU1 */SU2 * SUS + /SU1 * SU2 * /SUS +
    SU1 * /SU2 * /SU3 + SU1 * SU2 * SU3 ;
SUME =/(/SU1 */SUZ * SUS + /SU1 * SU2 * /SU3 +
            SU1 * /SU2 * /SU3 + SU1 * SU2 * SU3) ;
```

Figure 3. AMAZE Implementation of the Parity Generator/Checker Circuit

Table 1. Programming Table



## 9－Bit Parity Generator／Checker With 82S153／153A

```
"
" SS EXFECTED
OLTFUTS
"IIIIIIII MMBBERULUII EBEEB
"76543こ10 E076543こ18
    LLLLLLLL /////////L
    HLHHLHiLL /////////H
    LHHLLHHL /////////H
    HHLHLLHL /////////L
    LLHLHHLH /////////H
    HLLHHLLH /////////L
    LHLLHLHH /////////L
    HHHHHHHH /////////H
QUIT
    983こ1
    "HLLLLL
    "LHLLLH
    "LHLHL
    "HLLHH
    "LHHLL
    "HLHLH
    "HLHHL
    "LHHHH
```



* This is a test patterr, for the $Э$-bit parity gereratir/checker
* circuit. The simulator will use this file as an irput to



## a．Input Pattern PARGEN．TST

S2S15．Aipargen．STD
This file is the result of logic simulation of the parity generator／checker circuit．The inputs are read from input file FARGEN．TST
＂INFUTS $\leqslant=E(I / D)=>$ TFIACE TEFMS
＇ 765432109875543210
＂
00000000 HL．．．．LLLO ：
10110100 LH．．．．LLHI ；
01100110 LH．．．．LHLI ； $11010010 \mathrm{HL} . .$. LHHO ； 00101101 LH．．．．HLLI $10011001 \mathrm{HL} . .$. HLHO ； $01001011 \mathrm{HL}====\mathrm{HH} \mathrm{O}$ ？ 11111111 LH．．．．HHH1；
＂

＂OOIIIIOOOI
CONTFOL LINES DESIGNATED I／O USAGE ACTUAL I／O USAGE

FIN LIST．．．

|  | 98 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | 09

b．Output File From SIMULATOR
Figure 4．Tesí Veciors

## 9-Bit Parity Generator/Checker With 82S153/153A

APPENDIX A


NOTES:

1. All programmed "AND" gate locations are pulled to logic "1"
2. All programmed "OR" gate loc

Figure A-1. FPLA Logic Diagram

## Signetics

AN22
PLS151 Toolkit

## Application Note

Application Specific Products

a. Basic Gates Configuration



```
******************** TK152-1 #######*************
QDEVICE TYPE
************** 825151
ODRAWING
************ FIELIRE 1. BASIC EATE CONFIEURATIONS
EREVISION
************* TK151-1 RESV. 0
EDATE
***##******* JLL_Y 10, 1985
SSYMBOL
************ TK151-1
GCOMPANY
#*********** SIGNETICS
GNAME
************ DAVID K. WONG
EDESCRIPTION
This file contains the G basic logic gates: AND, NAND, OR, NOR, XOR and EQU.
ECOMMON PRODUCT TERM
EI/O DIRECTION
COUTPUT POLARITV
GI/O STEERING
GLOGIC EQUATION
A_AND_B =A*B;
D_NAND_E = /(DD*E);
A_OR_B}=1(1/A*/B;
A_NOR_B = /A */B;
AB_OR_DE = /( /(A_AND_B) * D_NAND_E ) ;
AB_NOR_DE = /(A_ANDD_B) * D_NAND_E ;
A_N_B-}=A*/B
A-_N_B = /A *B;
A_XOR_B = /(/(A_N_B-) */(A-_N_B));"Equivalent to (A */B) + (/A * B) "
A_EQU_B = / (A_N_B-) */(A-_N_B); "Equivalent to (/A */B) + (A * B) "
```

c. Boolean Equations of Basic Gate Configurations

Figure 1 (Continued)

Table 1. Program Table of Basic Gate Configurations


a. Basic Latches Configuration



| LABEL | ** FNC | **PIN |  | PIN | ** | FNC | \#* | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R1- | ** I | ** 1-1 |  | :-20 | ** | +5v | **VCC |  |
| S1- | ** I | ** 2-; |  | : -19 | ** | 10 | **Q1 |  |
| RR2 | **I | ** 3-1 |  | :-18 | ** | 10 | **Q1 |  |
| SS2 | I | ** 4-1 | 8 | t-17 | ** | 0 | **Q2 |  |
| DIN | ** I | ** 5-1 | 2 | : -16 | ** | 0 | **Q2 |  |
| LE- | **I | ** 6-1 | 5 | :-15 | ** | 10 | **Q3 |  |
| N/C | **/B | 7-1 | 1 | : -14 | ** | 0 | **D_N | LE |
| N/C | **/B | ** 8-1 | 5 | :-13 | ** | 0 | **Q3 | N_LE- |
| N/C | ** /B | ** 9-1 | 1 | :-12 | ** | /B | **N/C |  |
| GND | ** OV | ** 10-1 |  | :-17 | ** | /B | **N/C |  |

```
*********************** TKIS1-2 **************************
QDEVICE TYPE
825151
eDRAWING
******###### FIELRE 2. BASIC LATCHES CONFIEURATION
EREVISION
************ TK1S1-2 REV. O
EDATE
************** JLL_Y 10, 1985
esYmBOL
************* TK151-2
#*******N
MCDMPANY STONETICS
**************** SIGNETIC
MNANE
*#********** DAVID K. WONG
EDESCRIPTION
This files contains basic configurations of two RS-latches and a D-latch.
ECOHMON PRODUCT TERH
QI/O DIRECTION
QIO DIRECTION
EI/O STEERING
QI/O STEERING
"*************************************
    * CROSS-COUPLED NAND RS-LATCH *
    **********************************
Q1- =II/(/R1- * Q1) ;
Q1 = / (/S1-* Q1-) %
    "***************************************
    * CROSS-COUPLED NOR RS-LATCH *
    *******##########################
Q2- = RR2 * O2;
Q2 = SS2 * O2-;
```



```
    # D-LATCH 
D_N_LE = DIN LE- ;
Q3_N_LE- = Q3 */LE- % (D_N_LE) */(OS_N_LE-) )
```

Figure 2 (Continued)

Table 2. Program Table of Basic Latches

| ******* <br> Cust/Project - ** <br>  <br> Rev/I. D. - *********** TK151-2 REV. 0 <br>  <br> LDSRSRQQQQQDENNNNN <br> EISR11111223_3/1/1/1 <br>  <br> E L |
| :---: |




## c. Boolean Equations of 4-Bit D-Latch

Figure 3 (Continued)
Table 3. Program Table of 4-Bit D-Latch



```
******************茾*TK151-4 **********************
EDEVICE TYPE
825151
GDFAWING
************ PLS151 TOOL,KIT FIGUPE }
GREVISION
************ tk151-4 REV. O
edATE
************ JURY 10, 1985
ESYMBOL
************ TK151-4
ECOMPANY
************ SIGNETICS
ENAME
************ DAVID K. WONG
@DESCRIPTION
This file contains a single pin debouncer and a pulse shaper.
ECOHMON PRODUCT TERM
QI/O DIRECTION
EOUTPUT POLARITY
QI/0 STEERING
ELOGIC EQUATION
"***************************************************************************
    * DEBOUNCER -- This circuit uses one bidirectional pin to de- *
        * DEBOUNCER -- This circuit uses one bidirectional pin to de-
                    bounce a single pale double throw switch. When
                    it shorts the output to vec or ground. One pro-
                        pagation delay later, the output is switched to
                            the same polarity as the switch.
    ##*************************************************************************)
    IN1 = IN1;
*************************************************************************
    * PULSE SHAPER -- This circuit creates a LOW-to-HGH glitch
        * which has the pulse width of one prop delay.
        * Wider pulse width may be generated with add-
    * itional feedback loops.
    ********************************************************************)
INZ- =/(IN2);
OUT2 = IN2**IN2:
```


## c. Boolean Equations of Single Pin and Pulse Shaper

Figure 4 (Continued)
Table 4. Program Table of Single Pin Debouncer and Shaper


## AN23

## PLS168/168A Primer

## Application Note

## Application Specific Products

## INTRODUCTION

THE PLS168/168A is a bipolar Field-Programmable Logic Sequencer as shown in Figure 1, which consists of 12 inputs, a 48 product term PLA and $14 \mathrm{R} / \mathrm{S}$ flip-flops. Out of the 14 flip-flops, six are buried State Registers ( $\mathrm{P}_{4}-\mathrm{P}_{9}$ ), four Output Registers ( $\mathrm{F}_{0}-\mathrm{F}_{3}$ ), and four Dual-purpose Registers ( $P_{0}-P_{3}$ ), which may be used as Output or State Registers. All flip-flops are positive edge-triggered. They are preset to "1" at power-up, or may be asynchronously set to " 1 " by an optional PR/OE pin, which may be programmed either as a preset pin or as an Output Enable pin. Additional features includes the Complement Array and diagnostics features.

## ARCHITECTURE

As shown in Figure 2, the device is organized as a decoding AND-OR network which drives a set of registers some of which, in turn, feedbacks to the AND/OR decoder while the rest serve as outputs. Outputs $P_{0}$ to $P_{3}$ may be programmed to feedback to the AND/OR decoder as State Registers and, at the same time, used as outputs. The user now can design a 10 -bit state machine without external wiring. The AND/OR array is the classical PLA structure in which the outputs of all the AND gates can be programmed to drive all
the OR gates. The schematic diagram of the AND-OR array is shown in Figure 3. This structure provides the user a very structured design methodology which can be automated by CAD tools, such as Signetics AMAZE software package. The output of the PLA is in the form of sum-of-products which, together with the RS flip-flops, is the ideal structure for implementation of state machines. (Refer to Appendix A for a brief description of synchronous finite state machines.)

## Design Tools

A direct approach to implement a design using the PLS168/168A is the H/L table supplied in the data sheet as shown in Table 1. The table-is organized according to input and output of the PLA decoding network. The lefthand side of the table represent the inputs to the AND-array, which includes input from input pins and present state information from the feedback buffers which feedback the contents of the State Register. The righthand side of the table represents the output of the OR-array, which drives the State and Output Registers as the next state and output. Each column in the lefthand side of the table represents an input buffer, which may be inverting, non-inverting, disconnected or unprogrammed. Each column in the righthand side of the table represents a pair of outputs to the flip-flops, which may be set, reset,
disconnected, or unprogrammed. The programming symbols are $\mathrm{H}, \mathrm{L},-$, and 0 . (See Figure 4 for details.) For inputs buffers, " H " means that the non-inverting buffer is connected, ' $L$ " means that the inverting buffer is connected, "-" means that both inverting and non-inverting buffers are disconnected, and " 0 " means that both inverting and noninverting buffers are connected which causes that particular AND-term to be unconditionally Low. On the output side of the table, " H " means that the particular AND-term is connected to the OR-term on the ' $S$ ' input of the particular flip-flop, "L" means that the AND. term is connected to the " R " side, "-" means that the AND-term is not connected to the flip-flop at all, and ' 0 ' means that the AND-term is connected to both the " S " and " R " sides. More details of the symbols and their meanings are shown in Appendix B. Each row in the table represents an ANDterm. There are 48 AND-terms in the device. Therefore, there are 48 rows in the table. An example of implementing a transition from one state to another is shown in Figure 4 a . The state diagram can be implemented by the PLS168 as shown in Figure 4b. The state diagram is translated into $\mathrm{H} / \mathrm{L}$ format as shown in Figure 4c. The first column on the lefthand side of the table is for the Complement Array which will be discussed in detail in the next section.

## PLS168/168A Primer



## NOTES

Table 1. PLS168/168A Programming Table



Figure 2. The Architecture of PLS168/168A


Figure 3. Schematic Diagram of AND-OR Array

a. State Diagram
b. Implementation of State Diagram (a) With PLS168


TBOzO10S
c. PLS168 Programming Table

Figure 4. Implementing State Machine With PLS168


Figure 5. Logic Diagram of Complement Array

## Complement Array

An additional feature is the Complement Array, which is often used to provide escape vectors in case the state machines get into undefined states during power-up or a timing violation due to asynchronous inputs. A logic diagram of the Complement Array is shown in Figure 5. The output of the Complement Array is normally Low when one or more ANDterms are High. If all of the AND-terms are Low, then the output of the Complement

Array will be High. In this example, if each AND-term is a decoder for a particular state and input combination, and if the circuit gets into an undefined state, none of the ANDterms will be High. Therefore, the output /C will be High, which will then enable the ANDterm $S$ which in turn may be used to reset all registers to Low or High as predefined. The state machine thus escapes from being in an undefined state by using the Complement Array and one AND-term. Without the Complement Array an alternate way of escaping
from being in an undefined state is by defining all possible states which are not being defined. This method may require quite a few AND-terms depending on the design. Another application for the Complement Array is illustrated by the following example. As shown in Figure 6, when the machine is in state 23, if input vector equals 1001, it will go to next state 24. If the input is 1101 , then go to state 25. But if the input is neither 1001 nor 1101, then go to state 03. It takes only two terms to implement the first two transition vectors. To implement the third vector "go to state 03 if input is neither 1001 nor 1101', the Complement Array accepts the outputs of the first two AND-terms as inputs. If the input vector is neither 1001 nor 1101, then both terms will be Low, which causes the output of the Complement Array (/C) to be High. A third AND-term is used to AND state 24 and /C together to set the registers to state 03. The State Diagram is translated into AMAZE syntex as shown in Figure 6b, where all vectors are in square brackets and the Complement Array is represented by the ELSE statement. The State diagram Figure 6a can also be expressed in the format of a program table as shown in Figure 6c. The complement array may be used to exit from different present states to different next states. It can be used many times in one state machine design as shown in Figures $7 \mathrm{a}, \mathrm{b}$, and c where the state diagram is implemented using the AMAZE state equation syntex and the $\mathrm{H} / \mathrm{L}$ format.


NOTE: $\overline{8001}+\overline{101}=\overline{1001+101}$
AFO224IS

## a. State Diagram

WHILE [23]
IF [1001] THEN [24] WITH
[OUT1]
IF [1101] THEN [25] WITH
[OUT2]
ELSE: [03] WITH [OUT9]
b. AMAZE State Equation Syntex

reozeots
c. H/L Format

Figure 6. Application of Complement Array


## a. State Diagram

WHILE [00]
IF [0000] THEN [01] WITH [OUTO]
IF [0001] THEN [02] WITH [OUT1]
ELSE: [3F] WITH [OUT9]
WHILE [01]
IF [0010] THEN [03] WITH [OUT2]
IF [0011] THEN [04] WITH [OUT3]
ELSE: [2F] WITH [OUT6]
WHILE [02]
IF [0100] THEN [05] WITH [OUT4]
IF [0101] THEN [06] WITH [OUT5]
ELSE: [2F] WITH [OUT7]

## b. AMAZE State Equation



## c. PLS168 Programming Table

Figure 7. Applications of Complement Array


Figure 8


Figure 10. Change of tcko Due to Metastable Condition of Flip-Flop

## Optional Preset/Output Enable

The PR/OE pin provides the user with the option of either using that pin to control the Tri-state output buffers of the Output Registers, or have that pin to asynchronously preset all registers to High. The purpose of the preset function is to provide the system a way to set the PLS168 to a known state, all Highs. The output enabie function are sometimes used where the state machine is connected to a bus which is shared by other output circuits. It is also used during power-up sequence to keep the PLS168 from sending power glitches to other circuits which it drives. By programming the PR/OE pin to control the Tri-state output buffers, the preset function is permanently disabled. By programming the PR/OE pin to control the asynchronous preset of the registers, the output buffers are permanently enabled. While using the preset function to asynchronously preset the register, if a rising edge of the clock occurs while the preset input is High, the registers will remain preset. Normal flip-flop operation will resume only after the preset input is Low and the rising edge of the next clock. Setting the registers to a predefined pattern other than a!! Highs may be accomplished by using a dedicated p-term, which is activated by an input pin which will also inhibit all other p-terms which are being used. The inhibiting of other p-terms eliminates the problem of undetermined state of an RS filip-flop caused by having Highs on both $R$ and $S$ inputs.

## Diagnostic Features

In debugging a state machine, sometimes it is necessary to know what is the content of the state register. The buried State Register may be read by applying +10 V on $\mathrm{I}_{0}$, which will cause the contents of register bits $\mathrm{P}_{4}$ to $\mathrm{P}_{5}$, $P_{6}$ to $P_{9}$ to be displayed on output pins $F_{2}$ to $F_{3}$ and $P_{0}$ and $P_{3}$ respectively. While the devica can handle the +10 V on pin $\mathrm{l}_{0}$, prolonged and continuous use will cause the chip to heat up since more power is being dissipated at +10 V . To facilitate more expedient functional tests, synchronous preset vectors as described above may be used to set the State Register to different states without having to go through the entire sequence.

## Timing Requirements

Since the PLS168 is intended to be a synchronous finite state machine, the inputs are expected to be synchronous to the clock and set-up and hold time requirements are expected to be met. In general, the set-up time requirement is measured at its worst case as having the entire AND-array connected to the OR-term being measured and there is only one active AND-term to drive the entire line. The set-up time decreases from there as less $p$-terms are used. This is due to the capacitance of the unused AND-terms being removed from the line. Figure 8a shows the typical set-up time requirement of a PLS168A device. Figure 8 b shows the normalized setup time as a percentage of the worst case,
which is with 48 terms connected. In a typical state machine design, some flip-flops will change states more frequently than others. Those that change more frequently will have more p-term loading on its OR gates than those that change states less frequently. The different loadings on the OR-terms cause different delay on the inputs of the flip-flops as shown in Figure 9. If an input fails to meet the set-up time specification, it is possible that the resultant of the input change gets to one set of flip-flops before the rising edge of the clock while it gets to other flip-flops during or after the clock's rising edge. The result is that some flip-flops have changed states and some have not, or some get into metastable condition as shown in Figure 10. The state machine is now either out of sequence or is in an undefined state. This problem often occurs with asynchronous inputs which is generated totally independent of the clock on the system. A common remedy for the problem of asynchronous inputs is to use latches or flipflops to catch the input and then synchronously feed it to the state machine. This minimizes the problem with the different propagation delays due to different p-term loading. But there is still a finite probability that the external latches or flip-flops will get into metastable condition, which may be propagated into the state machine. Nevertheless, the window for the flip-flops in state machine to get into undefined states or metastable condition is narrowed by a great extent.

## APPENDIX A

## INTRODUCTION TO STATE MACHINE

A state machine is a synchronous sequential circuit which interprets inputs and generates outputs in accordance with a predetermined logic sequence. It is analogous to running a computer program with a computer. The state machine, with its sequence coded in hard-
ware, can run much faster than a computer running the sequence in software. Therefore, it is often used in controller applications where speed is important.
Generally, state machines may be classified as Mealy or Moore machines as shown in Figures 1a and 1b. The fundamental difference of the two types are: the output of a Moore machine is a dependent of only the
state of the memory elements whereas the output of a Mealy machine is a dependent of both the state of the memory elements and the inputs to the state machine. The figures also show graphic representations of the logic sequence in the form of state diagram in which the bubbles represent state vectors, and the arrows represent transitions from present states to next states.


AF02220S
Appendix A-1. Moore Machine Model


## APPENDIX B

## LOGIC PROGRAMMING

The FPLS can be programmed by means of Logic programming equipment.
With Logic programming, the AND/OR gate input connections necessary to implement the desired logic function are coded directly from the State Diagram using the Program Table on the following page.
In this table, the logic state or action of control variables C, I, P, N, and F, associated with each Transition Term $T_{n}$, is assigned a symbol which results in the proper fusing pattern of corresponding link pairs, defined as follows:

## PRESET/DE OPTION - (P/E)



PROGRAMMING:
The PLS168A has a power-up preset feature. This feature insures that the device will power-up in a known state with all register elements (state and output register) at a logic high (H). When programming the device it is important to realize this is the initial state of the device. You must provide a next state jump if you do not wish to use all highs ( H ) as the present state.
'AND' ARRAY - (I), (P)

'OR' ARRAY - (N), (F)

"COMPLEMENT" ARRAY - (C)


## NOTES:

1. This is the initial unprogrammed state of all link pairs. It is normally associated with all unused (inactive) AND gates $T_{n}$.
2. Any gate $T_{n}$ will be unconditionally inhibited if any one of its $I$ or $P$ link pairs is left intact.
3. To prevent simultaneous Set and Reset flip-flop commands, this state is not allowed for $N$ and $F$ link pairs coupled to active gates $T_{n}$ (see flip-flop truth tables).
4. To prevent oscillations, this state is not allowed for $C$ link pairs coupled to active gates $T_{n}$.

## Signetics

## Application Specific Products

## DESCRIPTION

The PLS173 is a 24-pin PLA device which has 10 bidirectional outputs and 12 dedicated inputs. The output of the device is the sum of products of the inputs. The polarity of each output may be individually programmed as Active-High or Active-Low. A logic diagram of the device is shown in Appendix A. A 10-bit comparator similar to the 74LS460 compares two 10 -bit data inputs to establish if EQUIVALENCE or NOT EQUIVALENCE exists. The output has True and Complement comparison status outputs. The logic diagram of the comparator is shown in Figure 1.

The truth table is as shown in Table 1 where vectors $a$ and $b$ are 10-bit inputs to A9 to A0 and $\mathrm{B9}$ to BO . If the input to $\mathrm{A} 9-\mathrm{AO}$ is bit-to-bit equivalent to the input to $B 9-B 0$, the two input vectors are considered EQUIVALENT, and output EQ goes High and NE goes Low. If the two input vectors are not bit-to-bit equivalent, then EQ goes Low and NE goes High. The circuit is implemented with AMAZE as shown in Figures $2 \mathrm{a}, 2 \mathrm{~b}$ and 2 c . The result of logic simulation of the circuit is shown in Figure 2d.

AN24

Application Note

Notice that on the OR side of the program table in Figure 5, all the fuses in the OR-term are intact, which means that all the ANDterms are still connected to all the OR-terms. This feature provides for future modification. But if all the unused AND-terms are deleted, the device will run faster. There are also many unused AND-terms which will provide for future modification. But if they are deleted (both on the AND and OR side), it will amount to about $450 \mu \mathrm{~A}$ per term power saving. Figure 3 is the program table with all unused terms deleted.

Table 1. Function Table

| $\mathbf{A}_{\mathbf{9}}-\mathbf{A}_{0}$ | $\mathbf{B}_{9}-\mathbf{B}_{\mathbf{0}}$ | $\mathbf{E Q}$ | $\mathbf{N E}$ |
| :---: | :---: | :---: | :---: |
| $a$ | $a$ | $H$ | $L$ |
| $b$ | $b$ | $H$ | $L$ |
| $a$ | $b$ | $L$ | $H$ |
| $b$ | $a$ | $L$ | $H$ |



Figure 1. Logical Equivalent Circuit of 10-Bit Comparator
******************** AN24_173 ********************


| LABEL | ** | FNC | **PIN |  |  | FIN** |  | FNC | ** | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 40 | ** | I | ** | 1-1 |  | 1-24 | ** | +5V | **VCC |  |
| 80 | ** | I | ** | 2-1 |  | 1-23 | ** | I | **B9 |  |
| A1 | ** | I | ** | 3-1 |  | 1-22 | ** | I | **A9 |  |
| B1 | ** | I | ** | 4-1 | 8 | i-21 | ** | I | **EB |  |
| A2 | ** | I | ** | 5-i | 2 | :-20 | ** | I | **AB |  |
| B2 | ** | I | ** | 6-1 | 5 | 1-19 | ** | $\square$ | \# HNE |  |
| A3 | ** | I | ** | 7-1 | 1 | :-18 | ** | /0 | **EQ |  |
| E3 | ** | I | ** | 8-1 | 7 | 1-17 | ** | I | **E7 |  |
| A4 | ** | I | ** | 9-1 | 3 | 1-16 | ** | I | **A7 |  |
| E4 | ** | I | ** | 10-1 |  | 1-15 | ** | I | **B6 |  |
| A5 | ** | I. | ** | 11-1 |  | + -14 | ** | I | **A6 |  |
| GND | ** | OV | ** | 12-1 |  | 1-13 | ** | I | ** HS |  |

a. Pin List of 10 -Bit Comparator

Figure 2

```
******************** AN24 173 ********************
gDEVICE TYFE
825173
CDRAWING
================== 10-GIT COMPARATOR USING FLSS173
GREUISION
.......................EEV-O
GDATE
................. OCT-14-85
ESVMEDL
..-................ AN24_173
@COMFANY
*..-............. SIGNETICS
CNAME
\because................ DAVID WDNG
GDESCRIPTION
This circuit compares two lo-bit inputs. If they are bit-to-bit equivalent,
outputs EQ goes HIGH and NE goes LOW. If the inputs are not bit-to-bit equiv-
alent to each other, outputs EQ goes LOW and NE goes HIGH.
ECOMMON PRODUCT TERM
\begin{tabular}{|c|c|c|c|c|c|}
\hline TO & \(=\) & AO & * & /BO & , \\
\hline T1 & \(=\) & /AO & * & B0 & ; \\
\hline T2 & = & A1 & * & /E1 & : \\
\hline T3 & \(=\) & /A1 & * & E1 & ; \\
\hline T4 & = & A2 & * & /B2 & ; \\
\hline T5 & = & /A2 & * & E2 & ; \\
\hline T6 & = & A3 & * & /ES & ; \\
\hline T7 & = & /A3 & * & B3 & 7 \\
\hline TB & \(=\) & A4 & * & /E4 & ; \\
\hline T9 & \(=\) & /A4 & * & B4 & \% \\
\hline 110 & \(=\) & AS & * & /B5 & ; \\
\hline T11 & \(=\) & /A5 & * & B5 & ; \\
\hline T12 & \(=\) & /A6 & * & E6 & \% \\
\hline T13 & \(=\) & A6 & * & /B6 & ; \\
\hline T14 & \(=\) & A7 & * & /E7 & ; \\
\hline T15 & = & /A7 & * & E7 & ! \\
\hline T16 & = & A8 & * & /B8 & ; \\
\hline T17 & \(=\) & /A8 & * & E8 & ; \\
\hline T18 & = & A9 & * & /B9 & ; \\
\hline T19 & \(=\) & /A9 & * & E9 & ! \\
\hline
\end{tabular}
@I/O DIRECTION
GOUTPLUT POLARITY
@LOGIC EQUATION
```



```
    T10+T11+T12+T13+T14+T15+T16 +T17+T1B+T17);
NE = TO + T1 + T2 + TS + T4 + T5 + T6 + T7 + TG +T9 +
    T10 +T11 +T12 +T1Z +T14 +T15 +T16 +T17 +T18 +T17;
b. Boolean Equations of \(\mathbf{1 0}\)-Bit Comparator
Figure 2 (Continued)
```



825173 !
FOLAFIITY


TE01700s
c. Program Table of $\mathbf{1 0 - B i t}$ Comparator After Assembly of Boolean Equation File

Flgure 2 (Continued)
825173 A: AN24_173. STD
" AMAZE FILE ID: AN24 173

* LOGIC SIMLLATION OF 10-BIT COMPARATOR
"
" < = INFUTS==>〈=BiIfO;=> TRACE TERMS
" 11
" 1098765432109876543210
n
000000000000 0000LHOOOO :
0100000000000000 H 10000;
100000000000 0000HL 0000 ;
110000000000 0000LH0000;
000100000000 0000HL 0000
0010000000000000 Hz 0000 ;
001100000000 O000LH0000 ;
000001000000 0000HL 0000 ;
000010000000 0000HL0000 ;
000011000000 0000ㄴH0000 ;
000000010000 0000HL 0000 ;
000000100000 0000HL 0000 ;
000000110000 00001 40000 ;
000000000100 0000HL0000
0000000010000000 H H 0000
000000001100 0000LH0000 ;
0000000000010000 HL 0000 ;
0000000000100000 HL 0000
000000000011 0000Li 10000 ;
0000000000000100 HL 0000
000000000000 1000HL0000 ;
0000000000001100 LHOOOO
000000000000 0001HL0000
0000000000000010 HL 0000
0000000000000011 LHOOOO
0000000000000000 HL 0100
0000000000000000 HL 1000
000000000000 0000LH1100
0000000000000000 HL 0001 ;
0000000000000000 HL 0010 ;
000000000000 0000LH0011;
"
"
" IIIIOOIIII DESIGNATED I/O USAGE
" IIIIOOIIII ACTUAL I/O USAGE
. PINLIST...
$\begin{array}{lllllllllllll}* & 13 & 11 & 10 & 09 & 08 & 07 & 06 & 05 & 04 & 03 & 02 & 01\end{array}$
$\begin{array}{lllllllllll}\text { " } & 23 & 22 & 21 & 20 & 19 & 18 & 17 & 16 & 15 & 14\end{array} ;$
d. Test Vectors Generated by AMAZE After Logic Simulation

Figure 2 (Continued)


Figure 3. Program Table of 10-Bit Comparator With All Unused Terms Deleted

## APPENDIX A

## FPLA LOGIC DIAGRAM FOR PLS173



## NOTES:

# A Simple Entry/Exit Metering Device 

## Application Note

## Application Specific Products

## DESCRIPTION

The following is the implementation of a counter/controller using a PLS157. This system counts and controls the number of entries to a certain media. For example, it can be used as a parking-lot controller to keep track of the number of cars entering a parking lot, and restricting any entries when the parking lot is full.
The design utilizes the six registers, six bidirectional I/O lines and the general architecture of the PLS157. In this design, the user can set the maximum number of entries using
external switches. Since the six registers in the device are used as a six-bit counter, the maximum number that can be set is $2^{6}$. However, the design can be cascaded to increase the number of entries.

## SYSTEM OPERATION

The basic system configuration is shown in Figure 1. As can be seen from this figure, the system can be expanded indefinitely. All the devices in cascade are identical to each other. Whenever there is a need for expanding the maximum number of counts, a device


Figure 1. System Configuration


Figure 2. /ENAB_CTRL Output Configuration
can be programmed identical to the device(s) already in the system and added in cascade.
There are external switches connected to the bi-directional inputs of the flip-flops. The user sets the maximum count in binary with the switches and loads the value into the registers. If the maximum count necessary exceeds the number available in one device, then another device is cascaded to the existing device. For example, in a system with two devices, the maximum available increases to $2^{12}$ or 4096.
When the maximum count is set, the control circuitry is used to keep track of the number of entries and exits. In the case of a parking lot, a pressure sensor can be used at the entrance and exit to generate a pulse which triggers the control circuitry. An alternative could be light beam sensors to generate the necessary pulses.
The operation of the system is such that each entry decreases the maximum count stored in the registers by one. When the count is zero, it means that the media is full and the control circuitry generates a signal to disable any further entries to the system. On the other hand, each exit increases the count by one. Since it is assumed that the media is empty when the maximum count is set, it is, therefore, impossible to physically count past the maximum set number. This is due to the fact that there cannot be more exits from the system than the actual number of objects residing in the system. If there are objects in the system when the maximum number is set, these objects should also be taken into consideration when setting the maximum count.

## CONTROL SIGNALS

The following is the explanation of the control signals shown in Figure 1.
The /ENTRY and /EXIT inputs signify an entrance or exit to or from the respective media and are triggered from the sensors at the entrance and exit. Each entry causes a count-down from the maximum set number until all the flip-flops are low. This means that the system is full and the count-down should be disabled.


Figure 3. Single Device Configuration

When all the flip-flops are low, the /FULL_N signal which is an Active-Low output is activated. The count-down is enabled by the /ENAB_DN input, which is connected externally to the /ENAB_CTRL line. The /ENAB_CTRL is a Tri-state output which is controlled by the /FULL_N signal. When all the flip-flops are low, the /FULL_N signal deactivates the /ENAB_CTRL output as shown in Figure 2.
All of the /ENAB_CTRL outputs are connected to the /ENAB_CTRL bus as shown in Figure 1. When the media is full, all the /ENAB_CTRL signals are deactivated which cause the count-down to be disabled.
An exit causes a count up. As mentioned before, the total number of exits from the system cannot exceed the total number of entries.

The /ALLHIGH_N signal is an Active-Low output which becomes low when ail the flipflops are high. Figure 3 shows the configuration of a single device.
The /FULL_N and /ALLHIGH_N signals are used to activate the /FULL_N-1 and /AL-LHiGH_Ni-1 of a cascaded device. These


TC03s50S
Figure 4. Cascaded Configuration

Table 1. An Up/Down Count Sequence Example

| Dev. B |  | DEV. A |  | Dev. B |  | DEV. A |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FOB | F18 | FOA | F1A | FOB | F1B | FOA | F1A |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
|  | (0) | 6 | 0. | 0 | 0 | 0 |  |
| (0) | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
|  | 1 | 1 | 0 | 0 | (0) | 1 | $1)$ |
|  | 1 | 0 | 1 | 0 | 1 | 0 | 0 |
|  | 1 | 0 | 0. | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 |  |  | 1 | 0 |
| 0 | 0 | 1 | 0 | (0) | 1 | 1 | 1) |
| 0 | 0 | 0 | 1 | (1) | 6 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| COUNT DOWN |  |  |  |  | cou | UP | TBozeos |

signals will be explained in detail shortly. The /FULL_N signal is also used to trigger any control circuitry used to restrict any further entries to the system. In the case of a parking lot, the /FULL_N can be used to activate a light or close the entrance gate.

The EXOR output is used to clock the system and is externally connected to the CLK input of the device. The EXOR generates a clock pulse when either an exit or entry take place. This restricts the system from counting if a simultaneous entry and exit takes place.

To set the maximum count, the user can use switches connected to inputs FO-F5 of the device(s). Then by bringing the /LOAD input low and triggering the /ENTRY or /EXIT inputs to generate a clock pulse, the data from these switches can be latched inte the registers.

## CASCADE DEVICE EXAMPLE

This is an example of two cascaded devices. Figure 4 shows the cascade configuration of devices ' $A$ ' and ' $B$ '. For the sake of simplicity, it is assumed that each device contains only two registers. This assumption gives clarity to the explanation, and can be extended to cover the six registers contained in each device.

As an example, it is assumed that the maximum count to be implemented in this example is 1001 in binary. In other words, the maximum number of entries is set to be 'ten'. FOA and F1A are the registers in device $A$, and FOB and F1B are the registers in device $B$. 10 is the input sequence to device $B$ and 01 is input sequence to device $A$.

The count-up and count-down sequences are shown in Table 1.

Table 2. Count Sequence

| NO. | F5 | F4 | F3 | F2 | F1 | Fo |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 |  | 0 | 9 |
| 2 | 0 | 0 | 0 | 0 | 1 | 0 |
| 3 | 0 | 0 | 0 | 9 | 1 | 1 |
| 4 | ! | ! | - | 1 | 0 | 0 |
| 7 | 0 | 0 | (0) | (1) | (1) | 1 |
| 8 | : | $\stackrel{\square}{0}$ | 1 | 0 | 0 | 0 |
| 15 16 |  | $\binom{0}{1}$ | ( $\begin{aligned} & \text { ¢ } \\ & 0\end{aligned}$ | (1) | (1) | ( ${ }^{1}$ |
| $\begin{aligned} & 31 \\ & 32 \end{aligned}$ | ( 0 | (1) | (1) | (1) | (1) | (1) |
| $\begin{aligned} & 62 \\ & 63 \end{aligned}$ | $\left(\begin{array}{l}1 \\ 1 \\ 0\end{array}\right.$ | $\binom{1}{1}$ | ${ }_{0}^{1}$ | $\binom{1}{0}$ | (1) | $\left(\begin{array}{l}0 \\ 0 \\ 0\end{array}\right)$ |

## A Simple Entry/Exit Metering Device

In the 1001 example, FOB is the MSB (Most Significant Bit) and F1A is the LSB (Least Significant Bit). As can be seen in Table 1, a count-down occurs in device 'B', when FOA and F1A are both low. When F0A and F1A are low, this means that the /FULL_N signal is active. The /FULL_N-1 input of device ' $B$ ' is connected to the FULL_N output of device ' A '. Therefore, a count down occurs in device 'B' only when the input to /FULL_N-1 goes low. In this manner, the count-down sequence in Table 1 can be implemented.

Similarly, for the count-up sequence, a countup occurs in device 'B' only when both FOA and F1A are high. At this point, the /ALLHIGH_N signal becomes active. Therefore, a count-up occurs in device ' $B$ ' only when /ALLHIGH_N of device ' A ' is active.

## UP/DOWN COUNTERS

An up-down counter is implemented in each device to keep track of the number of entries and exits. To implement these counters the flip-flops are set in the toggle mode. Table 2 shows the count sequence.
The following conditions are true for the count-up sequence:

## Table 3a

| REGISTER | TRUE CONDITION FOR <br> TOGGLE |
| :--- | :--- |
| F0 | Unconditionally Toggle |
| F1 | F0 |
| F2 | F0*F1 |
| F3 | F0*F1*F2 $^{*}$ |
| F4 | F0*F1*F2*F3 $^{*}$ |
| F5 | F0*F1*F2*F3*F4 $^{2}$ |

Similarly, for the count-down sequence:
Table 3b

| REGISTER | TRUE CONDITION FOR TOGGLE |
| :---: | :---: |
| FO | Unconditionally Toggle |
| F1 | /F0 |
| F2 | /F0*/F1 |
| F3 | /F0*/F1*/F2* |
| F4 | /F0*/F1*/F2*/F3 |
| F5 | /F0*/F1*/F2*/F3*/F4* |



Figure 6. System Clock

```
File Name : METER
Date * 10/\Xi1/1985
Time : 14:35:31
########################## P I N L L I S T 据############################
```



T801920S
Figure 7

## CONTROL SIGNALS

The following are the control signals used to control the operation of the devices:

The logic diagram for generating the 'CNTUP' and 'CNT-DN' signals is shown in Figure 5.
As can be seen from this figure, a count-up occurs when the following is true:
a) An exit takes place and,
b) the system is not loading in any data and, c) the previous stage has generated the /ALLHIGH_N-1 signal.

A count-down occurs when:
a) An entry takes place and,
b) the system is not loading in any data and,
c) the previous stage has generated the /FULL_N-1 signal and,
d) the media is not full, thus /ENAB_DN signal is low.
The system clock is generated using the CNT-UP and CNT-DN signals. The system is
to be clocked only when an exit or entry takes place. In order to prevent the system from being clocked when a simultaneous entry and exit takes place, these two signals are exclu-sive-OR'ed (Figure 6).
The equations shown in (Tables 3a and 3b) are generated using Signetics AMAZE software (Figures 7 and 8). The resulting program table is shown in Table 4.

©COMMON FRODUCT TERM
UFCNT $=/$ LOAD * EXIT * ALLHIGH N-1; "UFCNT is the signal generated for "activating the count-up from the ENTRY" "input and the ALLHIEH signal from any " "connected devices

DNCNT $=/$ LOAD $*$ ENTFY $*$ FULL_N-1;
"DNCNT is similar to UPCNT except it is " "generated for the count down

```
ALL-HIGH =/FO */F1 */F2 */FS */F4 */FS;
ALL-LOW =FO *F1 * F2 * FS * F4 * F5;
@COMFLEMENT ARRAY
/C = /(0);
```

©I/O DIRECTION
$\begin{array}{ll}\text { DO } & =0 ; \\ \text { D1 } & =0 ;\end{array} \quad$ "/EXIT is an input
$\begin{array}{ll}D_{1}=0 & \text { "ALLHIGH_N-1 is an input }\end{array}$
$\mathrm{D} 2=/ F U L L_{-} \mathrm{N} ;$
D. $3=1 ;$
D4 $=1 ;$
D4 $=1 ; ~$
DS $=1 ; ~$
"When maximum count is reached /FLILL $N$
"disables /ENAB-CTRL which in turn disables
"the device(s) from counting down
"/ENAB-CTRL is connected to the ENAB DN of the "
"device(s) "
"EXOF is an output
"/ALLHIGH_N is an output
"/FULL_N is an output:

Figure 8

GOUTPUT FOLARITY

```
X2 = 0; "/ENAB_CTRL is active low
X3 = 1; "ExOR is active high
X4 = 0; "/ALLHIGH_N is active low
X5 = 0;
"/FULL_N is active low
GFLIF FLOP CONTROL
FC = 1; "All flip flops are J-K
@OUTPUT ENABLE
"NOT USED"
@REGISTER LOAD
LA = LDAD; "Load the registers with the number set "
LE =LOAD; "by the input switches "
@ASYNCHFIONOUS FRESET/RESET
"NOT USED"
GFLIP FLOF MODE
"NOT USED"
ELOGIC EQUATION
EXOF = UFCNT*/DNCNT + DNCNT*/UFCNT; "Dutput count pulse only if there is not "
/FULL.N = /( ALL-LOW * /LGAD); "a simultaneous entry and exit
AALLHIGH N =/( ALL-HIGH * "indicates when maximum count is reached
shows when empty
"The following is the implementation of the counter together with the
"necessary logic."
/FO: T = (ENAB DN * DNCNT) + UFCNT;
/F1: T = (ENAB_DN * FO * DNCNT) + (/FO * UFCNT);
/F2: T = (ENAE_DN * FO * F1 * DNCNT) + (/FO * /F1 * UFCNT);
/FS: T = (ENAB ..DN * FO * F1 * F2 * DNCNT) +
    (/FO */F1 */F2 * UFCNT);
/F4: T = {ENAB_DN * FO * F1 * F2 * FS * DNCNT} +
    (/FO * /F1 * /F2 * /FS * UFCNT);
/FS: T = (ENAB_DN * FO * F1 * F2 * FS * F4 * DNCNT) +
    (/FO */F1 */F2 */FZ */F4 * UFCNT);
```

Figure 8 (Continued)

## A Simple Entry/Exit Metering Device

Table 4. Program Table for Entry/Exit Meter


# AN26 <br> PLHS18P8A Primer 

Application Note

## Application Specific Products

## FEATURES

- 100\% functional replacement for all 20-pin PALs
- I/O propagation delay: 15ns (max)
- Security fuse lock
- 10 inputs
- 8 bidirectional I/O lines
- Tri-state outputs have programmable polarity
- Architecture: 8 groups of nine AND gates. Total of 72 product terms
- Software support on Signetics AMAZE
- Complete TTL compatibility
- Each bidirectional I/O has individually controllable output enable


## ARCHITECTURE

The PLHS18P8A is an oxide-isolated, bipolar field-programmable logic array. This device is configured as a decoding two-level AND-OR (sum of products) structure. The PLHS18P8A block diagram is shown in Figure 1. All the AND gates are linked to ten inputs $\left(I_{0}-I_{9}\right)$ and eight bidirectional I/O lines $\left(\mathrm{B}_{(0)}-\mathrm{B}_{(7)}\right)$. These links can be made via the on-chip true/complement buffers. The 72 AND gates are configured in 8 groups which contain 9 AND gates each. In every group, eight AND gates are used for user-defined logic functions and the ninth AND gate is used as a tristate output enable control. This gives the user capability to control the output enable by means of a product term. The outputs of the eight logical product terms are ORed together (see Figure 1). The output polarity of each OR gate is individually programmable via an Ex-clusive-OR gate. The user has a choice of Active-Low or Active-High on each of the eight outputs. Figure 2 shows the logic diagram of the PLHS18P8A.

## HOW A DEVICE IS PROGRAMMED

There are three main programmable sections on the PLHS18P8A:
A. The AND array.
B. The output polarity.
C. The security fuse.
A. The AND array - The AND array fuses are back-to-back diode pairs which act as open connections in a virgin device. These open connections are configured as 'Don't

Cares' (' - ') in an unprogrammed device. The open connections are pulled to a logic high ('1') (see Figure 3). Consequently, all unprogrammed AND locations are pulled to a logic high ('1') state. This means that in an unprogrammed device, all the product terms are active. During fusing, current is avalanched across individual diode pairs. This essentially short circuits the diode and provides a connection for the associated product term. Figure 3 shows how a typical connection is made to the AND array (see Appendix $B$ for a description of the vertical fuses).

The inputs to the AND array consist of 10 dedicated inputs ( $10-19$ ) and 8 bidirectional I/Os $(B(0)-B(7))$. Initially, all these inputs are configured as 'Don't Cares' (' - '). These inputs can be connected to the AND array through an inverting or non-inverting buffer. The AND gate can be connected to the inverting buffer by programming the inverting fuse. Similarly, a connection can be made to the non-inverting buffer by programming the non-inverting fuse. Disabling an AND term is achieved by implementing a logical low ('0') on the output of the specified AND gate. At least one pair of fuses must be programmed for one input to disable the product term. When both fuses are programmed, both the inverting and non-inverting buffers are connected to the inputs of the AND gate. This will in turn create a logical Low ('O') on the output.
In each block of nine AND gates, one gate is used as an output enable control for the tristate output. The remaining eight gates are connected to a fixed OR gate. Since in the unprogrammed state the outputs of all the AND gates are at logic High ('1'), the output of the OR gate also acquires a logic High state. Therefore the user is responsible for deactivating any unwanted product terms. This is done by creating a logic Low (' 0 ') on. the outputs of the unwanted product terms as previously explained. Moreover, the output buffer is always enabled since the product term controlling the tri-state output buffer also has a logic High state. If any of the bidirectional pins are to be defined as inputs, the product term controlling the specified bidirectional pin must be disabled. The bidirectional pin can also be configured as a dynamic I/O by defining the required logic for the output-enable-control product term.
B. The Output Polarity - In an unprogrammed device, all the output polarities are configured as inverting buffers. The outputs of the PLHS18P8A are configured as tri-state buffers. The two inputs of each Ex-OR gate
are connected as follows: one input is connected to the output of the fixed OR gate. The second input is a connection to ground (logic low) through a fusible link. Figure 4 shows how an Ex-OR gate is used to define the output polarity.

As mentioned earlier, an unprogrammed fuse acts as an open connection which is pulled to a logic high. Therefore the output of the ExOR gate acts as an inverting buffer. When the fuse is programmed, there is a connection between ground (logic Low) and the input of the Ex-OR gate. This will cause the Ex-OR gate to act as a non-inverting buffer.
C. The Security Fuse - Programming equipment used to program the PLHS18P8A are capable of determining the logic pattern stored in this device (see Appendix A). The security fuse can be blown to disable the programmer from reading the pattern in a programmed device. This feature adds a measure of protection for proprietary designs.

The procedure for programming this fuse depends on the programmer manufacturer and is explained in the manufacturer's operations manual.

## DESIGN TOOLS FOR THE PLHS18P8A

Many CAD tools such as Signetics' AMAZE software ${ }^{1}$ are available to implement designs using the PLHS18P8A. The AMAZE software enables the user to enter the design in the form of Boolean equations or via the program table shown in Table 1. This program table is a one-to-one map of all the programmable links of Figure 2. The following explains the implementation of designs using the program table. Also, an example on using the Boolean Logic Entry program of the AMAZE software is given.
Using PTE (Program Table Entry) - Assume that $Z$ is a typical logic function with the following equation:

$$
Z=P_{0}+P_{1}
$$

Where P0 and P1 are product terms with the following equations:

$$
\begin{aligned}
& P 0=A * / B * C \\
& P 1=/ A * B * / D
\end{aligned}
$$

## NOTE:

[^23]

B0031205
Flgure 1. Block Diagram of the PLHS18P8A

## PLHS18P8A Primer

AN26


NOTES:

1. All unprogrammed or virgin "AND" gate locations are pulled to logic "1"
2. All unprogrammed or virgin "OR" gate locations are pulled to logic " 1 ".
3. Programmable corrections.

Figure 2. Logic Diagram of the PLHS18P8A

a. Unprogrammed Connection

Figure 3. How a Fuse is Programmed


Figure 4. How the Output Polarity is Defined

The program table in Table 1 is used to implement this equation. Table 2 shows the implementation of the logic function using the PTE. The first group of AND terms is used to implement this function. $B(7)$ is used for the output, 10,11 , and 12 as inputs.

- Term 0 is the direction control term. It is the tri-state output enable control term. Since $Z$ is configured as an output, leaving Term 0 in its unprogrammed state causes the output to be unconditionally enabled.
- Term 1 is the P -term labeled PO , where $A^{*} / B^{*} C$ is designated by HLH in columns 10,11 , and 12 .
- Term 2 is the P -term labeled P 1 , where $/ A^{*} B^{*} / D$ is designated by $L H L$ in columns 10,11 , and 12 .
- Terms 3, 4, 5, 6, 7. At least one input (or all the inputs) must be set to zero to disconnect these terms from the OR gate.
- The output polarity for $\mathrm{B}(7)$ is H , and this is entered in the 'Polarity' section.

Using BLAST (Boolean Logic And State Transfer) - The BLAST module in AMAZE can be used to implement the above equation. Figures 5 and 6 show the pin list and logic equation format. Table 3 is the program table generated from these equations.

## APPENDIX A

## Programmers

The PLHS18P8A can be programmed by means of logic programming equipment. With Logic Programming, the AND/Ex-OR gate input connections necessary to implement the desired logic are coded directly from the logic equations using the program table shown in Table 1.

The symbols used in the program table correspond to the fusing pattern of the corresponding link pairs, detined in Figure 6.

To program the device, the address of every fuse to be programmed must be entered in the programmer. This is a tedious and error-
prone method of implementing the required logic pattern. Using CAD software, such as Signetics' AMAZE software, enables users to go directly from program table or logic equations to a fuse plot. The fuse plot can be downloaded to a programmer through a seria! port.

## APPENDIX B

The vertical fuse is the latest in programmable logic technology. It combines reliability, low capacitance and testability in an incredibly small space.
The vertical fuse takes advantage of the properties of silicon and aluminum. The virgin fuse is a three-layer device: a shallow layer of N -type silicon on top, a layer of P-type silicon in the middle, and a layer of N-type silicon on the bottom. This forms a pair of PN diodes, back-to-back, which will not allow current to pass under normal circumstances.
There is a cap of aluminum on top of this structure. During programming, high current conditions ( 50 to 100 times what is seen during normal operation) is induced by avalanche breakdown of the reverse-biased diode. The aluminum will "'spike" through the shallow $N$-type layer. Once the aluminum has spiked through, the top diode in the pair is shorted out. The whole vertical fuse will then look like a pure PN diode. Before programming, the fuse is an excellent blocking element, having current leakages in the order of nanoamps. After programming, the fuse is set as a small, well-defined diode.

## QUALITY

Besides the $A C$ and $C$ parametrics, each and every fuse goes through three tests for forward characteristics, reverse characteristics, and programmability. Extensive on-chip test circuitry ensures full AC parametric testing before and after the part is programmed. This insures that the customer receives the highest possible fusing yield which is made possible by vertical fuses. Vertical fuses also offer the smallest and fastest array structure together with the highest reliability possible.

Table 1. Program Table

| Cust/project Date | PLHSIEpBA Primar |  |
| :---: | :---: | :---: |
| Rev/I. D. - |  |  |
| Commants: |  |  |
| Program Table | $\begin{gathered} \text { for } 10 p l \\ z=P 0+ \end{gathered}$ | anting P1 |
| wherel |  |  |
|  | $P O=A$. | B). $C$ |
|  | $P 1=1 / 4$ | B. (/D) |


O-

## PLHS18P8A Primer

```
Fil| Name : 1EPRIMER
Date : 3/22/1986
Time:13:52:54
```



| Label | ** FNC | **PIN |  | - PIN | *** FNC | * Label |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | ** I | ** 1-1 | P | 1-20 | ** +5V | **VCC |
| B | * 1 | ** 2-1 | $L$ | 1-19 | ** 0 | **2 |
| C | ** I | ** 3-1 | H | 1-18 | ** 10 | * INVERT |
| D | ** I | * 4-1 | 8 | 1-17 | * I | **INPUT |
| N/C | ** I | ** 5-1 | 1 | 1-16 | * B | **BIDIR |
| N/C | ** I | * 6-1 | 日 | 1-15 | **/B | **/EDIR |
| N/C | ** I | **) 7-1 | $P$ | 1-14 | */ /8 | **N/C |
| N/C | ** I | * 8-1 | E | 1-13 | **/B | **N/C |
| N/C | ** I | ** 9-1 | A | 1-12 | **/B | **N/C |
| END | ** OV | **10-1 |  | \|-11 | ** I | **N/C |

Figure 5


Figure 6. Boolean Equation File

| File Name i Igpriner <br> Dete I 5/22/1986 <br> Time ; 1315615 |  |
| :---: | :---: |
| Cust/Praject sete |  |
| Rev/1. D. | PLHEITPea rev |



$$
\left.\begin{array}{lllll}
1110 & 0 & 0 & 0 & 0,0 \\
12 & 0 & 0!0 & 0 & 0 \\
0,0 & 0 & 0 & 0!/ \\
12!0 & 0 & 0 & 0 & 0
\end{array}\right)
$$

$$
\begin{array}{lllllllllllllll}
12!0 & 0,0 & 0 & 0,0 & 0 & 0 & 010 & 0 & 0 & 0,0 & 0 & 0 & 0! \\
13!0 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 0! & 0 & 0 & 0,0 & 0 & 0 & 0!1 & A
\end{array}
$$

$$
\begin{array}{lllllllllll}
1410 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 010 & 0 & 0 & 0,0 \\
15 & 0 & 0!1 \\
1510 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 010 & 0 & 0 & 0,0 \\
1610 & 0.0 & 0 & 0 & 0.0 & 0 & 0 & 010 & 0 & 0 & 0.0
\end{array}
$$

$$
\begin{array}{lllllllllllllll}
17!0 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 0!0 & 0 & 0 & 0,0 & 0 & 0 & 0!1 \\
18!0 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 0!0 & 0 & 0 & 0,0 & 0 & 0 & 0!1 \\
19!0 & 0,0 & 0 & 0 & 0,0 & 0 & 0 & 0!0 & 0 & 0 & 0,0 & 0 & 0 & 0!1
\end{array}
$$

$$
71!--1-\ldots-----!------1 / / / / 1 / / / A!
$$



Table 3. Programming Table Generated by AMAZE

# Signetics 

## Application Note

Application Specific Products

## INTRODUCTION

The PLHS473 is a 24-pin field- programmable logic array (FPLA) which has 11 dedicated inputs, 2 dedicated outputs and 9 bidirectional I/Os. The logic array consists of 24 programmable product terms which are connected to 22 programmable OR terms in the classical PLA architecture. A functional diagram is shown in Figure 1. The shaded areas represent programmable interconnects between vertical and horizontal lines. Eleven dedicated inputs, $l_{0}$ to $l_{10}$, are located on the upper lefthand corner of the diagram, and the 9 bidirectional I/Os, $\mathrm{B}_{0}$ to $\mathrm{B}_{8}$ are located on the lower righthand corner. All inputs to the AND array have true and inverting input buffers. The output portion of the 9 bidirectional I/Os and 2 outputs may be programmed to be Active-High or Active-Low by altering fuses $X_{0}$ to $X_{8}, X_{A}$ and $X_{B}$ which are connected to one leg of the Exclusive-OR gates. Each output is connected to two ORterms, one of which provides the logic function OR to the output while the other provides the ENABLE function for the tri-state output buffer. Alternatively, each output may be configured to emulate an open-collector output by programming the output to an unconditional LOW and apply the logic function on the tri-state controlling OR-term as shown in Figure 2. In addition, the PLHS473 has a security fuse which may be programmed to lock out unauthorized access to the fuse map of the design.
This device is fabricated with an oxide-isolation process for the best speed/power performance. The programmable element is a 'vertical fuse" which is actually two PN diodes connected back-to-back (anode-to-anode
stacked on top of one another) as shown in the insets of Figure 1. The fuses are normally open-circuited. To program a fuse, a sufficiently high voltage is applied across the two diodes such that one diode breaks down which induces metal migration across the PN junction of the avalanched diode. This technology allows smaller chip size and faster speed performance. The guaranteed propagation delay may be tested by using the two factory-programmed test columns and a test row as a test vehicle for speed testing. These test columns are to be deleted automatically in the process of programming.

The vertical fuses of an unprogrammed device, being normally open-circuited, set all AND terms to a High state and disconnected to all OR terms. The OR terms are normally Low when they are not connected to the AND terms. Once an AND term is programmed to make connections with the OR array, it cannot be disconnected. However, AND terms may be disabled by having the true and inverting input buffers (e.g., $A * / A, B * / B$, etc.) of all inputs connected to the AND term which is to be disabled.

While even a single input, ( $A^{*} / A$ ), will hold the AND term to a Low, glitches may develop if the input voltage changes state. Therefore, it is recommended that the complementary buffers of all inputs in the disabled AND term be connected.

## Programming the PLHS473

The programming table and symbols of the PLHS473 are shown in Table 1 where there is a place for every function that is shown in Figure 1. The table is divided into two main
sections. The left side of the table, sections $A$ and $B$, represents the input side of the AND array (section $A$ has all dedicated inputs $I_{0}$ to $I_{10}$, section $B$ has inputs from the bidirectional I/Os $B_{0}$ to $B_{8}$ ), whereas the right side, sections $C, D$, and $E$, represents the outputs of the OR array. Section $C$ represents the OR array which controls the tri-state output buffers of the bidirectional $I / O s B_{0}$ to $B_{8}$ and outputs $O_{A}$ and $O_{B}$, while section $D$ represents the OR array which drives the outputs Section E controls the output polarity of each output. As shown in Table 1, the program table is very similar to a truth table. Each row represents one of the 24 product terms, while each column in sections A and B represents an input to the 24 product terms and in sections $C$ and $D$, each column represents an output. The intersection of a column and a row in sections $A$ and $B$ represents four possible fuse configurations, namely, 1) both inverting and non-inverting input buffers are connected to the AND term, 2) only the inverting buffer is connected, 3) only the noninverting input buffer is connected, and 4) both inverting and non-inverting buffers are disconnected. These four configurations are represented as ' 0 ', "L', 'H', and " -'" respectively. Each intersection of a row and a column in sections $C$ and $D$ involves only two fuse configurations, either connected or dis connected. Therefore, the entry there is either ' $A$ '" or ' - ", respectively. In the polarity control section (section E), each square represents the configuration of the fuse connected to the Exclusive-OR, which is connected to a particular output pin. An ' H ' represents an Active-High or non-inverting output, an 'L'" represents an Active-Low or inverting output. See Table 1 for further details.


NOTES:

1. All unprogrammed or virgin "AND" gate locations are pulled to logic "1".
2. All unprogrammed or virgin "OR" gate locations are pulled to logic " 0 '.
3. Programmable connections.

Figure 1. PLHS473 Logic Diagram


Figure 2. Emulation of Open-Collector Output

Notice that as shown in Figure 1, all fuses in their unprogrammed state are normally opencircuited. This means that all product terms are initially disconnected to the OR array, all

OR gates are initially at a logic LOW, and all output pins are initially in High-Z state. Therefore, if anys of the outputs are to be enabled, its controlling $O R$ term must be set to a logic

HIGH. An example is shown in Table 2, term 0 where pins $\mathrm{O}_{\mathrm{A}}, \mathrm{O}_{B} \mathrm{~B}(\mathrm{O})_{8}$ are programmed as dedicated outputs. The input section of term 0 is entirely "dashed out" (this is actually its unprogrammed state) which causes the AND term to be unconditionally HIGH. OR terms $E_{A}, E_{B}$, and $D_{8}$ are connected to product term 0 by the " $A$ " entries in their respective squares. The rest of the $D$ section and the $B(O)$ section are "dotted out" (left unconnected) since we are not concerned with them for the moment. If more outputs are needed later on, their corresponding squares may be changed to "As" from 'dots" as the need arises.

Table 1. PLHS473 Programming Table


OUTPUT POLARITY - ( $0, B$ )


## AND ARRAY - (I, B)



OR ARRAY - (O, B)


## NOTES:

1. This is the initial unprogrammed state of all link pairs.
2. Any gate $P_{n}$ will be unconditionally inhibited if any one of its ( $(, B)$ link pairs is programmed for a connection.


Figure 3. Emulation of Open-Collector Output

## VIRGIN STATE

A factor shipped virgin device contains all fusible links.

1. Ail output at ' $L$ '" polarity.
2. All $P_{n}$ terms are enable.
3. All $P_{n}$ terms are active on all outputs.

Once we have determined the outputs, we can proceed with defining the logic functions. As an example, the logic function

OUT-0 = INPUT-1*/INPUT-2
is shown in Table 2, term \#2 where in the column labeled "INPUT-1", an " H " is entered to represent a connection of the noninverting input buffer of INPUT-1 and the AND term 2. In the column labelled 'INPUT-2', an "L" is entered to represent the connection of the inverting input buffer of INPUT-1 and the AND term 2. On the output side of the table, $\mathrm{O}_{\mathrm{B}}$ in term 0 is programmed " A " to make a connection between term 2 and the OR term which is connected to the output pin $\mathrm{O}_{8}$ : The output polarity of $\mathrm{O}_{\mathrm{B}}$ is arbitrarily set to Active-High by programming an " H " in the $O_{B}$ column of the polarity section.
A sum of several product terms (AND-OR) is implemented by connecting multiple AND terms to the same OR term. An example is shown in Table 2, terms 4 and 5, which implement the logic function

$$
\begin{aligned}
\text { OUT-1 }= & (\text { INPUT-1 } * / \text { INPUT-2) }+ \\
& \text { (INPUT-3 * INPUT-4) }
\end{aligned}
$$

The logic function

$$
\begin{aligned}
\text { OUT-2 }= & /((\text { INPUT-1 * INPUT-2 })+ \\
& \text { (INPUT-3 * INPUT-4)) }
\end{aligned}
$$

is shown in terms 9 and 10. The output is Active-Low as programmed " $L$ " in the polarity section of OUT-2. As a rule, the AND function is implemented in a row, whereas the OR function is implemented in a column. Since the AND portions of terms 2 and 4 are the same, they may be combined as shown in term 7, which saves a duplicated term.
Table 2 terms 12 and 13 together emulate an open-collector output as an example. The logic equation

$$
\begin{aligned}
\mathrm{O}-\mathrm{C}= & /((\text { INPUT-1 } * \text { INPUT-2 })+ \\
& (\text { INPUT-3 * INPUT-4) })
\end{aligned}
$$

is implemented by first programming O-C Active-High in the polarity section. Terms 12 and 13 implement the sum of product func-
tion. Notice that the $\mathrm{B}(\mathrm{O})$ of $\mathrm{O}-\mathrm{C}$ is programmed as a "dot" in both terms 12 and 13, which, together with the polarity control, causes it to be unconditionally Low, since a disconnected OR term is unconditionally Low. The intersections of column $D_{7}$ and terms 12 and 13 are programmed " A " so that the tristate output buffer of $\mathrm{B}(\mathrm{O})_{7}$ is enabled at input conditions (INPUT-1 * INPUT-2) $=1$ or (INPUT-3 * INPUT-4) $=1$. Terms 10 and 11 may be represented as shown in Figure 3.

Signetics produces a software package, AMAZE, as a design tool which assists implementation of logic design and documentation. For further information on AMAZE software, refer to the AMAZE User's Manual. Two simple circuits shown as examples are implemented using AMAZE. The first circuit is a simple cross-coupled RS latch. The second circuit is a multiplexer/demultiplexer which multiplexes four inputs to one output or demultiplexes one input into four outputs. Both circuits are put into the same PLHS473 device.

Table 2. Examples of Programming PLHS473

File Name: 473PRIME
Oate: $9 / 4 / 1986$
Tipe : $15: 53: 78$

## 

| LABEE | if FMC | * 4 P1 |  | Pidyt FNC | ti |
| :---: | :---: | :---: | :---: | :---: | :---: |
| /5 | ** 1 | +4 1-1 |  | :-24 4* +5 y | * +YCC |
| if | \# | ** 2-1 |  | :-23 $4: 10$ | +i8 |
| $\mathrm{N} / \mathrm{C}$ | \% 1 | ** 3-1 | $F$ | $\mathfrak{i - 2 2} 5310$ | 8xamat |
| N/6 | * ! | i4) 4-1 | 1 | :-2] +15 | + + W $/ C$ |
| N/C | ** | ** 5-1 | H | :-20 4 \& | **F |
| W/C | +11 | +4 a-1 | 9 | $:-19+0$ | H2N/C |
| N/C | ** | ** 7-1 | 4 | :-18 $4 \pm 0$ | * $+\mathrm{H} / \mathrm{C}$ |
| N/C | ** 1 | +1 8-1 | 7 | -17 + 18 | + + N/ $/ \mathrm{C}$ |
| S0 | Hid | 4* 9-1 | 3 | - $-16 \pm 48$ | +61] |
| SI | **! | t* 10-1 |  | :-15 +18 | - |
| 018 | * 1 | ** 11-1 |  | 1-14 $4 \times 8$ | + 48 |
| 6x | * ${ }^{\text {OV }}$ | 4. 12-i |  | i-13 \& | \$1\% |

Figure 4. Pin List

| gile Hase : 473PRike |
| :---: |
| Date: 9/4/1986 |
| Tine : 15:54:14 |
| CDEVICE TYPE |
| PLHS473 |
| CDRANING |
| trevision |
| CDATE |
| dsymbol |
| File name $=473$ Prime |
| econpany |
| emanc |
| EESCRIPTION |
| SCOMMOM PRODHET TERM |
| el/o directiom |

-The lio direction definition is ootional, and ady be defaulted to the PIN LIST unless it is bidirectional and is controlled by a logic equation.

$\mathrm{DB}=1 ; \quad$ "Each output wist be defined seperately by its own
$07=1 ; \quad$ logic equation. *


|  | When $01 \%=1,83,82,81,80$ becout outputs, Data flows tros $F$ to $A, B, C, D$. |
| :---: | :---: |
| $02=01 \mathrm{R}$; |  |
| D1 $=01 \mathrm{R}$; |  |
| $D \mathrm{C}=01 \mathrm{R}$; |  |
| D5 = /DiR ; | When DIR $=0, B 5$ tecones an output, output buffers of 80 to $B 3$ are disabled, Data floms trom $A, B, C$, D to F. . |
|  | Figure 5. Boolean Equations ${ }_{\text {T803 }}$ |

## QUUTPUT POLARITY

*The definition of output polarity is optional and may be defaulted the FIN LIST, "
*************** POLARITY DEFINITION FOR R/S LATCH *************
x8, $x 7=1$; $\quad$ Outputs with the sane polarity aay be defined in the same equation. Since the outputs $Q$ and QNOT are detined as active LOM, this equation causes the XDR to function as an inverter."

 High."

## elogic equation

" *************** EQUATIOKS FOR R/S LATCH ********************
$0 \quad=14$ is + out 1 ; * The equation wust used the format output $=\| \ldots . .$.$) ; since output$ 0 is defined as active Loul.
QNOT $=((1 R+Q)$;



Figure 5. Boolean Equations (Continued)

File Nase : 473FRINE
Dete : $9 / 4 / 198 \mathrm{C}$
Tine: 15:56:24
Cust/Project -
Date
Revil. D. -

| PLHS4T3 | POLARITY: |
| :---: | :---: |
| --- |  |
| T! | ! LLLLLLHLHHHH! |
| $\varepsilon$ |  |
| R! ..... | !0 8(0) $-\ldots$. |
| H ! 19876543210!976543210! | !BA876543210! |
| ---10---------- | --! |
| 0!--------- | !AAA,A.A....: |
|  | ! AA. AR.A. . . ! |
| 2!-LL---------------H | !AR. . AAA. . . . |
| 3!-LH--------------H-1 | !AA. , AAA. . . . |
| 4!-HL-------- ------ | !AR. . AAA.....! |
| 5!-HH-------------H---1 | !AR, , AAA. . . . |
| 6!-LL-------- - --H---- | !AA.A.A..$A!$ |
| 7!-LH--------!--H----- | ! $A A_{1} . A_{1} A_{1}, A_{1}$ ! |
| 8!-HL-------- | !AA..A.A.A., ! |
| 9!-H月-----------H----- | !AA, , A.AA....! |
| 10!------------------- | !AA., A.A....' |
| 11! 1 ------------------- | !AA. .A.A....! |
|  | !AA..A.A.... |
| 13!--------------------- | ............! |
| 14!-------------------- | ............. |
| 15!-------------N------ | !............! |
| 16!-------------------- | ............ |
| 17!------------------- | ............ |
| 18!------------------- | ............! |
| 19!-------------------- | !............! |
| 20!-------------------- | ............! |
| 21!--------------.---- | !............! |
| 22!------------------- | !............! |
| 23!-------------------- | ............ |
|  | NWGQHFNDCAA |
| [101/]/1/RS N/ / | /1 W/ 1 |
| $\bigcirc$ CCCCCC OC C | CCOC C |
| T | T |

Figure 6. Program Table

Application Note

## Application Specific Products

## INTRODUCTION

The general technique underlying the operation of this A/D converter is illustrated by the fuctional block diagram in Figure 1. The system consists of a D/A converter, a comparator circuit, and digital logic circuitry. The digital logic circuitry outputs a digital vaue which is converted to analog by the D/A converter.

The comparator senses when the output is greater or less than the input and causes the digital circuit to decrement or increment its digital output respectively. The initial conversion is completed in 13 clock cycles. If tracking mode is used, the A/D converter then tracks the input voltage as it changes by incrementing or decrementing 1 -LSB per clock. The tracking function makes it possible to make an A/D conversion in one clock cycle if the input changes less than the value of 1 -LSB per clock period. The conversion may be halted and the digital output, as well as the converted analog output from DAC, will hold their output constant indefinitely. This feature works well as sample-and-hold since its output voltage will not decay over time whereas the output of an analog sample/hold will decay due to charge leakages.

In order to avoid the violation of setup time by the output of the comparator, its output is latched. There is a built-in 2-phase clock in U2 which may be used to drive the logic circuitry and the latch of the comparator (see Signetics NE5105 data sheet for details on output latches of voltage comparators).

The analog input voltage may be sampled and held by an analog sample/hold circuit to
keep the input to the ADC from changing. The DONE output may be used to control the sample-and-hold if needed.
This paper discusses only the digital circuit which contains the SAR and the Up/Down Counter. The analog circuits are not within the scope of this paper.

## SAR

Two PLS179s are connected together to form a 12-bit shift register and up/down counter. The schematic diagram of the A/D converter is shown in Figure 2. U2 contains bits 0 to 4 and U1 contains Bits 5 to 11. Interconnects are made as shown in the diagram. The digital output to the DAC is in natural binary format (e.g. 000000000000 equal zero, and 111111111111 is full scale or 4095). After the/ST input becomes 0 , at the rising edge of the next clock, the SAR is initialized to halfscale ( 100000000000 ) and the DONE flipflop is reset to output 0 which causes the open-collector output /DONE_OC to become high impedance. The digital output is converted by the DAC and is compared to the analog input voltage by the comparator. If the digital output is greater than the analog input, the SAR shifts the 1 to next MSB on the right. The content of the SAR becomes ( 01000000 0000 ). If the digital output is still greater than the input, the SAR shifts right one bit again. The content of the SAR then becomes ( 0010 00000000 ). The shitting of 1 to the next MSB in equivalent to reducing by half the value of the bit under consideration. If the output is still too large, the SAR reduces it by half again by shifting to the right one more time.

The SAR keeps shifting to the right until the digital output is less than the input. When the output is less than the input, the SAR adds one bit to the next MSB while keeping all the higher order bits unchanged. For example, if the current output is 000100000000 and the output is less than the input, the SAR adds one bit to the right at the next clock. The output becomes 000110000000 . The output is again compared to the input. If the addition of that one bit is too much, it will be shifted to the right until the output becomes less than the input. When that happens, that SAR will again add one bit to the right. The algorithm of the SAR may be summarized as the following: If the output is greater than the input, shift to the right; otherwise add one bit to the right. This process continues until all 12 bits have been operated on. The last bit (Bit 0 ) is always changed from 0 to 1 , which is used as the condition to set DONE to 1 which, in turn, sets open-collector output, /DONE_OC, to 0 .

## UP/DOWN COUNTER

After DONE becomes 1 , if /ST and /HOLD are 1 and /TRACK is 0 , the SAR turns into a 12-bit up/down counter. If the analog input voltage increases, the counter will increment by 1 at every clock until it matches the input. If the input decreases, the counter will decrement by 1 . When /HOLD becomes 0 , the counter is inhibited and the output is held indefinitely. The counters consist of 12 toggle flip-flops and 2 p-terms per flip-flop for directional control. The counter will operate only


Figure 1. Functional Block Diagram of 12-Bit High-Speed A/D Converter


Figure 2. Schematic Diagram of 12-Bit High-Speed A/D Converter

# High-Speed 12-Bit Tracking A/D Converter Using PLS179 

after the approximation cycle is completed and DONE is 1.

Since the /ST and /HOLD inputs may be asynchronous with the clock, in order to minimize the possibilities of having a metastable condition from happening, these inputs close-up are latched by flip-flops /START of U1 and /HLD of U2 respectively. Once they are latched, subsequent operation begins at the rising-edge of the next clock. The output of the comparator may be latched to prevent setup time violation. (Signetics NE5105 is a high-speed comparator with an output latch. External latch may be used with other comparators.)

## CLOCKS

U2 generates an optional 2-phase clock which may be used to control the latch of the comparator. The two clocks are basically $180^{\circ}$ out of phase and CLOCK2 has an additional 25 ns propagation delay behind CLOCK1. CLOCK2 is used to drive the clockinputs of the PLS179 devices.

The clock frequency is controlled by $R$ and $C$. Those who want to use the built-in clock
should experiment with RC time constants for the best value. It is recommended that the capacitance should be less than 1000pF for best results (see Ap Note AN13 for more detail).

## DONE AND /DONE_OC

The output DONE is reset to 0 when /ST is 0 . It remains 0 until the approximation cycle is completed. After the least significant bit becomes 1, the DONE bit becomes 1 at the next clock. It remains 1 until it is reset again by input /ST.

The /DONE_OC output is configured to emulate an open-collector output. The output is programmed to have a logic 0 . When DONE is 0 , the Tri-state output buffer is set to $\mathrm{Hi}-\mathrm{Z}$ condition. As soon as DONE equals 1 , the Tristate buffer is enabled and /DONE_OC becomes 0 .

In the initial phase of A/D conversion, 13 clock cycles are required. It is essential that the input voltage to the comparator remains unchanged while the SAR is converting. It may be necessary to have a sample/hoid at
the front end. The DONE output may be used to control the analog sample/hold circuit.

## INPUT LATCHES

Flip-flop /START and 2 p-terms in U1 are configured as a non-inverting D flip-flop. The input, /ST, and the output /START have the same polarities. Flip-flop /HLD and 2 p-terms in U2 also form a non-inverting D flip-flop. The output /HLD and the input /HOLD have the same polarities.

## AMAZE INPLEMENTATION

The implementation of the logic circuit using AMAZE is as shown in the appendices. The SAR circuit is first designed as a state machine (file name: ADCS.SEE). It is then partitioned into two PLS179s after proper pin assignments are made. Then the up/down counter, input latches, 2-phase clocks and the open-collector output, are implemented by using Boolean equations in their respective .BEE files (file names: ADCB1.BEE and ADCB2.BEE) in AMAZE. The files are then assembled to produce the fuse-maps of PLS179 (ADCB1.STD and ADCB2.STD).


Figure 3. Timing Diagram of Successive Approximation Cycle

## APPENDIX A: STATE EQUATIONS OF SAR



## High-Speed 12-Bit Tracking A/D Converter Using PLS179

## APPENDIX A: STATE EQUATIONS OF SAR (Continued)

```
MTRANSITIONS
WHILE [ INIT ]
    IF [] THEN [ HALFSCALE ] "INITIALIIEE REGISTER TO HALF SCALE"
WHILE [ ST2O4E ]
    IF [ GREATER ] THEN [ SH1024 ] "IF GREATER THAN, SHIFT 1 BIT"
        IF [ LESS ] THEN [ AD1O24 ] "IF LESS THAN, ADD 1 BIT"
WHILE [ ST1O24 ]
        IF [ GREATER ] THEN [ SH512 ]
        IF [ LESS ] THEN [ ADSI2 ]
WHILE [ ST512]
    IF [ GREATER ] THEN [ SH256 ]
    IF [ LESS ] THEN [ AD256 ]
WHILE [ ST256 ]
    IF [ GREATER ] THEN [ SH128 ]
    IF [ LESS ] THEN [ AD12B ]
WHILE [ ST128]
    IF [ GREATER ] THEN [ SH64 ]
        IF [ LESS ] THEN [ AD64 ]
WHILE [ STG4 ]
    IF [ GREATER ] THEN [ SH32 ]
    IF [ LESS ] THEN [ ADS2 ]
WHILE [ ST32 ]
    IF [ GREATER ] THEN [ SH16 ]
    IF [ LESS ] THEN [ AD1G ]
WHILE [ ST16 ]
        IF [ GREATER ] THEN [ SHB ]
        IF [ LESS ] THEN [ ADS ]
WHILE [ STB ]
    IF [ GREATER ] THEN [ SH4 ]
        IF [ LESS ] THEN [ AD4 ]
WHILE [ ST4 ]
    IF [ GREATER ] THEN [ SH2 ]
    IF [ LESS ] THEN [ AD2 ]
WHILE [ ST2 ]
    IF[ GREATER ] THEN [ SH1 ]
    IF [ LESS ] THEN [ ADI ]
WHILE [ ST1 J
    IF [ GREATER ] THEN [ SHO ]
    IF[] THEN [END]
```


## APPENDIX B: PIN LISTS

File Name : ADCB2
Date : 10/21/1986
Time : 10:58:26


| LABEL | ** FNC | **PIN |  |  | PIN** |  | FNC | ** LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK | ** CK | ** | 1-: |  | :-24 | ** | +5V | **VCC |
| /START | ** I | ** | 2-1 |  | 1-23 | ** | 18 | **/DONE_OC |
| CDMPARE | * | ** | 3-1 |  | i-22 | ** | B | **i/c |
| /HCLD | ** I | ** | 4-1 | $P$ | i-21 | ** | 0 | **/HLD |
| /TRACK | ** I | ** | 5-1 | $L$ | :-20 | ** | 0 | **BIT4 |
| BITS | ** I | ** | 6-1 | 5 | 1-19 | ** | 0 | **BIT3 |
| N/C | ** I | ** | 7-1 | 1 | i-18 | ** | 0 | **BIT2 |
| N/C | ** I | ** | 8-1 | 7 | 1-17 | ** | 0 | **EIT1 |
| N/C | ** I | ** | 9-1 | 9 | :-16 | ** | 0 | **BITO |
| RC | ** / | ** | 10-1 |  | : -15 | ** | 0 | * ${ }^{\text {PDONE }}$ |
| Clock 1 | ** 0 | ** | 11-1 |  | 1-14 | ** | 10 | **CLOCK2 |
| GND | ** OV | ** | 12-1 |  | i-13 | ** | /DE | **N/C |



| LABEL | ** | FNC | **PIN |  |  | PIN** |  | FNC | ** | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK | ** | CK | ** | 1-1 |  | :-24 | ** | +5V | **VCC |  |
| /ST | ** | I | ** | 2-; |  | :-23 | ** | /B | **N/C |  |
| COMPARE | ** | I | ** | 3-1 |  | i-22 | ** | 0 | **/STAR | RT |
| /HLD | ** | 1 | ** | 4-: | $P$ | i-21 | ** | 0 | **BIT11 |  |
| TRRACK | ** | 1 | ** | 5-: | $L$ | 1-20 | ** | 0 | **BIT10 |  |
| EIT4 | ** | 1 | ** | 6-1 | 5 | i-19 | ** | 0 | **EIT9 |  |
| BIT3 | ** | I | ** | 7-1 | 1 | :-18 | ** | 0 | **BITA |  |
| BIT2 | ** | I | ** | 8-: | 7 | 1-17 | ** | 0 | **BIT7 |  |
| BIT1 | ** | I | ** | 9-1 | 9 | 1-16 | ** | 0 | **BIT6 |  |
| BITO | ** | I | ** | 10-: |  | : -15 | ** | 0 | **BIT5 |  |
| DONE | ** | I | ** | 11-: |  | ! 14 | ** | /B | **N/C |  |
| GND | ** | OV | ** | 12-i |  | :-13 | ** | /OE | **N/C |  |

APPENDIX C: BOOLEAN EQUATIONS OF UP/DOWN COUNTER AND INPUT LATCH

```
File Name : ADCB1
Date : 10/21/1986
Time : 10:54:48
```

CDEVICE TYPE
PLS179
QDRAWING
EREVISION
EDATE
esymbol
FILE NAME : ADCB1
ecompany
ENAME
GDESCRIPTION
ECOMMON PRODUCT TERM
ECOMFLEMENT ARRAY
GI/O DIRECTION
EOUTPUT POLARITY
EFLIP FLOP CONTROL
$F C=1 ; \quad$ "SET ALL FLIP FLOP TO BE $3 / K "$
GOUTFUT ENABLE
@REGISTER LOAD
GASYMCHRONQUS PRESET/RESET
gFLIF FLOF MODE
ELOGIC EQUATION
"NON-INVERTING INPUT LATCH: /START =/ST "
START : J = ST ;
$K=/ S T$
"UP/DOWN COUNTER ROUTINE"
/EITS : T = /START * TRACK * DONE * /HLD * COMPARE * /BITO * /BITI *
/BIT2 * /BITS * /BIT4 +
/START * TRACK * DONE * /HLD * /COMPARE * BITO * BIT1 *
BIT2 * BIT3 * BIT4 ;
/BITG : T = /START * TRACK * DONE */HLD * COMPARE */BITO */BITI *
/BIT2 * /BITS * /BIT4 * /BITS +
STAFT * TRACK * DONE * /HLD * /COMPARE * BITO * BITI *
BIT2 * BIT3 * BIT4 * BITS ;
/BIT7 : T = SSTART * TRACK * DONE * /HLD * COMPARE *
/BITO * /BITI * /BIT2 * /BITS * /BIT4 * /BITS * /BIT6 +
/START * TRACK * DONE * /HLD * /COMPARE *
BITO * BIT1 * BIT2 * BIT3 * BIT4 * BITS * BIT6
/BITB : T = /START * TRACK * DONE * /HLD * COYPARE */BITO */BITI *
/BIT2 * /BITS * /BIT4 * /BITS * /EIT6 * /BIT7 +
ISTAFT * TRACK * DONE * /HLD * /COMPARE * BITO * BITI *

/BIT2 */BIT3 */EIT4 */BITS * /BIT6 */BIT7 */BIT8 +
/START * TRACK * DONE * /HLD * /CDPMPARE * BITO * BITI *
BIT2 * BIT3 * BIT4 * BIT5 * BIT6 * BIT7 * BITB ;
/BIT1O : $T=/$ START * TRACK * DONE * /HLD * COMPARE * /BITO * /BITI *
/BIT2 * /BIT3 * /BIT4 * /BITS * /BIT6 * /BIT7 * /BIT8 *
/BITG +
ISTART * TRACK * DCINE * /HLD * JCOMPARE * BITO * BITI *
BIT2 * BITS * BIT4 * BIT5 * BIT6 * BIT7 * BITE *
BIT9 ;
/BITII : T = /START * TRACK * DONE * /HLD * COMPARE * /BITO * /BITI *
/BIT2 * /BIT3 * /BIT4 */BITS */BITS */BIT7 */BITE *
/BIT9*
/BIT10 +
/START * TRACK * DONE * /HLD * /COMPARE * BITO * BITI *
BIT2 * BIT3* BIT4 * BITS * BIT6* BIT7* BIT8*
BIT9 * BITIO :

## APPENDIX C: BOOLEAN EQUATIONS OF UP/DOWN COUNTER AND INPUT LATCH (Continued)

| Bit2 + <br> BIT2 ; <br> BIT2 * <br> BIT2 * | File Name : ADCB2 <br> Date : 10/21/1996 <br> Tine : 10:38:56 <br> eDEVICE TYPE <br> PLSIT9 <br> - Drawing <br> EREVISION <br> eDATE <br> ESYMBOL <br> file name : adcer <br> ECOMPANY <br> ENAME <br> GDESCRIPTION <br> GCOMMON PRODUCT TERM <br> ECOMPLEMENT ARRAY <br> EIM DIRECTION <br> DO = RC ; <br> "RC OSCILLATOR" <br> DS $=$ DONE ; $\quad$ "ENABLE /DONE_OC TO OUTPUT A LOGIC LOW." <br> EQUTPUT POLARITY <br> EFLIP FIGE CONTROL <br> $F C=1$; <br> QOUTPUT ENABLE <br> eREGISTER LOAD <br> EASYNCHRONOUS PRESET/RESET <br> GFLIP FLOP MODE $\text { MMO, M1, M2, M3, M4, MS = } ; \text { SET FO - FS TO J/K FLIF FLOPS. " }$ <br> ELOGIC EQUATION <br> "NON-INVERTING INPUT LATCH: /HLD $=/$ HOLD " <br> HLD : J $\quad \mathrm{J}=$ HOLD; $K=/ \text { HOLD } ;$ <br> "UP/DOWN COUNTER ROUTINE" <br> /BITO : T = /START * TRACK * DONE * /HLD ; <br> /BIT1 : T = /START * TRACK * DONE * /HLD * /COMPARE * BITO + SSTART * TRACK * DONE * /HLD * COMPARE * /BITO ; <br> /EIT2 : $T=/$ START * TRACK * DONE * /HLD * /COMPARE * BITO * BITI + /START * TRACK * DONE * /HLD * COMPARE * /BITO */BITI ; <br> /RITS : T = /START * TRACK * DONE * /HLD * /COMPARE * EITO * BITI * <br> /START * TRACK * DONE * /HLD * COMPARE * /BITO */BITI * / <br> /BIT4 : T = /START * TRACK * DONE * /HLD * /COMPARE * BITO * BIT1 * <br> BIT3 + <br> /START * TRACK * DONE * /HLD * COMPARE * /BITO */BIT1 */ <br> /BIT3; <br> /DONE_OC = ( 1 ); <br> "RE OSCILLATOF" <br> RC $=/(1)$; <br> CLOCK1 $=$ RC: <br> CLOCK2 $=/($ CLOCKi $)$; "BUILT-IN DELAY OF 1 tPD" |
| :---: | :---: |

## APPENDIX D: U1 ADCB1 FUSE MAP



APPENDIX D: U2 ADCB2 FUSE MAP (Continued)

$\left.\begin{array}{cccccccccccccccccccccccccccc}N N N\end{array}\right]$

## Application Specific Products


#### Abstract

SUMMARY The evolution of Programmable Logic Devices (PLD's) has led to the birth of a new generation of programmable devices designated as PML (Programmable Macro Logic). The immense versatility of these devices brings them closer as plausible alternatives to semicustom design approaches in low-tomedium ranges of applications. The following paper begins with a background on PML and a brief description of the PML basic architecture (See Reference 1.) Next, the first PML devices are introduced with a detailed discus-


sion of the PLHS501. The implementation of PML in the AMAZE software package is presented. A system level example intends to demonstrate the capabilities of PML as an eloquent and efficient design alternative.

## the emergence of the THIRD GENERATION PLD ARCHITECTURE

PML was introduced at WESCON '85 by Signetics Corporation. The unique architecture of PML breaks away into a new era of


Figure 1. One of the Latest Registered PALs ${ }^{\text {TM }}$
programmable logic devices. The purpose of the PML architecture is to overcome the two level AND-OR bottleneck and provide the user with a higher level of logic integration. Current PLD's rely on two levels of logic transformation to implement combinational logic in Sum-Of-Products (SOP) form. In addition various PLD's make use of higher level macros such as flip-flops to form sequential logic functions. These macros connect the AND-OR chain to dedicated $1 / O$ pins.

Figure 1 show the basic architecture of one of the most recent PAL ${ }^{T M}$ devices. It is clear that this architecture is inefficient in making full use of the available on-chip resources. This is due to the fact that an unused 1/O macro will be wasted and remains futile.
For example, if an $1 / O$ pin is used as an input, the output macros are all wasted. Obviously, such an architecture cannot provide the user with an increase in the levels of logic integration. The PML device takes advantage of the fundamental architecture shown in Figure 2 to overcome these deficiencies and waste of on-chip resources. As shown in Figure 2, PML incorporates the NAND-NAND gate equivalence to break the AND-OR bottleneck.
The core of the PML is the programmable NAND-NAND network which connects the input and output macros to each other. Thus the inputs, outputs, and function macros are all connected by a single array.
At the present, two devices are under development which employ the above architecture. Both devices are fabricated by the Signetics state-of-the-art oxide isolation process and are packaged in 52-pin PLCC.
The first device available will be the PLHS501. The seemingly simple structure of this device can implement every logic function furnished by the current PAL ${ }^{\text {TM/PLA }}$ devices. Although the PLHS501 is principally a combinational logic device, its unique architecture makes it an ideal tool for applications involving asynchronous state machines (See Reference 2.)

The PLHS502 is a sequential logic device. It supplements the PLHS501 features with sixteen edge-triggered flip-flops. The device can provide diverse applications encompassing synchronous and asynchronous state machine designs.

## PLHS501 Programmable Macro Logic Primer

Table 1. Functional Description of PLHS501 I/O Pins

| PIN NO. | IDENTIFIER | FUNCTION |
| :---: | :---: | :--- |
| $41-45,47-52$, <br> $1-7,9-14$ | $10-123$ | Dedicated inputs |
| $37-40$ | /B0-/B3 | Fuse-programmable bidirectional I/Os with Active-Low <br> outputs. Can be configured as open-collector outputs. |
| $15-18$ | B4-B7 | Logic controlled bidirectional I/Os with Active-High <br> Tri-state outputs. |
| $28-29$ | X0-X1 |  |
| $30-31$ | X2-X3 | Pairs of Tri-state Exclusive-OR outputs that have |
| $32-33$ | X6-X7 | common Output Enable. |
| $35-36$ | O0-O1 |  |
| 19,21 | O2-O3 | Pairs of dedicated Active-Low Tri-state output buffers. |
| $22-23$ | O4-O5 | Pach pair has common Output Enable control. |
| $24-25$ | O6-O7 of dedicated Active-High Tri-state output buffers. |  |
| $26-27$ |  | Each pair has common Output Enable control. |



Figure 2. PML Fundamental Architecture

## THE PLHS501 PML

The PLHS501 architecture in Figure 3 exhibits an exquisite logic tool. The device provides a combination of 72 NAND terms, 24 dedicated inputs ( $10-123$ ), eight bidirectional I/O's (B0-B7), eight exclusive-OR outputs (X0-X7),
and eight dedicated outputs (O0-O7). Figure 4 shows the PLHS501 logic diagram and Table 1 illustrates the functional breakdown of the PLHS501 I/O pins.

Since the output of each NAND term feeds back to the inputs of the NAND array, intri-
cate logic functions can be implemented without wasting valuable I/O pins. For example, in order to implement an internal 'RS' latch in a combinational PAL ${ }^{\text {TM }} / P L D$, at least two inputs and two outputs are required. The same internal latch can be configured by the PLHS501 without using any I/O pins.


LD07800S
Flgure 3. PLHS501 Logic Diagram


Figure 5 illustrates how 'RS' and ' $D$ ' latches are implemented in the PLHS501.

Another eminent application of the PLHS501 is in generating asynchronous state machines.

The blend of internal feedback paths together with the abundant number of gates makes this device suitable for designing asynchronous state machines which employ propagation delays of feedback paths as memory elements as shown in Figure 6. (See Reference 2.)

Figure 4. PLHS501 Pin Assignments



Figure 6. Model of Asynchronous State Machines Using Propagation Delays of the Feedback Path as Memory Elements

## PML DEVELOPMENT <br> SOFTWARE

Programmable logic development software has become an integral part of the PLD design process. Without software tools PLDs become perplexing devices which are inconvenient to use. Development software enables the user to take full advantage of the programmable logic's resources. The complexity of the PML devices makes software an indispensable element in the design process.

The AMAZE PLD design software, as noted in Reference 3, has been developed for Signetics programmable logic devices. PML
design and development will be fully supported by AMAZE. Figure 7 shows the AMAZE configuration for supporting PML. The structure of the software is based on the following modules:
.BLAST (Boolean Logic And State Transfer entry)
.DPI (Device Programmer Interface)
.SIM (PLD functional SIMulator)
.PI (PML Integrator)
The foundation for the above modules is an AMAZE standard fuse file (STD). The STD file is the common means of communication between all the modules. The following para-
graphs briefly explain the implementation of PML in the AMAZE structure.

## BLAST

The basic elements of BLAST are:

1. Boolean Equation Entry (BEE).
2. State Equation Entry (SEE).
3. Schematic To Boolean Converter (STBC).
4. BEE accepts user defined logic in the form of boolean equations and produces an AMAZE standard fuse file. The boolean notation in BEE will account for the following PML features.
a. The single array architecture provides an option to specify the number of logic (gate) levels that accommodate a specified function. The number of gate levels dictate the delay between the inputs and outputs. The number of logic levels for each function can be specified using the following notation:

LABEL [ number of logic levels ] = equation; where LABEL is the user designated name of the output pin.
b. Some outputs have more than one gate associated with them (for example registered or EXOR outputs). The input SIDE of these outputs can be specifically defined. For example:

$$
\text { Pin Label: } \begin{aligned}
R & =\text { eqn; } \\
S & =\text { eqn; }
\end{aligned}
$$

c. User definable CLOCK Logic (e.g. as in the PLHS502) can be specified.
d. For PML devices the Sum-of-Products (SOP) can be defined as common terms.


Figure 7. AMAZE Configuration for PML

# PLHS501 Programmable Macro Logic Primer 

2. SEE accepts state machine definitions and produces the AMAZE standard fuse file. Particularly, SEE will include asynchronous state machine implementations utilizing the PLHS501.
3. STBC converst schematic netlists produced by CAD systems such as Futurenet ${ }^{T M}$, Daisy, and Mentor into an AMAZE BEE file. STBC will fuily embody the PML in the following manner:
a. De Morgan's theorem is applied to produce equations in SOP form. All the functions in SOP form are then converted into their NAND- NAND equivalent.
b. The converter will determine the polarity and the number of levels in each equation and will automatically determine the correct output polarity.

## DPI

Device Programmer Interface provides the interface between the AMAZE standard fuse file and a commercial programmer. It allows the transmission of data to and from the device programmer.

## SIM

The functional simulator uses the AMAZE standard fuse file in the following manner:
a. An event driven simulator will assess the delays within the PML in order to properly simulate the pattern.
b. Automatically generates test vectors for the pattern simulation.

PI
The PML Integrator is a conversion that transforms various PAL ${ }^{\mathrm{TM}}$ or PLD circuits into a PML device. It will automatically fit multiple PAL ${ }^{\text {TM }} / \mathrm{PLLD}$ devices inio a singie FMiL. it is capable of automatically receiving patterns from a commercial device programmer and downloading it back to the programmer after the PML transformation. The implementation of an 'Integrator' will allow the automatic conversion of numerous PAL ${ }^{\text {TM } / P L D s ~ i n t o ~ a ~}$ single PML device

AMAZE will not be the total extent of devel opment software available for the PML devices. The task of implementing PML design software is already underway by a number of different vendors of CAD software.

## PLHS501 DESIGN EXAMPLE

The following example intends to manifest the capabilities of the PLHS501. Figure 8 shows a system formed with TTL logic. The system requirements make it imperative only to use discrete asynchronous latches. Thus, none of the 7 latches in the system can be directly replaced by registers. The system diagram is drafted using Futurenet ${ }^{T M}$ DASH-2 Schematic Designer. The system is partitioned into two PLS173s and one PLS153. In order to convert the system into its targeted PLD's, the PINLIST (see Figures 9a-9c) has to be defined. Using the AMAZE PIN-LIST editor, the specified PLD's are labeled with the same labels as those on the system schematic (Figure 8). After the declaration of labels, AMAZE automatically converts the system to the designated PLDs. The AMAZE
generated boolean equation files are shown in Figures 9a, 9b, and 9c. Figure 10 shows the overall system implemented with PLDs. The logic condensation capabilities of PML makes it feasitule to replace the whole system by a single PLHS501 (Figure 11). The PLHS501 in this design will still have ample space for any future additions.

The above example demonstrates only part of the PLHS501 capabilities. The introduction of PML devices and their immense logic power will pave the way for a new generation of efficient and elegant systems.

## REFERENCES

1. Cavian, Napoleone 1985. "Third Generation PLD Architecture Breaks AND-OR Bottleneck', WESCON 1985 Conference Proceedings.
2. Wong, David K. "Third Generation PLS Architecture and its Applications', Electro 1986 Conference Proceedings.
3. '1986 PLD Data Manual', Signetics Corporation.





Figure 9. Part 1: PLS173



Figure 9b. Part 2: PLS173

## 

| LABEL | ** | FNC | **PIN |  |  | FIN** |  | FNC | ** | LABEL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OT1BIN3A | ** | I | ** | 1-1 |  | 1-20 | ** | +5V |  |  |
| OTIEINSE | ** | I | ** | 2-1 |  | 1-19 | ** | E |  |  |
| INBC | ** | I | ** | 3-1 | P | 1-1日 | ** | B |  |  |
| OT2IN3D | ** | I | ** | 4-1 | $L$ | 1-17 | ** | 0 |  |  |
| OT2GIN3E | ** | I | ** | 5-1 | 5 | 1-16 | ** | 10 |  |  |
| OTiF | ** | I | ** | 6-1 | 1 | i-15 | ** | 0 |  |  |
| IN1L | * | I | ** | 7-1 | 5 | i-14 | ** | 0 |  | INIK |
| INIH | ** | I | ** | 8-1 | 3 | i-13 | ** | 0 |  |  |
| \%OT3AIN1F | ** | 10 | ** | 9-1 |  | 1-12 | ** | 0 |  |  |
| GND | ** | OV | ** | 10-1 |  | 1-11 | ** | I |  |  |

## EDEVICE TYPE <br> PLS133 CDRAWING <br> GREVISIDN <br> QDATE BSMMBCL <br> aCOMPANY <br> QNAME <br> ADESCRIPTION <br> GCOMMON PRODUCT TERM <br> G1/O DIRECTION <br> @OUTFUT POLARITY <br> QLOGIC EQUATION



## PLHS501 Programmable Macro Logic Primer

AN29


CD12990
Figure 10. System in Figure 8 Implemented With PLD's


Figure 11. System in Figure 10 Implemented With PLHS501

## Signetics

Application Specific Products

## INDEX

## Section 10

Package OutlinesA PLASTIC: Leaded Chip Carrier10-3
F CERAMIC: Dual-In-Line ..... 10-5
FA CERAMIC: Dual-In-Line With Quartz Window ..... 10-7
N PLASTIC: Dual-In-Line ..... 10-9

## Package Outlines

## PLASTIC PLCC

1. Package dimensions conform to JEDEC specifications for standard Leaded Chip Carrier outline (PLCC) package.
2. Controlling dimensions are given in inches with dimensions in millimeters contained in parentheses.
3. Dimensions and tolerancing per ANSI Y14.5M - 1982.
4. 'D-E" and 'F-G' are reference datums on the molded body and do not include mold flash or protrusions. Mold flash or
protrusions shall not exceed 0.15 mm ( $0.006^{\prime \prime}$ ) on any side.
5. Pin numbers start with pin \#1 and continue counterclockwise when viewed from the top.
6. Lead material: Olin 194 (Copper Alloy) or equivalent, solder dipped.
7. Body material: Plastic (Epoxy).
8. Thermal resistance values are determined by temperature sensitive parameter (TSP) method. This method uses the
forward voltage drop of a calibrated diode to measure the change in junction temperature due to a known power application. Test condition for these values follow:

$$
\begin{aligned}
& \text { Test Ambient - Still Air } \\
& \text { Test Fixture - } \theta_{\mathrm{JA}}-\text { Giass epoxy test } \\
& \text { board }\left(2.24^{\prime \prime} \times\right. \\
& \left.2.24^{\prime \prime} \times 0.062^{\prime \prime}\right) \\
& \qquad \theta_{\mathrm{JC}}-\text { Water cooled heat } \\
& \text { sink }
\end{aligned}
$$

## PLASTIC LEADED CHIP CARRIER (PLCC)

| NO. OF LEADS | PACKAGE CODE | DESCRIPTION |
| :---: | :---: | :---: |
| 20 | A | 350 mil-wide |
| 28 | A | 450 mil-wide |
| 52 | A | 750 mil-wide |


| TYPICAL $\theta_{\text {JA }} / \theta_{\text {JC }}$ VALUES ( ${ }^{\circ} \mathbf{C} / \mathrm{W}$ ) |  |  |  |
| :---: | :---: | :---: | :---: |
| Die <br> Size | Power <br> Dissipation $(W)$ | Average <br> $\theta_{\text {JA }}$ | Average <br> $\theta_{\text {JC }}$ |
| 20 K | .75 | 70 | 30 |
| 25 K | 1.0 | 61 | 23 |
| 50 K | 1.0 | 42 | 15 |

## 20-PIN PLASTIC PLCC (A PACKAGE)



## Package Outlines

## 28-PIN PLASTIC PLCC (A PACKAGE)



## 52-PIN PLASTIC PLCC (A PACKAGE)



## Package Outlines

## HERMETIC CERDIP

1. Package dimensions conform to JEDEC specifications for standard Ceramic Dual Inline (Cerdip) package.
2. Controlling dimensions are given in inches with dimensions in millimeters, mm , contained in parentheses.
3. Dimensions and tolerancing per ANSI Y14.5M - 1982.
4. Pin numbers start with pin \#1 and continue counterclockwise when viewed from the top.
5. These dimensions measured with the leads constrained to be perpendicular to plane T.
6. Lead material: ASTM alloy F-30 (Alloy 42) or equivalent - tin plated or solder dipped.
7. Body Material: Ceramic with glass seal at leads.
8. Thermal resistance values are determined by temperature sensitive parameter (TSP) method. This method uses the
forward voltage drop of a calibrated diode to measure the change in junction temperature due to a known power application. Test condition for these values follow:
Test Ambient - Still Air
Test Fixture - $\theta_{\mathrm{JA}}$ - Textool ZIF socket with $0.04^{\prime \prime}$ standoff
$\theta_{\mathrm{JC}}$-Water cooled heat sink

## HERMETIC DUAL-IN-LINE PACKAGES

| NO. OF LEADS | PACKAGE CODE | DESCRIPTION |
| :---: | :---: | :---: |
| 20 | F | 300 mil-wide |
| 24 | F | 300 mil-wide |
| 28 | F | 600 mil-wide |


| TYPićái $\hat{\theta}_{\text {JA }} / \hat{J}_{\text {JC }}$ VÁLUUES ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |  |  |  |
| :---: | :---: | :---: | :---: |
| Die | Power <br> Size | Average <br> $\theta_{\text {JA }}$ | Average <br> $\theta_{\text {JC }}$ |
| 20 K | .75 | 70 | 7.8 |
| 25 K | 1.0 | 62 | 6.9 |
| 30 K | 1.0 | 48 | 6.3 |

## 20-PIN CERAMIC DIP (F PACKAGE)



## Package Outlines

## 24-PIN CERAMIC DIP (F PACKAGE)



## 28-PIN CERAMIC DIP (F PACKAGE)



## Package Outlines

## HERMETIC CERDIP WITH QUARTZ WINDOW

1. Package dimensions conform to JEDEC specifications for standard Ceramic Dual Inline (Cerdip) package.
2. Controlling dimensions are given in inches with dimensions in millimeters, mm , contained in parentheses.
3. Dimensions and tolerancing per ANSI Yi4.5M - 1982.
4. Pin numbers start with pin \#1 and continue counterclockwise when viewed from the top.
5. These dimensions measured with the leads constrained to be perpendicular to plane $T$.
6. Lead material: ASTM alloy F-30 (Alloy 42) or equivalent - tin plated or solder dipped
7. Body Material: Ceramic with glass seal at ieads.
8. Thermal resistance values are determined by temperature sensitive parameter (TSP) method. This method uses the
forward voltage drop of a calibrated diode to measure the change in junction temperature due to a known power appiication. Test condition for these values follow:

Test Ambient - Still Air
Test Fixture - $\theta_{\text {JA }}$ - Textool ZIF socke with $0.04^{\prime \prime}$ standoff
$\theta_{\mathrm{JC}}-$ Water cooled heat sink
hermetic dual-in-Line packages with quartz window

| NO. OF LEADS | PACKAGE CODE | DESCRIPTION | TYPICAL $\theta_{\text {JA }} / \theta_{\text {Jc }}$ VALUES ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 24 \\ & 28 \end{aligned}$ | $\begin{aligned} & F \\ & F \end{aligned}$ | 300 mil -wide 600 mil-wide | $\begin{gathered} \text { Die } \\ \text { Size } \end{gathered}$ | Power <br> Dissipation (W) | Average $\theta_{\text {JA }}$ | Average $\theta_{\mathrm{Jc}}$ |
|  |  |  | $\begin{aligned} & 25 \mathrm{~K} \\ & 30 \mathrm{~K} \end{aligned}$ | $\begin{aligned} & .5 \\ & .5 \end{aligned}$ | $\begin{aligned} & 67 \\ & 52 \end{aligned}$ | $\begin{aligned} & 7.8 \\ & 7.0 \end{aligned}$ |

## 24-PIN CERAMIIC DIP WITH QUÂRTZ WINDOW (FA PACKAGE)



## Package Outlines

## 28-PIN CERAMIC DIP WITH QUARTZ WINDOW (FA PACKAGE)



## Package Outlines

## PLASTIC DIP

1. Package dimensions conform to JEDEC specification MS-001-AA for standard Plastic Dual Inline (DIP) package.
2. Controlling dimensions are given in inches with dimensions in millimeters, mm , contained in parentheses.
3. Dimensions and tolerancing per ANSI Y14.5M - 1982.
4. "T", "D" and "E" are reference datums on the molded body and do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.01 inch $(0.25 \mathrm{~mm})$ on any side.
5. These dimensions measured with the leads constrained to be perpendicular to plane T .
6. Pin numbers start with pin \#1 and continue counterclockwise when viewed from the top.
7. Lead material: Olin 194 (Copper Alloy) or equivalent, solder dipped.
8. Body material: Plastic (Epoxy)
9. Thermal resistance values are determined by temperature sensitive parameter (TSP) method. This method uses the
forward voltage drop of a calibrated diode to measure the change in junction temperature due to a known power application. Test condition for these values follow:
Test Ambient - Still Air
Test Fixture - $\theta_{\text {JA }}-$ Textool ZIF socket with $0.04^{\prime \prime}$ standoif
$\theta_{\mathrm{JC}}$-Water cooled heat sink

## PLASTIC DUUȦL-iN-LiNE PÁCKÂGES

| NO. OF LEADS | PACKAGE CODE | DESCRIPTION |
| :---: | :---: | :---: |
| 20 | N | Cu. Lead Frame <br> 300mil-wide <br> Cu. Lead Frame <br> 300mil-wide <br> Cu. Lead Frame <br> 600mil-wide |


| TYPICAL $\theta_{\text {JA }} / \theta_{\text {JC }}$ VALUES $\left({ }^{\circ} \mathrm{C} / \mathrm{W}\right)$ |  |  |  |
| :---: | :---: | :---: | :---: |
| Die | Power <br> Dissipation $(W)$ | Average <br> $\theta_{\text {JA }}$ | Average <br> $\theta_{\text {Jc }}$ |
| Size |  |  |  |

## 20-PIN PLASTIC (N PACKAGE)



## Package Outlines

## 24-PIN PLASTIC (N PACKAGE)



28-PIN PLASTIC (N PACKAGE)


## Signetics <br> Application Specific Products <br> Sales Offices

## Sales Offices

## SIGNETICS <br> HEADQUARTERS

811 East Arques Avenue
P.O. Box 3409

Sunnyvale,
California 94088-3409
Phone: (408) 991-2000

## ALABAMA

## Huntsville

Phone: (205) 830-4001
ARIZONA
Phoenix
Phone: (602) 265-4444
CALIFORNIA
Canoga Park
Phone: (818) 340-1431
Irvine
Phone: (714) 833-8980
(213) 588-3281

Los Angeles
Phone: (213) 670-1101

## San Diego

Phone: (619) 560-0242
Sunnyvale
Phone: (408) 991-3737
COLORADO
Aurora
Phone: (303) 751-5011
FLORIDA
Clearwater
Phone: (813) 796-7086
Ft. Lauderdale
Phone: (305) 486-6300
georgia
Atlanta
Phone: (404) 953-0067
ILLINOIS
Itasca
Phone: (312) 250-0050
INDIANA
Kokomo Phone: (317) 453-6462
KANSAS
Overiand Park Phone: (913) 469-4005

MARYLAND
Gien Burnie Phone: (301) 787-0220

## MASSACHUSETTS

Littleton Phone: (617) 486-8411
MICHIGAN
Farmington Hills Phone: (313) 476-1610

## MINNESOTA

Edina
Phone: (612) 835-7455
NEW JERSEY
Parsippany
Phone: (201) 334-4405
NEW YORK
Hauppauge
Phone: (516) 348-7877
Wappingers Falls
Phone: (914) 297-4074
NORTH CAROLINA
Cary
Phone: (919) 481-0400
OHIO
Worthington
Phone: (614) 888-7143

## OREGON

Portland
Phone: (503) 297-5592
PENNSYLVANIA
Plymouth Meeting
Phone: (215) 825-4404
TENNESSEE
Greeneville
Phone: (615) 639-0251
TEXAS
Austin
Phone: (512) 339-9944
Richardson
Phone: (214) 644-3500
CANADA
SIGNETICS CANADA, LTD.
Etobicoke, Ontario Phone: (416) 626-6676
Nepean, Ontario
Signetics, Canada, Ltd.
Phone: (613) 726-9576

## REPRESENTATIVES

## ARIZONA

Scottsdale
Thom Luke Sales, Inc. Phone: (602) 941-1901

## CALIFORNIA

Santa Clara
Magna Sales
Phone: (408) 727-8753
CONNECTICUT
Brookfield
M \& M Associates Phone: (203) 775-6888

## FLORIDA

Clearwater
Sigma Technical Sales Phone: (813) 791-0271

Ft. Lauderdale
Sigma Technical Sales
Phone: (305) 731-5995
ILLINOIS
Hoffman Estates
Micro-Tex, Inc.
Phone: (312) 382-3001
iNDIANA
Indianapolis
Mohrfield Marketing Inc.
Phone: (317) 546-6969

## KANSAS

Kansas City
B.C. Electronic Sales

Phone: (913) 342-1211
MASSACHUSETTS
Needham Heights
Kanan Associates
Phone: (617) 449-7400
Com-Sales, Inc.
Phone: (617) 444-8071

## MICHIGAN

Bloomfield Hills
Enco Marketing Phone: (313) 642-0203

## minnesota

Eden Prairie
High Technology Sales
Phone: (612) 944-7274
MISSOURI
St. Louis
B.C. Electronic Sales

Phone: (314) 521-6683
NEW JERSEY
East Hanover
Emtec Sales, Inc.
Phone: (201) 428-0600
NEW MEXICO
Albuquerque
F.P. Sales

Phone: (505) 345-5553
NEW YORK
Ithaca
Bob Dean, Inc.
Phone: (607) 257-1111
OHIO
Cleveland
Covert \& Newman
Phone: (216) 663-3331
Dayton
Covert \& Newman Phone: (513) 439-5788
Worthington
Covert \& Newman
Phone: (614) 888-2442

OKLAHOMA
Tulsa
Jerry Robinson and
Associates
Phone: (318) © $£ 5-3562$
OREGON
Hillsboro
Western Technical Sales
Phone: (503) 640-4621
PENNSYLVANIA
Pittsburgh
Covert \& Newman
Phone: (412) 531-2002
Willow Grove
Delta Technical Sales Inc.
Phone: (215) 657-7250
TEXAS
Houston
OM Sales
Phone: (713) 789-4426
UTAH
Salt Lake City
Electrodyne
Phone: (801) 486-3801

## WASHINGTON

## Bellevue

Western Technical Sales
Phone: (206) 641-3900
Spokane
Western Technical Sales
Phone: (509) 922-7600
WISCONSIN
Waukesha
Micro-Tex, Inc.
Phone: (414) 542-5352
CANADA
Burnaby, British Columbia Tech-Trek, Ltd. Phone: (604) 439-1367
Mississauga, Ontario Tech-Trek, Ltd.
Phone: (416) 238-0366
Nepean, Ontario
Tech-Trek, Ltd.
Phone: (613) 726-9562
Richmond, British Columbia Tech-Trek, Ltd. Phone: (604) 271-3149
Ville St. Laurent, Quebec Tech-Trek, Ltd. Phone: (514) 337-7540

## DISTRIBUTORS

ALABAMA
Huntsville
Arrow Electronics
Phone: (205) 837-6955
Hamilton/Avnet Electronics Phone: (205) 837-7210
Schweber Electronics
Phone: (205) 882-2200

## ARIZONA

Phoenix
Schweber Electronics
Phone: (602) 997-4874
Wyle LEMG
Phone: (602) 249-2232

## Tempe

Anthem Electronics
Phone: (602) 966-6600
Arrow Electronics
Phone: (602) 968-4800
Hamilton/Avnet Electronics
Phone: (602) 231-5100
CALIFORNIA
Calabasas
Wyle LEMG
Phone: (818) 880-9000
Canoga Park
Schweber Electronics
Phone: (818) 999-4702

## Chatsworth

Anthem Electronics Phone: (818) 700-1000
Arrow Electronics
Phone: (818) 701-7500
Hamilton/Avnet Electronics
Phone: (818) 700-2600 Hamilton/Avnet Electronics
Phone: (818) 700-6500

## Costa Mesa

Avnet Electronics
Phone: (714) 754-6111
Hamilton Electro Sales
Phone: (714) 641-4100
Culver City
Hamilton/Avnet Electronics
Phone: (213) 558-2121
El Segundo
Wyle LEMG
Phone: (213) 322-8100
Garden Grove Wyle LEMG Computer Products
Phone: (714) 891-1717

## Gardena

Hamilton/Avnet Electronics Phone: (213) 217-6364 Schweber Electronics Phone: (213) 327-8409

## Hayward

Arrow Electronics
Phone: (415) 487-4600

## Irvine

Anthem Electronics
Phone: (714) 768-4444
Schweber Electronics
Phone: (714) 863-0200
Wyle LEMG
Phone: (714) 863-1611

## Ontario

Hamilton/Avnet Electronics
Phone: (714) 989-4602
Rancho Cordova
Wyle LEMG
Phone: (916) 638-5282

## Sacramento

Hamilton/Avnet Electronics
Phone: (916) 925-2216
Schweber Electronics
Phone: (916) 929-9732

## San Diego

Anthem Electronics
Phone: (619) 453-4871
Arrow Electronics
Phone: (619) 565-4800
Hamilton/Avnet Electronics
Phone: (619) 571-7510
Schweber Electronics
Phone: (619) 450-0454
Wyle LEMG
Phone: (619) 565-9171

## San Jose

Anthem Electronics Inc.
Phone: (408) 295-4200
Schweber Electronics
Phone: (408) 946-7171
Santa Clara
Wyle LEMG
Phone: (408) 727-2500

## Sunnyvale

Arrow Electronics
Phone: (408) 745-6600
Hamilton/Avnet Electronics
Phone: (408) 743-3355

## Torrance

Hamilton/Avnet Electronics
Phone: (213) 615-3962
Tustin
Arrow Electronics
Phone: (714) 838-5422

## COLORADO

## Aurora

Arrow Electronics
Phone: (303) 696-1111

## Denver

Wyle Distribution Group
Phone: (303) 457-9953

## Englewood

Anthem Electronics
Phone: (303) 790-4500
Hamilton/Avnet Electronics
Phone: (303) 779-9998
Schweber Electronics
Phone: (303) 799-0258

## Thornton

Wyle LEMG
Phone: (303) 457-9953

## CONNECTICUT

Danbury
Hamilton/Avnet Electronics
Phone: (203) 797-2800
Schweber Electronics
Phone: (203) 748-7080

## Meriden

Lionex Corp.
Phone: (203) 237-2282
Wallingford
Arrow Electronics
Phone: (203) 265-7741

## FLORIDA

Altamonte Springs Schweber Electronics
Phone: (305) 331-7555
Clearwater
Arrow Electronics
Phone: (813) 576-8995

## Deerfield Beach

Arrow Electronics
Phone: (305) 429-8200
Ft. Lauderdale
Hamilton/Avnet Electronics
Phone: (305) 971-2900

## Hollywood

Schweber Electronics
Phone: (305) 927-0511

## Palm Bay

Arrow Electronics
Phone: (305) 725-1480

## St. Petersburg

Hamilton/Avnet Electronics
Phone: (813) 576-3930

## Winter Park

Hamilton/Avnet Electronics
Phone: (305) 628-3888

## GEORGIA

Norcross
Arrow Electronics Phone: (404) 449-8252
Hamilton/Avnet Electronics
Phone: (404) 447-7507
Q.C. Southeast, Inc.

Phone: (404) 449-9508
Schweber Electronics
Phone: (404) 449-9170

## ILLINOIS

Elk Grove
Schweber Electronics
Phone: (312) 364-3750

## Schaumburg

Arrow Electronics
Phone: (312) 397-3440

## Bensenville

Hamilton/Avnet Electronics
Phone: (312) 860-7700

## INDIANA

Carmel
Hamilton/Avnet Electronics
Phone: (317) 844-9333

## Indianapolis

Arrow Electronics
Phone: (317) 243-9353

## IOWA

Cedar Rapids
Arrow Electronics
Phone: (319) 395-7230
Hamilton/Avnet Electronics
Phone: (319) 362-4757
Schweber Electronics
Phone: (319) 373-1417

## KANSAS

Overland Park
Arrow Electronics Phone: (913) 642-0592 Hamilton/Avnet Electronics
Phone: (913) 888-8900
Schweber Electronics
Phone: (913) 492-2922

## MARYLAND

Columbia
Arrow Electronics
Phone: (301) 995-0003
Hamilton/Avnet Electronics
Phone: (301) 995-3500
Lionex Corp.
Phone: (301) 964-0040

## Gaithersburg

Schweber Electronics
Phone: (301) 840-5900

## MASSACHUSETTS

Peabody Hamilton/Avnet Electronics
Phone: (617) 531-7430

## Wilmington

Lionex Corp.
Phone: (617) 657-5170
Schweber Electronics
Phone: (617) 275-5100

## Woburn

Arrow Electronics
Phone: (617) 933-8130
Hamilton/Avnet Electronics
Phone: (617) 273-7500

## Sales Offices

## MICHIGAN

Ann Arbor
Arrow Electronics
Phone: (313) 971-8220

## Grand Rapids

Arrow Electronics
Phone: (616) 243-0912
Hamilton/Avnet Electronics
Phone: (616) 243-6805

## Livonia

Hamilton/Avnet Electronics
Phone: (313) 522-4700
Schweber Electronics
Phone: (313) 525-8100

## MINNESOTA <br> Edina

Arrow Electronics
Phone: (612) 830-1800
Schweber Electronics
Phone: (612) 941-5280

## Minnetonka

 Hamilton/Avnet Electronics Phone: (612) 932-0600
## MISSOURI

Earth City
Hamilton/Avnet Electronics Phone: (314) 344-1200
Schweber Electronics
Phone: (314) 739-0526
St. Louis
Arrow Electronics
Phone: (314) 567-6888

## NEW HAMPSHIRE

Manchester
Arrow Electronics Phone: (603) 668-6968 Hamilton/Avnet Electronics Phone: (603) 624-9400 Schweber Electronics Phone: (603) 625-2250

## NEW JERSEY

Cherry Hill
Hamilton/Avnet Electronics Phone: (609) 424-0100

## Fairfield

Arrow Electronics
Phone: (201) 575-5300 Hamilton/Avnet Electronics Phone: (201) 575-3390 Lionex Corporation Phone: (201) 227-7960 Schweber Electronics Phone: (201) 227-7880

## Marlton

Arrow Electronics
Phone: (609) 596-8000

## NEW MEXICO

Albuquerque
Hamilton/Avnet Electronics
Phone: (505) 765-1500
Ariow Electronics
Phone: (505) 243-4566

## NEW YORK

Buffalo
Summit Distributors
Phone: (716) 887-2800

## East Syracuse

Hamilton/Avnet Electronics
Phone: (315) 437-2641
Hauppauge, L.I.
Arrow Electronics
Phone: (516) 231-1000
Hamilton/Avnet Electronics
Phone: (516) 231-9800
Lionex Corp.
Phone: (516) 273-1660
Liverpool
Arrow Electronics
Phone: (315) 652-1000

## Rochester

Arrow Electronics
Phone: (716) 427-0300
Hamilton/Avnet Electronics
Phone: (716) 475-9130
Schweber Electronics
Phone: (716) 424-2222
Westbury, L.I.
Schweber Electronics
Phone: (516) 334-7474
NORTH CAROLINA
Raleigh
Arrow Electronics
Phone: (919) 876-3132
Hamilton/Avnet Electronics
Phone: (919) 878-0810
Schweber Electronics
Phone: (919) 876-0000

## OHIO

Beechwood
Schweber Electronics Phone: (216) 464-2970

## Centerville

Arrow Electronics
Phone: (513) 435-5563

## Cleveland

Hamilton/Avnet Electronics
Phone: (216) 831-3500

## Columbus

Arrow Electronics
Phone: (614) 885-8362

## Dayton

Hamilton/Avnet Electronics Phone: (513) 439-6700 Schweber Electronics Phone: (513) 439-1800

## Solon

Arrow Electronics
Phone: (216) 248-3990

## Westerville

Hamilton/Avnet Electronics
Phone: (614) 882-7004
OKLAHOMA
Tulsa
Arrow Electronics
Phone: ( 918 ) 665-7700
Quality Components
Phone: (918) 664-8812
Schweber Electronics
Phone: (918) 622-8000
OREGON
Hillsboro
Wyle LEMG
Phone: (503) 640-6000

## Lake Oswego

Anthem Electronics
Phone: (503) 684-2661
Hamilton/Avnet Electronics
Phone: (503) 635-8831
Tigard
Arrow Electronics
Phone: (503) 684-1690

## PENNSYLVANIA

Horsham
Lionex Corp.
Phone: (215) 443-5150
Schweber Electronics
Phone: (215) 441-0600
Monroeville
Arrow Electronics
Phone: (412) 856-7000

## Pittsburgh

Hamilton/Avnet Electronics
Phone: (412) 281-4150
Schweber Electronics
Phone: (412) 782-1600
RHODE ISLAND
E. Providence

Arrow Electronics
Phone: (401) 431-0980

## TEXAS

Addison
Quality Components
Phone: (214) 733-4300

## Austin

Arrow Electronics
Phone: (512) 835-4180
Hamilton/Avnet Electronics
Phone: (512) 837-8911
Quality Components
Phone: (512) 835-0220
Wyle LEMG
Phone: (512) 834-9957
Schweber Electronics
Phone: (512) 458-8253

## Carrolton

Arrow Electronics
Phone: (214) 380-6464

## Dallas

Schweber Electronics
Phone: (214) 661-5010

## Houston

Arrow Electronics
Phone: (713) 530-4700
Hamilton/Avnet Electronics
Phone: (713) 780-1771
Schweber Electronics
Phone: (713) 784-3600
Wyle LEMG
Phone: (713) 879-9953

## Irving

Hamilton/Avnet Electronics
Phone: (214) 659-4111

## Richardson

Wyle LEMG
Phone: (214) 235-9953
Sugar Land
Quality Components
Phone: (713) 240-2255
UTAH
Salt Lake City
Anthem Electronics
Phone: (801) 973-8555
Arrow Electronics
Phone: (801) 972-0404
Hamilton/Avnet Electronics
Phone: (801) 972-2800
Wyle LEMG
Phone: (801) 974-9953

## WASHINGTON

## Beilevue

Arrow Electronics
Phone: (206) 643-4800
Hamilton/Avnet Electronics
Phone: (206) 453-5844
Wyle LEMG
Phone: (206) 453-8300

## Redmond

Anthem Electronics
Phone: (206) 881-0850

## WISCONSIN

## Brookfield

Arrow Electronics
Phone: (414) 792-0150
Schweber Electronics
Phone: (414) 784-9020

## New Berlin

Hamilton/Avnet Electronics
Phone: (414) 784-4510

## CANADA

Brampton, Ontario
Zentronics, Ltd.
Phone: (416) 451-9600

## Sales Offices

Burnaby, British Columbia Hamilton/Avnet Electronics Phone: (604) 437-6667
Calgary, Alberta Hamilton/Avnet Electronics Phone: (403) 230-3586 Zentronics, Ltd. Phone: (403) 272-1021
Mississauga, Ontario Hamilton/Avnet Electronics Phone: (416) 677-7432

Montreal, Québec
Arrow Canada Phone: (514) 735-5511

## Nepean, Ontario

Arrow Canada Phone: (613) 226-6903 Hamilton/Avnet Electronics Phone: (613) 226-1700 Zentronics, Ltd. Phone: (613) 226-8840

## Québec, Québec

Arrow Canada
Phone: (418) 687-4231
Richmond, British Columbla Zentronics, Ltd. Phone: (604) 273-5575
Saskatoon, Saskatchewan
Zentronics, Ltd.
Phone: (306) 955-2202
Toronto, Ontario
Arrow Canada
Phone: (416) 661-0220
Ville St. Laurent, Québec Hamilton/Avnet Electronics
Phone: (514) 335-1000
Zentronics, Ltd.
Phone: (514) 737-9700
Waterloo, Ontario
Zentronics, Ltd. Phone: (519) 884-5700

Winnipeg, Manitoba Zentronics, Ltd. Phone: (204) 775-8661

FOR SIGNETICS
PRODUCTS
WORLDWIDE:
ARGENTINA
Philips Argentina S.A.
Buenos Aires
Phone: 54-1-541-7141

AUSTRALIA
Philips Electronic
Components and Materials, Ltd.

Artarmon, N.S.W.
Phone: 61-2-439-3322

## AUSTRIA

Osterrichische Philips
Bauelemente
Wien
Phone: 43-222-62-91-11

## BELGIUM

N.V. Philips \& MBLE

Bruxelles
Phone: 32-2-5-23-00-00

## BRAZIL

Phillips Do Brasil, Ltda. Sao Paulo
Phone: 55-11-211-2600
CHILE
Philips Chilena S.A.
Santiago
Phone: 56-02-077-3816
COLOMBIA
Iprelenso, Ltda.
Bogota
Phone: 57-1-2497624

## DENMARK

Miniwatt A/S
Copenhagen S
Phone: 45-1-54-11-33
FINLAND
Oy Philips Ab
Helsinki
Phone: 358-0-172-71
FRANCE
R.T.C. La Radiotechnique-

Compelec
Paris
Phone: 33-1-43-38-80-00

## GERMANY

Valvo
Hamburg
Phone: 49-40-3-296-1
GREECE
Philips Hellenique S.A. Athens
Phone: 30-1-9-21-5111

## HONG KONG

Philips Hong Kong, Ltd.
Kwai Chung
Phone: 852-0-245-121

INDIA
Peico Electronics \& Elect. Ltd.

Bombay
Phone: 91-22-493-8721
INDONESIA
P.T. Philips-Ralin Electronics

Jakarta Selatan
Phone: 62-21-512-572
IRELAND
Philips Electrical Ltd. Dublin
Phone: 353-1-69-33-55
ISRAEL
Rapac Electronics, Ltd. Tel Aviv
Phone: 972-3-477115
ITALY
Phillips S.p.A.
Milano
Phone: 39-2-67-52-1
JAPAN
Nikon Philips Corp. Tokyo Phone: 81-3-448-5617
Signetics Japan Ltd.
Phone: 81-3-230-1521/2
KOREA
Philips Industries, Ltd. Seoul
Phone: 82-2-794-5011/2/3
/4/5
MEXICO
Electronica S.A. de C.V.
Toluca
Phone: (721) 613-00
NETHERLANDS
Philips Nederland B.V. Eindhoven
Phone: 31-40-793-333
NEW ZEALAND
Philips New Zealand Ltd.
Auckland
Phone: 64-9-605914

## NORWAY

Norsk A/S Philips
Osio
Phone: 47-2-68-02-00

## PERU

Cadesa
Lima
Phone: 51-14-319253
PHILIPPINES
Philips Industrial Dev., Inc. Makat
Phone: 63-2-868951-9

PORTUGAL
Philips Portuguesa SARL
Lisbon
Phone: 351-1-65-71-85

## SINGAPORE

Philips Project Dev. Pte., Ltd.
Singapore
Phone: 65-350-2000

## SOUTH AFRICA

E.D.A.C. (PTY), Ltd.

Joubert Park
Phone: 27-11-402-4600

## SPAIN

Miniwatt S.A.
Barcelona
Phone: 34-3-301-63-12
SWEDEN
Philips Komponenter A.B.
Stockholm
Phone: 46-8-782-10-00
SWITZERLAND
Philips A.G.
Zurich
Phone: 41-1-488-2211
TAIWAN
Philips Taiwan, Ltd.
Taipei
Phone: 886-2-712-0500

## THAILAND

Philips Electrical Co.
of Thailand Litd.
Bangkok
Phone: 66-2-233-6330-9
TURKEY
Turk Philips
Ticaret A.S.
Istanbul
Phone: 90-11-43-59-10
UNITED KINGDOM
Mullard, Ltd.
London
Phone: 44-1-580-6633
UNITED STATES
Signetics International Corp.
Sunnyvale, California
Phone: (408) 991-2000
URUGUAY
Luzilectron, S.A.
Montevideo
Phone: 598-91-56-41/42
/43/44
VENEZUELA
Magnetica, S.A.
Caracas
Phone: 58-2-241-7509


[^0]:    1. All gate inputs with a blown link float to a logic "1".
[^1]:    NOTES:

    1. All AND gate inputs with a blown link float to a logic " 1 "
    2. All OR gate inputs with a blown fuse float to a logic " 0 ".
    
[^2]:    NOTES:

    1. All programmed "AND" gate locations are pulled to a logic "1"
    2. All programmed "OR' gate locations are pulled to a logic " 0 ".
    
[^3]:    NOTES:

    1. All programmed "AND" gate locations are pulied to a logic " 1 ".
    2. All programmed "OR" gate iocations are puiled to a logic " 0 ".
    
[^4]:    NOTES:

    1. All AND gate inputs with a blown link float to a logic '
    2. All OR gate inputs with a blown fuse float to a logic ' 0 '
    
[^5]:    *PAL is a registered trademark of Monolithic Memories, Inc.

[^6]:    Notes on following page.

[^7]:    Notes on following page.

[^8]:    Notes on iollowing page.

[^9]:    Notes on following page.

[^10]:    Notes on following page.

[^11]:    1. All AND gate inputs with a blown link float to a logic "1"
    2. All OR gate inputs with a blown fuse float to logic " 0 "
    3. Programmatle cornection.
[^12]:    ${ }^{1}$ PAL is a trademark of MMI.

[^13]:    NOTES:

    1. All programmed "AND" gate locations are pulled to logic "1"
    2. All programmed "OR" gate locations are pulled to logic " 0 ".
    
[^14]:    Notes on following page.

[^15]:    Notes on following page

[^16]:    Fusible $\mathrm{Ni}-\mathrm{Cr}$ links are initially intact at all array cross-points.

[^17]:    Notes on following page.

[^18]:    See Notes on following page.

[^19]:    See Notes on following page.

[^20]:    NOTES:

    1. The FPLS is shipped with all links initially intact. Thus, a background of " 0 " for all Terms, and an " H " for the P/E option, exits in the table, shown BLANK instead for clarity. 2. Unsed $C_{n t} I_{m}$, and $P_{s}$ bits are normally programmed Don't Care ( - ).
    2. Unused Transition Terms can be left blank for future code modification, or programmed as (-) for maximum speed.
    3. Letters in variable fields are used as identifiers by logic type programmers.
[^21]:    ${ }^{*}$ PAL $^{T M}$ and PLE ${ }^{\text {TM }}$ are trademarks of Monolithic Memories, Inc.
    (** AMAZE accepts TTL schematics generated with DATA-I/O FUTURENET DASH)

[^22]:    Figure 3. Logic Diagram of PLS159 FPLS

[^23]:    1. Refer to Signetics Programmable Logic Data Manual for a complete description of the AMAZE programmable logic development software.
