## PAL®/PLE™ DEVICE Programmable Logic Array Handbook Fifth Edition ## PAL®/PLE™ Device Programmable Logic Array | | PAL® Device Introduction | |----------|----------------------------------| | | PAL®/HAL® Device Specifications | | 3 | PAL Device Programmer Ref. Guide | | 7 | HAL/ZHAL™ Devices | | | Logic Cell Array™ | | | PALASM® Software Syntax | | | PAL Device Applications | | 1 | Logic Tutorial | | | PLE™ Devices | | 1 | PLE Circuit Applications | | | Article Reprints | | 1 | General Information | | 1 | Package Drawings | | <u> </u> | Representatives and Distributors | PAL®, HAL®, PALASM®, and SKINNYDIP® are registered trademarks of Monolithic Memories Inc. PLE™, MegaPAL™, ZHAL™, ProPAL™, and SMAC™ are trademarks of Monolithic Memories Inc. Logic Cell Array™ is a trademark of XILINX. ©Copyright 1978, 1981, 1983, 1985, 1986 Monolithic Memories Inc. • 2175 Mission College Boulevard • Santa Clara, CA 95054-1592 • (408) 970-9700 • (910) 339-9220 | Table of Contents | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------| | PAL® Device Introduction | 1-2 | | PAL*/HAL* Device Specifications | | | Table of Contents for Section 2 | | | PAL/HAL Devices | | | Small 20 Series: 10H8, 12H6, 14H4, 16H2, 16C1, 10L8, 12L6, 14L4, 16L2 20 (standard) 20-2 (half power) | 2-8 | | Medium 20 Series: 16L8, 16R8, 16R6, 16R4 20 (standard) 20A (high speed) 20A-2 (high speed and half power) 20A-4 (high speed and quarter power) 20B (very high speed) 20B-2 (very high speed and half power) 20B-4 (very high speed and quarter power) 20B-0 (ultra high speed) | 2-21<br>2-22<br>2-24<br>2-25<br>2-26<br>2-27<br>2-28<br>2-29 | | Medium 20PA Series: 16P8A, 16RP8A, 16RP6A, 16RP4A | 2-37 | | Large 20 Series: 16X4, 16A4 | | | Large 20RA: 16RA8 | 2-51 | | Small 24 Series: 12L10, 14L8, 16L6, 18L4, 20L2, 20C1 | 2-55 | | Small 24A Decoder Series: 6L16A, 8L14A | 2-65 | | Medium 24 Series: 20L8, 20R8, 20R6, 20R4 24A (high speed) 24A-2 (high speed and half power) 24B (very high speed) | 2-73<br>2-75 | | Medium 24X Series: 20L10, 20X10, 20X8, 20X4 24X (standard) 24XA (high speed) | 2-83 | | Large 24RS Series: 20S10, 20RS10, 20RS8, 20RS4 | 2-90 | | Large 24RA: 20RA10 | | | PAL32VX10/A | | | PMS14R21/A | 2-113 | | PAL10H20P8 | 2-115 | | MegaPAL devices: 32R16, 64R32 | 2-119 | | f <sub>MAX</sub> Parameters Waveforms | | | Test Load | 2-128 | | MMI PAL® Device Programmer Reference Guide | 3-1 | |--------------------------------------------------------------------------------------------------------------------------|-------------| | Data I/O Corporation 20 Pin Device Families | | | 24 Pin and MegaPAL Device Families | | | Digelec | | | 20 Pin Device Families | | | 24 Pin and MegaPAL Device Families | | | Kontron 20 Pin Device Families | | | 20 Pin Device Families 24 Pin and MegaPAL Device Families | | | <u> </u> | | | Micropross 20 Pin Device Families | 3-9 | | 24 Pin and MegaPAL Device Families | 3-10 | | andre de la companya de la companya de la companya de la companya de la companya de la companya de la companya<br>Promac | | | 20 Pin Device Families | 3-11 | | 24 Pin and MegaPAL Device Families | 3-12 | | Stag Microsystems | | | 20 Pin Device Families | 3-13 | | 24 Pin and MegaPAL Device Families | | | Storey Systems 20 Pin Device Families | | | 20 Pin Device Families | 3-15 | | 그리는 바다가 하는 것이 가는 경기에 들어가 보는 것이 되었다. 그는 그는 그들은 그는 그를 가는 것이 되었다. 그는 그는 그는 그는 그는 그를 가는 것이 없다는 것이다. 그는 그는 그는 그를 가는 것이다. | 3-10 | | Structured Design 20 Pin Device Families | 9 17 | | 24 Pin and MegaPAL Device Families | | | (2) (1) - [2] (1) - [2] (2) - [2] (2) (2) (2) (3) (3) (4) (4) (4) (4) (4) (4) (5) (6) (6) (6) (7) (7) (7) (7) | | | Valley Data Sciences 20 Pin Device Families | 3-19 | | 24 Pin and MegaPAL Device Families | 3-20 | | Varix 20 Pin Device Families | | | | | | 24 Pin and MegaPAL Device Families | 3-22 | | | | | | | | | | | 경기에 가는 사람들이 가장하는 것이 되었다.<br>생물에 가장 가장이 되었다. 사람들이 되었다. 하는 사람들이 되었다. 사람들이 사람들이 되었다. | | | HAL°/ZHAL™ Devices | 1-1 | | ProPALIM HAL and ZHAL Devices: The Logical Solutions for Programmable | - · | | Logic | .4-3 | | ZHAL20A Series — Zero Power CMOS Hard Array Logic | | | | | | ZHAL64R32 — Zero Power CMOS Hard Array Logic4 | | | ZHAL24A Series — Zero Power CMOS Hard Array Logic4 | -24 | | Logic Cell Array <sup>™</sup> | <u>.</u> 1 | | | | | PALASM® Software Syntax | <b>)- 1</b> | | Ş. | PAL Device Applications | 7-1 | |----|-------------------------------------------------------------------|------| | | PAL20L10; 10-Bit Open Collector Buffer | 7-3 | | | PAL20L10; 10-Bit Open Collector Inverting Buffer | 7-5 | | ĸ. | PAL20X10; 10-Bit Addressable Register | 7-7 | | | PAL20L10; MC6800 Microprocessor Interface | 7-10 | | | PAL14L4; Quad 3:1 Multiplexer | | | | PAL20X8; 4-Bit Counter With Register | 7-14 | | | PAL20X8; 4-Bit Counter With Register PAL20X10; 9-Bit Down Counter | 7-16 | | | PAL20X10: Refresh Clock Generator | | | | PAL16R8; Octal Addressable Register | 7-21 | | | PAL16R8; Octal Addressable Register With Demux/Enables | 7-24 | | | PAL16R8; Octal Addressable Register With Demux/Clear | | | | PAL16C1; Rounding-Control Logic | 7-31 | | | PAL16R6; 4-Bit Counter With Terminal Count Lock | | | | PAL18L4; Memory-Mapped I/O | | | | PAL16R4; 74S508 Memory Map Interface #1 | | | | PAL16R4: 74S508 Memory Map Interface #2 | 7-38 | | | PAL20R4; 16 Input Registered Priority Encoder #1 | 7-39 | | | PAL16C1; 16 Input Priority Encoder Interrupt Flag #2 | | | | PAL20R4; 15 Input Registered Priority Encoder | | | | PAL16R4; 8 Input Registered Priority Encoder | 7-44 | | | PAL16R8; Dual Stepper Motor Controller | 7-47 | | | PAL20L10; Clean Octal Latch | | | | PAL16R4; Shaft Encoder #1 | 7-51 | | | PAL16R8; Shaft Encoder #2 | 7-54 | | | PAL20X10; Shaft Encoder #3 | 7-57 | | | PAL6L16; Four-to-Sixteen Decoder | 7-60 | | 9 | PAL8L14; PC I/O Mapper | 7-61 | | | PAL16C1; Octal Comparator | 7-62 | | | PAL16R8; Three-to-Eight Demultiplexer | 7-63 | | | PAL16RP8; Basic Flip-Flops | 7-64 | | | PAL20X10; 9-Bit Register | 7-65 | | | PAL20X10; 10-Bit Register | 7-66 | | | PAL64R32; 16-Bit Barrel Shifter | | | | PAL32R16; 16-Bit Addressable Register | 7-69 | | | PAL16RP8; Traffic Signal Controller | 7-71 | | | PAL16RP6; Memory Handshake Logic | 7-73 | | | PAL16RP4; 4-Bit Counter | 7-76 | | | PAL20X8; 8-Bit Counter | 7-77 | | | PAL20X10; 9-Bit Counter | | | | PAL20RS10; 10-Bit Counter | | | b. | PAL20RA10, PAL16C1; 5-Bit Up Counter | | | | PAL20RA10; 7-Bit I/O Port PAL20RA10; Serial Data Link Controller | 7-83 | | | PAL20RA10; Serial Data Link Controller | 7-85 | | | PAI 20RA10 PAI 20I 10: Interrupt Controller | 7-88 | | Logic Tutorial | 8-1 | |-------------------------------------------------------------------------------------------------------------------------------------------|------| | Table of Contents for Section 8 | 8-2 | | 1.0 Boolean Algebra | | | 1.1 The Language of Logic | 8-3 | | 1.2 AND, OR and NOT | 8-3 | | 1.3 Precedence | 8-4 | | 1.4 Associativity and Commutativity | 8-4 | | 1.5 Postulates and Theorems | 8-4 | | 1.5.1 Duality | 8-4 | | 1.5.2 Using Truth Tables | 8-5 | | 1.5.3 Complement of a Boolean Function | 8-5 | | 1.6 Algebra Simplification | 8-5 | | 1.6.1 Sum-of-Products and Product-of-Sums | 8-5 | | 1.6.2 Canonical Forms | 8-5 | | 1.6.3 Conversion Between Canonical Forms | 8-6 | | 1.7 Exclusive-OR (XOR) and Equivalence (XNOR) | 8-6 | | 1.8 Boolean Operator Summary | 8-7 | | 되는 이 경에 나는 뭐다. 나는 모든 말이 사람이 되었다. 하는 말이 사용을 하면 모든 것은 사람이 작가를 하면 하면 다른다. | | | 2.0 Binary Systems 2.1 Base Conversion | 8-8 | | 2.1.1 Base-2 to Base-10 Conversion | | | 2.1.2 Base-10 to Base-2 Conversion | | | 2.1.2 base-10 to base-2 conversion 2.1.3 Base-2 to Base-8 or Base-16 | 0-0 | | 2.1.3 Dase-2 to Dase-6 of Dase-10 | 8-8 | | 2.2 Simplicity of Binary Arithmetic | | | 2.2.1 1's Complement | | | 2.2.3 2's Complement | | | 2.2.4 Subtraction with 2's Complement | | | | 0-9 | | 3.0 Karnaugh Maps | | | on handage map recommended | 8-10 | | | 8-10 | | 3.1.2 Karnaugh Map Matrix Labels | 8-10 | | 3.1.3 Karnaugh Map Examples | 8-10 | | 4.0 Combinatorial Logic | | | 4.1 Logic Design Introduction | 8-11 | | | 8-11 | | | 8-12 | | 이 그 그의 성공원이 그 그는 그는 사람이 있는데 그리고 있는데 그 그들이 그렇게 되어 그는 그림에 있는데 그리고 있는데 이렇게 되는데 하는데 하는데 하는데 바다 바다를 하는데 다른데 다른데 다른데 다른데 다른데 다른데 다른데 다른데 다른데 다른 | 8-13 | | | 8-14 | | | 8-16 | | 4.7 Adder | 8-17 | | | 8-17 | | 지근 이용 없는 사용에 가게 되었다. 그는 그는 말에 가면서 그렇게 되었다. 그렇게 그렇게 살아 먹었다는 그 남편, 없는 것이 없는 것이다. | | | 5.0 Sequential Logic 5.1 Introduction | 0.04 | | 5.1 Introduction | 8-21 | | | 8-21 | | 그는 그는 아이들을 하고 그렇게 하는데 이번 경기를 하면 한 경기를 하는데 하는데 하는데 아이들이 아이들이 되었다면 하는데 살아지는데 그렇게 되었다면 하는데 아이들이 살아지는데 그렇게 되었다면 하는데 | 8-21 | | | 8-22 | | | 8-22 | | 그 그는 그 일반 사용하다 가입니다. 이 수 있는 그 한 그를 사용하는 사용을 하고 있다면 그를 가입니다. 그는 그는 그를 가입니다. 그를 가입니다. 그를 가입니다. 그를 가입니다. 그를 가입니다. | 8-23 | | | 8-23 | | | 8-23 | | 어느 이 그렇게 이 어느 바람이 바다를 하다면 하게 하게 되는 것이라면 되는 어느 아니는 이 그리면 그런 그런 그런 그런 그는 사람들이 모든 사람들이 모든 것이 없다. | 8-23 | | | 8-24 | | | 8-24 | | 5.4.3 Design Examples | | | 5.5 Counters | 8-29 | | PLE™ Devices | 9-1 | |---------------------------------------------------------------------------------------------|----------------| | Contents for Section 9 | 9-2 | | PLE to PROM Cross Reference Guide | | | Selection Guide | | | PLE means Programmable Logic Element | 9-5 | | Registered PLE | 9-5 | | PLEASM <sup>TM</sup> | | | Logic Symbols , | | | Specifications | 9-10 | | PLE Family Block Diagrams | 9-16 | | PLE Programmer Reference Chart | 9-20 | | 다른 20일 전에 보고 있는 것이 되었다. 그 사용통을 가능하다면 보고 있습니다.<br>10일 전에 보고 있는 1일 전에 보고 있는 것이 되었다. | | | PLE Circuit Applications | 0-1 | | Table of Contents for Section 10 | 10-2 | | Random Logic Replacement | 10-3 | | Basic Gates | 10-4 | | Memory Address Decoder | 10-6 | | 6-Bit True/Complement and Clear/Set Logic Functions | 10-10 | | Expandable 3-to-8 Demultiplexer | | | Dual 2:1 Multiplexer | | | Court III manapiones man country control | 10-15 | | | 10-17 | | | 10-20 | | | 10-22 | | . In dia, course por contents. | 10-23 | | | 10-24 | | | 10-26<br>10-27 | | 6-Bit Magnitude Comparator 4-Bit Magnitude Comparator with Polarity Control | 10-27 | | 8-Bit Barrel Shifter | 10-20 | | 4-Bit Right Shifter with Programmable Output Polarity | 10-30 | | 8-Bit Two's Complement Conversion | 10-36 | | A Portion of Timing Generator for PAL Array Programming | 10-38 | | Timing Generator for PAL Security Fuse Programming | 10-41 | | 그 물을 위해 하는 것은 그 사람이 되었는 그를 다 하고 사람들이 가게 하는 사람들이 되었다. | 10-44 | | Fast Arithmetic Look-up | 10-44 | | 4-Bit Multiplier Look-up Table ARC Tangent Look-up Table | 10-45 | | Hypotenuse of a Right Triangle Look-up Table | 10-48 | | Perimeter of a Circle Look-up Table | 10-51 | | Period of Oscillation for a Mathematical Pendulum Look-up Table | 10-54 | | Arithmetic Logic Unit | 10-57 | | Wallace Tree Compression | 10-58 | | Seven 1-Bit Integer Row Partial Products Adder | 10-60 | | | 10-61 | | Five 2-Bit Integer Row Partial Products Adder Four 3-Bit Integer Row Partial Products Adder | 10-62 | | | 10-63 | | Residue Arithmetic Using PLE Devices | 10-64 | | Distributed Arithmetic Using PLE Devices | 10-70 | | Registered PLE Devices in Pipelined Arithmetic | 10-72 | | Registered PLE Devices in Pipelined Arithmetic | | | 는 사람들이 있는 것으로 하고 있는 것을 하는 것을 하는 것으로 되었다. 그는 사람들이 모르는 것으로 가장 보고 있는 것으로 되었다. 전략으로 되었다.<br> | | | 보는 보통하는 것이 되었다. 그는 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 | | | 요. 그렇게 되어 보고 있는 것이 되었다. 그 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 | | | 공연 보는 눈에 어떻게 가장 하지만 하지만 하는 것 같아. 한 학생들은 그는 한 경기를 가지 않는 것을 하셨다. 그를 | | | Article Reprints | 11-1 | |------------------------------------------------------------------|-------| | Table of Contents for Section 11 | 11-2 | | Testing Your PAL Devices | 11-3 | | PAL20RA10 Design for Testability | 11-8 | | PAL Design Function and Test Vectors | 11-10 | | Metastability | 11-13 | | High-Speed Bipolar PROMs Find New Applications as | | | Programmable Logic Elements | 11-17 | | ABEL <sup>TM</sup> a Complete Design Tool for Programmable Logic | 11-25 | | CUPL <sup>TM</sup> the Universal Compiler for Programmable Logic | 11-29 | | General Information | 12-1 | | Package Drawings | | | Representatives and Distributors | | #### The PAL® Device Concept Monolithic Memories' family of PAL devices gives designers a powerful tool with unique capabilities for use in new and existing logic designs. The PAL device saves time and money by solving many of the system partitioning and interface problems brought about by increases in semiconductor device technology. Rapid advances in large scale integration technology have led to larger and larger standard logic functions; single I.C.s now perform functions that formerly required complete circuit cards. While LSI offers many advantages, advances have been made at the expense of device flexibility. Most LSI devices still require large numbers of SSI/MSI devices for interfacing with user systems. Designers are still forced to turn to random logic for many applications. The designer is confronted with another problem when a product is designed. Often the function is well defined and could derive significant benefits from fabrication as an integrated circuit. However, the design cycle for a custom circuit is long and the costs can be very high. This makes the risk significant enough to deter most users. The technology to support maximum flexibility combined with fast turnaround on custom logic has simply not been available. Monolithic Memories offers the programmable solution. The PAL device family offers a fresh approach to using fuse programmable logic. PAL circuits are a conceptually unified group of devices which combine programmable flexibility with high speed and an extensive selection of interface options. PAL devices can lower inventory, cut design cycles and provide high complexity with maximum flexibility. These features, combined with lower package count and high reliability, truly make the PAL device a circuit designer's best friend. ## The PAL Device — Teaching Old PROMs New Tricks Monolithic Memories developed the modern PROM and introduced many of the architectures and techniques now regarded as industry standards. As the world's largest PROM manufacturer, Monolithic Memories has the proven technology and high volume production capability required to manufacture and support the PAL device. The PAL device is an extension of the fusible link technology pioneered by Monolithic Memories for use in bipolar PROMs. The fusible link PROM first gave the digital systems designer the power to "write on silicon". In a few seconds he was able to transform a blank PROM from a general purpose device into one containing a custom algorithm, microprogram, or Boolean transfer function. This opened up new horizons for the use of PROMs in computer control stores, character generators, data storage tables and many other applications. The wide acceptance of this technology is clearly demonstrated by today's multi-million dollar PROM market. The key to the PROM's success is that it allows the designer to customize the chip quickly and easily to fit his unique requirements. The PAL device extends this programmable flexibility by utilizing proven fusible link technology to implement logic functions. By using PAL circuits the designer can quickly and effectively implement custom logic varying in complexity from random gates to complex arithmetic functions. #### ANDs and ORs The PAL device implements the familiar sum-of-products logic by using a programmable AND array whose output terms feed a fixed OR array. Since the sum-of-products form can express any Boolean transfer function, the PAL circuit uses are only limited by the number of terms available in the AND — OR arrays. PAL devices come in different sizes to allow for effective logic optimization. Figure 1 shows the basic PAL device structure for a two-input, one-output logic segment. The general logic equation for this segment is: Output = $$(I_1 + \overline{f_1})(\overline{I_1} + \overline{f_2})(I_2 + \overline{f_3})(\overline{I_2} + \overline{f_4}) + (I_1 + \overline{f_5})$$ $(\overline{I_1} + \overline{f_6})(I_2 + \overline{f_7})(\overline{I_2} + \overline{f_8})$ where the "f" terms represent the state of the fusible links in the PAL device AND array. An unblown link represents a logic 1. Thus: fuse blown, f = 0fuse intact, f = 1 An unprogrammed PAL device has all fuses intact. Figure 1 #### **PAL Device Notation** Logic equations, while convenient for small functions, rapidly become cumbersome in large systems. To reduce possible confusion, complex logic networks are generally defined by logic diagrams and truth tables. Figure 2 shows the logic convention adopted to keep PAL device logic easy to understand and use; in the figure, an "x" represents an intact fuse used to perform the logic AND function. (Note: the input terms on the common line with the x's are not connected together.) The logic symbology shown in Figure 2 has been informally adopted by integrated circuit manufacturers because it clearly establishes a one-to-one correspondence between the chip layout and the logic diagram. It also allows the logic diagram and truth table to be combined into a compact and easy to read form, thereby serving as a convenient shorthand for PAL circuits. The two-input, one-output example from Figure 1, redrawn using the new logic convention, is shown in Figure 3. Figure 2 Figure 3 As a simple PAL device example, consider the implementation of the transfer function: Output = $$|_{1}\overline{|_{2}} + \overline{|_{1}}|_{2}$$ The normal combinatorial logic diagram for this function is shown in Figure 4, with the PAL device logic equivalent shown in Figure 5. Figure 4 Figure 5 Using this logic convention it is now possible to compare the PAL device structure to the structure of the more familiar PROM (Programmable Read-Only Memory) and PLA (Programmable Logic Array). The basic logic structure of a PROM consists of a fixed AND array whose outputs feed a programable OR array (Figure 6). PROMs are low-cost, easy to program, and available in a variety of sizes and organizations. They are most commonly used to store computer programs and data. In these applications the fixed input is a computer memory address; the output is the content of that memory location. Figure 6 The basic logic structure of the PLA consists of a programmable AND array whose outputs feed a programmable OR array (Figure 7). Since the designer has complete control over all inputs and outputs, the PLA provides the ultimate flexibility for implementing logic functions. They are used in a wide variety of applications. However, this generality can make PLAs expensive, quite formidable to understand, and costly to program. The basic logic structure of the PAL (Programmable Array Logic) device, as mentioned earlier, consists of a programmable AND array whose outputs feed a fixed OR array (Figure 8). The PAL device combines much of the flexibility of the PLA with the low cost and easy programmability of the PROM. Table 1 summarizes the characteristics of the PROM, PLA, and PAL device logic families. PLA 4 In·4 Out·16 Products PAL Device 4 In-4 Out-16 Products Figure 7 Figure 8 | | AND | OR | OUTPUT OPTIONS | |------------|-------|-------|---------------------------------------------| | PROM | Fixed | Prog | TS, OC | | PLA | Prog | Prog | TS, OC, Prog. Polarity | | PAL Device | Prog | Fixed | TS, Registered Feedback, I/O Prog. Polarity | Table 1. #### **PAL Devices For Every Task** The members of the PAL device family and their characteristics are summarized in the PAL device menu. They are designed to cover the spectrum of logic functions at reduced cost and lower package count. This allows the designer to select the PAL device that best fits his application. PAL device units come in the following basic configurations: PAL device logic arrays are available in sizes from 6 x 16 (6 input terms, 16 output terms) to $64 \times 32$ , with both active high and active low output configurations available (ref. PAL device menu). This wide variety of input/output formats allows the PAL device to replace many different sized blocks of logic with single packages. #### Monolithic Memories PAL® Device Menu | | | | | DESCRIPTION | MAX | MUM | | |---------------------------------------|--------------------------|-----------------------|----------|---------------|-------------------|------------------------------------------|--------| | FAMILY | PART NUMBER PACKAGE | | OUTPL | JTS | t <sub>PD</sub> * | Icc | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | INPUTS | COMBINATORIAL | REGISTERED | ns | mĂ | | | PAL10H8 | | 10 | 8 | | 35 | | | | PAL12H6 | | 12 | 6 | 1 | 35 | | | | PAL14H4 | | 14 | 4 | | 35 | | | Cmall 20 | PAL16H2 | OOM I NII | 16 | 2 | | 35 | | | Small 20<br>Combinatorial | PAL16C1 | 20N, J, NL,<br>F, L | 16 | 2 | | 40 | 90 | | Combinatorial | PAL10L8 | [· L | 10 | 8 | 1 | 35 | | | | PAL12L6 | | 12 | -6 | | 35 | | | | PAL14L4 | | 14 | 4 | - | 35 | | | | PAL16L2 | | 16 | 2 | = 11 | 35 | | | | PAL10H8-2 | | 10 | 8 | - | | | | | PAL12H6-2 | | 12 | 6 | - | | | | | PAL14H4-2 | | 14 | 4 | - | | | | Small 20-2 | PAL16H2-2 | 20N, J, NL, | 16 | 2 | - | | | | Combinatorial | PAL16C1-2 | F, L | 16 | 2 | - 1 | . 60 | 45 | | | PAL10L8-2 | | 10 | 8 | | | | | | PAL12L6-2 | | 12 | 6 | | | | | | PAL14L4-2<br>PAL16L2-2 | | 14<br>16 | 4<br>2 | | | | | | PAL16L8 | | 16 | | | | | | Medium 20 | PAL16R8 | | 16 | 8 | 8 | | | | Standard | PAL16R6 | 20N, J, NL | 16 | 2 | 6 | 35 | 180 | | | PAL16R4 | | 16 | 4 | 4 | | | | | PAL16L8A | | 16 | 8 | | | 100 | | Medium 20A | PAL16R8A | 20N, J, NL, | 16 | | 8 | O.E | 100 | | Standard | PAL16R6A | W, L | 16 | 2 | 6 | 25 | 180 | | | PAL16R4A | | 16 | 4 | 4 | 91. A. S. C. | | | | PAL16L8A-2 | | 16 | 8 | | | | | Medium 20A-2 | PAL16R8A-2 | 20N, J, NL, | 16 | | 8 | 35 | 90 | | Standard | PAL16R6A-2<br>PAL16R4A-2 | F, L | 16<br>16 | 2 4 | 6 4 | | | | | PAL16L8A-4 | | -16 | 8 | | | | | Medium 20A-4 | PAL16R8A-4 | 20N, J, NL, | 16 | | 8 | | | | Standard | PAL16R6A-4 | F, L | 16 | 2 | 6 | 55 | 50 | | | PAL16R4A-4 | | 16 | 4 | 4 | | | | | PAL16L8B | | 16 | 8 | | | | | Medium 20B | PAL16R8B | 20N, J, NL, | 16 | | 8 | 15 | 180 | | Standard | PAL16R6B | W, L | 16 | 2 | 6 | 13 | 180 | | | PAL16R4B | | 16 | 4 | 4 | | | | Madium COD C | PAL16L8B-2 | OOM I AU | 16 | 8 | | | | | Medium 20B-2 | PAL16R8B-2 | 20N, J, NL, | | | 8 | 25 | 90 | | Standard | PAL16R6B-2<br>PAL16R4B-2 | W, L | 16<br>16 | 2<br>4 | 6 4 | | 35 4 | | | + | | | | | n en | | | Medium 20B-4 | PAL16L8B-4<br>PAL16R8B-4 | 20N, J, NL, | 16<br>16 | 8 | -<br>8 | | | | Standard | PAL16R6B-4 | 2014, 3, 14L,<br>W, L | 16 | 2 | 6 | 35 | 55 | | O.u. Idai d | PAL16R4B-4 | | 16 | 4 | 4 | roja je izvoje.<br>Pojaje izvoje | 5.00 | | | PAL16L8D | | 16 | 8 | | | | | Medium 20D | PAL16R8D | 001 1 1 | 16 | | 8 | | | | Standard | PAL16R6D | 20N, J, NL | 16 | 2 | 6 | 10 | 180 | | | PAL16R4D | | 16 | 4 | 4 | | May 18 | #### Monolithic Memories PAL® Device Menu | | | | | DESCRIPTION | MAXIMUM | | | |-----------------------------------------|-------------------------------------------------|---------------------|----------------------|------------------|------------------|-------------------|-----------------| | FAMILY | PART NUMBER | PACKAGE | | OUTPUTS | | t <sub>PD</sub> * | I <sub>cc</sub> | | | | | INPUTS | COMBINATORIAL | REGISTERED | ns | mĂ | | Medium 20AP<br>Programmable<br>Polarity | PAL16P8A<br>PAL16RP8A<br>PAL16RP6A<br>PAL16RP4A | 20N, J, NL | 16<br>16<br>16<br>16 | 8<br>-<br>2<br>4 | -<br>8<br>6<br>4 | 25/30** | 180 | | Large 20<br>Arithmetic | PAL16X4<br>PAL16A4 | 20N, J, NL,<br>F, L | 16<br>16 | 4<br>4 | 4<br>4 | 40 | 225<br>240 | | Large 20RA<br>Asynchronous | PAL16RA8 | 20N, J, NL | 16 | - 20 | 8 | 30/35** | 170 | $<sup>^{\</sup>bullet}$ Minimum commercial $t_{SU}$ for devices with all registered outputs. $^{\star\star}$ Polarity fuse programmed (active High). N = Plastic DIP NS = Plastic SKINNYDIP J = Ceramic DIP JS = Ceramic SKINNYDIP NL = Plastic Leaded Chip Carrier (PLCC) P = Pin Grid Array L = Leadless Chip Carrier (LCC) W = Cerpack F = Ceramic Solder Seal Flat Pack #### Monolithic Memories PAL® Device Menu #### PAL Circuit Series 24 | * | | | DESCRIPTION | | | MAXI | MUM | |---------------------------------------|-----------------------------------------------------------------|---------------------------|----------------------------------|-----------------------------|-------------------|-------------------------------------|--------------------------| | FAMILY | PART NUMBER | PACKAGE | 1346 | OUTPUTS | | t <sub>PD</sub> * | I <sub>CC</sub> | | | | | INPUTS | COMBINATORIAL | REGISTERED | ns | mĂ | | Small 24<br>Combinatorial | PAL12L10<br>PAL14L8<br>PAL16L6<br>PAL18L4<br>PAL20L2<br>PAL20C1 | 24NS, JS, W,<br>28NL, 28L | 10<br>14<br>16<br>18<br>20<br>20 | 10<br>8<br>6<br>4<br>2<br>2 | | 40 | 100 | | Small 24A<br>Decoder | PAL6L16A<br>PAL8L14A | 24NS, JS,<br>28NL | 6<br>8 | 16<br>14 | | 25 | 90 | | Medium 24A<br>Standard | PAL20L8A<br>PAL20R8A<br>PAL20R6A<br>PAL20R4A | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20 | 8<br>-<br>2<br>4 | -<br>8<br>6<br>4 | 25 | 210 | | Medium 24A-2<br>Standard | PAL20L8A-2<br>PAL20R8A-2<br>PAL20R6A-2<br>PAL20R4A-2 | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20<br>20 | 8<br>-<br>2<br>4 | -<br>8<br>6<br>4 | 35 | 105 | | Medium 24B<br>Standard | PAL20L8B<br>PAL20R8B<br>PAL20R6B<br>PAL20R4B | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20 | 8<br>-<br>2<br>4 | -<br>8<br>6<br>4 | 15 | 210 | | Medium 24X<br>Exclusive OR | PAL20L10<br>PAL20X10<br>PAL20X8<br>PAL20X4 | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20 | 10<br>-<br>2<br>4 | -<br>10<br>8<br>4 | 50 | 165<br>180<br>180<br>180 | | Medium 24XA<br>Exclusive OR | PAL20L10A<br>PAL20X10A<br>PAL20X8A<br>PAL20X4A | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20<br>20 | 10<br>-<br>2<br>6 | -<br>10<br>8<br>4 | 30 | 165<br>180<br>180<br>180 | | Large 24RS<br>Shared Product<br>Terms | PAL20S10<br>PAL20RS10<br>PAL20RS8<br>PAL20RS4 | 24NS, JS, W,<br>28NL, 28L | 20<br>20<br>20<br>20 | 10<br>-<br>2<br>6 | -<br>10<br>8<br>4 | 35/40**<br>35<br>35/40**<br>35/40** | 240<br>240<br>240<br>240 | | Large 24RA<br>Asynchronous | PAL20RA10 | 24NS, JS, W,<br>28NL, 28L | 20 | | 10 | 30/35** | 200 | | Large 24VX<br>Varied XOR | PAL32VX10<br>PAL32VX10A | 24NS, JS,<br>28NL | 32 | | 10 | 30<br>25 | 180 | | ECL | PAL10H20P8 | 24NS, JS,<br>28NL | 20 | 8 | | 6 | 210 | ### PAL Circuit Series MegaPAL<sup>TM</sup> | FAMILY | | | DESCRIPTION | | DESCRIPTION MAXI | IMUM | |--------------------------|-----------------------|-------------------------------|-------------|--------------------|-------------------------|-----------------------| | | PART NUMBER | PACKAGE | INPUTS | REGISTERED OUTPUTS | t <sub>PD</sub> *<br>ns | I <sub>CC</sub><br>mA | | 1500 Gates<br>5000 Gates | PAL 32R16<br>PAL64R32 | 40N, J, 44NL, 44L<br>88P, 84L | 32<br>64 | 16<br>32 | 40/45**<br>50/55** | 280<br>640 | #### **Basic PAL Device Features** PAL devices offer a number of different types of outputs. The basic types include the following: - Combinatorial - Programmable I/O - Registered Outputs with Feedback - XOR Outputs #### Combinatorial The simplest PAL devices have combinatorial outputs with no feedback. The basic structure shown in Figure 9 depicts four product terms summed at an active-low output. Figure 9 #### Programmable I/O A feature of the high-end members of the PAL device family is programmable input/output. This allows the product terms to directly control the outputs of the PAL device (Figure 10). One product term is used to enable the three-state buffer, which in turn gates the summation term to the output pin. The output is also fed back into the PAL device array as an input. Thus the PAL device drives the I/O pin when the three-state gate is enabled; the I/O pin is an input to the PAL device array when the three-state gate is disabled. This feature can be used to allocate available pins for I/O functions or to provide bidirectional output pins for operations such as shifting and rotating serial data. Figure 10 #### Registered Outputs with Feedback Another feature of the high-end members of the PAL device family is registered data outputs with registered feedback. Each product term is summed into a D-type output flip-flop on the rising edge of the system clock (Figure 11). The Q output of the flip-flop can then be gated to the output pin by enabling the active low three-state buffer. In addition to being available for transmission, the Q output is fed back into the PAL device array as an input term. This feedback allows the PAL device to "remember" the previous state, and it can alter its function based upon that state. This allows the designer to configure the PAL device as a state sequencer which can be programmed to execute such elementary functions as count up, count down, skip, shift, and branch. These functions can be executed by the registered PAL device at rates of up to 55.5MHz. #### **XOR Outputs** These PAL devices feature an exclusive-OR (XOR) function. The sum of products is segmented into two sums which are then exclusive ORed at the input of the D-type flip-flop (Figure 12). All of the features of the Registered PAL devices are included in the XOR PAL unit. The XOR function provides an easy implementation of the HOLD operation used in counters and other state sequencers. #### **PAL Device Programming** PAL devices can be programmed in most standard PROM programmers with the addition of a PAL device personality card. For details on programming equipment, see the PAL Device Programmer Reference Guide in this handbook. #### PALASM (PAL Device Assembler) PALASM is the software used to define, simulate, build, and test PAL device units. PALASM accepts the PAL device Design Specification as an input file. It verifies the design against an optional function table and generates the fuse plot which is used to program the PAL devices. PALASM is available upon request for many computers. #### **HAL (Hard Array Logic) Device** The HAL device family is the mask programmed version of a PAL device. The HAL device is to a PAL device just as a ROM is to a PROM. A standard wafer is fabricated as far as the metal mask. Then a custom metal mask is used to fabricate aluminum links for a HAL device instead of the programmable TiW fuses used in a PAL device. #### PAL Device Technology PAL circuits are manufactured using the proven TTL Schottky bipolar TiW fuse process to make fusible-link PROMs. An NPN emitter follower array forms the programmable AND array. PNP inputs provide high impedance inputs (0.25mA max) to the array. All outputs are standard TTL drivers with internal active pull-up transistors. #### **PAL Device Data Security** The circuitry used for programming and logic verification can be used at any time to determine the logic pattern stored in the PAL device array. For security, the PAL device has a "last fuse" which can be blown to disable the verification logic. This provides a significant deterrent to potential copiers, and it can be used to protect proprietary designs. #### **PAL Device Part Numbers** The PAL device part number is unique in that the part number code also defines the part's logic operation. The PAL device numbering system is shown in Figure 13. For example, a PAL 14L4CN would be a 14-input term, 4-output term, active-low PAL device with a commercial temperature range packaged in a 20-pin plastic DIP. Figure 13 #### **PAL Device Logic Symbols** The logic symbols for each of the individual PAL devices gives a concise functional description of the PAL device logic function. This symbol makes a convenient reference when selecting the PAL device that best fits a specific application. Figure 14 shows the logic symbol for a PAL10H8 array. Figure 14 #### A PAL Device Example As an example of how the PAL device enables the designer to reduce costs and simplify logic design, consider the design of a simple, high-volume consumer product: an electronic dice game. This type of product will be produced in extremely high volume, so it is essential that every possible production cost be minimized. The electronic dice game is simply constructed using a free running oscillator whose output is used to drive two asynchronous modulo six counters. When the user "rolls" the dice (presses a button), the current state of the counters is decoded and latched into a display resembling the pattern seen on an ordinary pair of dice. A conventional logic diagram for the dice game is shown in Figure 15. It is implemented using standard TTL, SSI and MSI parts, with a total I.C. count of eight: six quad gate packages and two quad D-latches. Looks like a nice clean logic design, right? Wrong!! Figure 15 A brief examination of Figure 15 reveals two basic facts: first, the circuit contains mostly simple, combinatorial logic, and second, it uses a clocked state transition sequence. Remembering that the PAL device family contains ample provision for these features, the PAL device catalog is consulted. The PAL16R8 has all the required functions, and the entire logic content of the circuit can be programmed into a single PAL device shown in Figure 16. In this example, the PAL device effected an eight-to-one package count reduction and a significant cost savings. This is typical of the power and cost-effective performance that the PAL device family brings to logic design. Figure 16 #### **Advantages of Using PAL Devices** The PAL device has a unique place in the world of logic design. Not only does it offer many advantages over conventional logic, it also provides many features not found anywhere else. Among the benefits of the PAL device family: - Programmable replacement for conventional TTL logic. - Reduces IC inventories substantially and simplifies their control. - Reduces chip count by at least 4 to 1. - Expedites and simplifies prototyping and board layout. - Saves space with 20-pin and 24-pin SKINNYDIP packages, and surface-mount PLCC packages. - High speed: 10ns maximum propagation delay, on D series. - Programmed on standard PROM programmers. - Programmable three-state outputs. - Special feature eliminates possibility of copying by competitors. All of these features combine together to lower product development costs and increase product cost effectiveness. The bottom line is that PAL devices save money. #### **Direct Logic Replacement** In both new and existing designs, the PAL device can be used to replace various logic functions. This allows the designer to optimize a circuit in many ways never before possible. The PAL device is particularly effective when used to provide interfaces required by many LSI functions. The combination of PAL device flexibility and LSI function density makes a powerful team. #### **Design Flexibility** The PAL device offers the systems logic designer a whole new world of options. Until now, the decision on logic system implementation was usually between SSI/MSI logic functions on one hand and microprocessors on the other. In many cases the function required is too awkward to implement the first way and too simple to justify the second. Now the PAL device offers the designer high functional density, high speed, and low cost. Even better, PAL devices come in a variety of sizes and functions, thereby further increasing the designer's options. #### **Space Efficiency** By allowing designers to replace many simple logic functions with single packages, the PAL device allows more compact P.C. board layouts. The PAL device space-saving 20-pin and 24-pin SKINNYDIP packages help to reduce board area further while simplifying board layout and fabrication. This means that many multi-card systems can now be reduced to one or two cards, and that can make the difference between a profitable success or an expensive disaster. #### **Smaller Inventory** The PAL device family can be used to replace up to 90% of the conventional TTL family. This considerably lowers both shelving and inventory cataloging requirements. In addition, small custom modifications to the standard functions are easy for PAL device users, but not so easy for standard TTL users. CD009 #### **High Speed** The PAL device family runs faster than or equal to the best of bipolar logic circuits. This makes the PAL device the ideal choice for most logical operations or control sequences which require a medium complexity and high speed. Also, in many microcomputer systems, the PAL device can be used to handle high-speed data interfaces that are not feasible for the microprocessor alone. This can be used to significantly extend the capabilities of the low-cost, low-speed NMOS microprocessors into areas formerly requiring high-cost bipolar microprocessors. #### **Easy Programming** The members of the PAL device family can be quickly and easily programmed using standard PROM programmers. This allows designers to use PAL devices with a minimum investment in special equipment. Many types of programmable logic, such as the PLA, require an expensive, dedicated programmer. #### Secure Data The PAL device verification logic can be completely disabled by blowing out a special "last link". This prevents the unauthorized copying of valuable data, and makes the PAL device perfect for use in any application where data integrity must be carefully guarded. #### Summary The PAL device family of logic devices offers logic designers new options in the implementation of sequential and combinatorial logic designs. The family is fast, compact, flexible, and easy to use in both new and existing designs. It promises to reduce costs in most areas of design and production with a corresponding increase in product profitability. ## A Great Performer! **Representatives and Distributors** | PAL/HAL Device Specifications | 2-1 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | Table of Contents for Section 2 | 2-2 | | PAL/HAL Devices | 2-3 | | Small 20 Series: 10H8, 12H6, 14H4, 16H2, 16C1, 10L8, 12L6, 14L4, 16L2 20 (standard) 20-2 (half power) | 2-8 | | Medium 20 Series: 16L8, 16R8, 16R6, 16R4 20 (standard) 20A (high speed) 20A-2 (high speed and half power) 20A-4 (high speed and quarter power) 20B (very high speed) 20B-2 (very high speed and half power) 20B-4 (very high speed and quarter power) 20B-4 (very high speed) | 2-21<br>2-22<br>2-24<br>2-25<br>2-26<br>2-27<br>2-28 | | Medium 20PA Series: 16P8A, 16RP8A, 16RP6A, 16RP4A | | | Large 20 Series: 16X4, 16A4 | | | Large 20RA: 16RA8 | 2-51 | | Small 24 Series: 12L10, 14L8, 16L6, 18L4, 20L2, 20C1 | 2-55 | | Small 24A Decoder Series: 6L16A, 8L14A | 2-65 | | Medium 24 Series: 20L8, 20R8, 20R6, 20R4 24A (high speed) 24A-2 (high speed and half power) 24B (very high speed) | 2-73<br>2-75 | | Medium 24X Series: 20L10, 20X10, 20X8, 20X4 24X (standard) 24XA (high speed) | 2-83 | | Large 24RS Series: 20S10, 20RS10, 20RS8, 20RS4 | 2-90 | | Large 24RA: 20RA10 | 2-98 | | PAL32VX10/A | 2-103 | | PMS14R21/A | | | PAL10H20P8 | 2-115 | | MegaPAL devices: 32R16, 64R32 | | | f <sub>MAX</sub> Parameters | 2-126 | | Waveforms | | | Test Load | 2-128 | # PAL® (Programmable Array Logic) Devices HAL® (Hard Array Logic) Devices #### Features/Benefits - Reduces SSI/MSI chip count greater than 4 to 1 - Saves space with SKINNYDIP® and PLCC packages - Reduces IC inventories substantially - Expedites and simplifies prototyping and board layout - PALASM® 2 silicon compiler provides easy design entry - Security fuse reduces possibility of copying by competitors #### Description The PAL device family utilizes an advanced Schottky TTL process and the Bipolar PROM fusible link technology to provide user-programmable logic for replacing conventional SSI/MSI gates and flip-flops at reduced chip count. The HAL device family utilizes standard Low-Power Schottky TTL process and automated mask pattern generation directly from logic equations to provide a semi-custom gate array for replacing conventional SSI/MSI gates and flip-flops at reduced chip count. The PAL device lets the systems engineer "design his own chip" by blowing fusible links to configure AND and OR gates to perform his desired logic function. Complex interconnections which previously required time-consuming layout are thus "lifted" from PC board etch and placed on silicon where they can be easily modified during prototype check-out or production. The PAL/HAL device transfer function is the familiar sum of products. Like the PROM, the PAL device has a single array of fusible links. Unlike the PROM, the PAL device is a programmable AND array driving a fixed OR array (the PROM is a fixed AND array driving a programmable OR array). In addition the PAL/HAL device provides these options: - Variable input/output pin ratio - Programmable three-state outputs - Registers with feedback - Arithmetic capability - Exclusive-OR gates Unused input pins should be tied directly to V<sub>CC</sub> or GND. Product terms with all fuses blown assume the logical high state, and product terms connected to both true and complement of any single input assume the logical low state. Registers consist of D-type flip-flops which are loaded on the low-to-high transition of the clock. PAL/HAL device Logic Diagrams are shown with all fuses blown, enabling the designer to use the diagrams as coding sheets. PALASM 2 software automatically generates a similar diagram, called the fuse plot. The entire PAL device family is programmed using inexpensive conventional PROM programmers with appropriate personality and socket adapter cards. Once the PAL device is programmed and verified, two additional fuses may be blown to defeat verification. This feature gives the user a proprietary circuit which is very difficult to copy. To design a HAL, the user first programs and debugs a PAL device using PALASM 2 software and the "PAL DEVICE DESIGN SPECIFICATION" standard format. This specification is submitted to Monolithic Memories where it is computer-processed and assigned a bit pattern number, e.g., H01234. Monolithic Memories will provide a PAL device sample for customer qualification. The user then submits a purchase order for a HAL of the specified bit pattern number, e.g., HAL18L4 H01234. For details on ordering HAL devices, please refer to the brochure, *ProPAL*, *HAL*, and *ZHAL Devices*: The Logical Solutions for Volume Programmable Logic, available from Monolithic Memories. #### Register Bypass (MegaPAL Devices) Outputs within a bank must either be all registered or all combinatorial. Whether or not a bank of registers is bypassed depends on how the outputs are defined in the equations. A colon followed by an equal sign [: = ] specifies a registered output with feedback which is updated after the low-to-high transition of the clock. An equal sign [ = ] defines a combinatorial output which bypasses the register. Registers are bypassed in banks of eight. Bypassing a bank of registers eliminates the feedback lines for those outputs. #### **Output Polarity** Output polarity is defined by comparison of the pin list and the equations. If the logic sense of a specific output in the pin list is different from the logic sense of that output as defined by its equation, the output is inverted or active low polarity. If the logic sense of a specific output in the pin list is the same as the logic sense of that output as defined by its equation, the output is active high polarity. Note that the P, RA, RS, and MegaPAL devices have programmable output polarity. ## Product Term Sharing (RS, MegaPAL Devices) The basic configuration is sixteen product terms shared between two output cells. For a typical output pair, each product term can be used by either output; but, since product term sharing is exclusive, a product term can be used by only one output, not both. If equations call for an output pair to use the same product term, two product terms are generated, one for each output. This should be taken into account when writing equations. PAL device assemblers configure product terms automatically. #### **Product Term Editing** A unique feature of product term sharing is the ability to edit the design after the device has been programmed. Without this feature, a new PAL device had to be programmed if the user needed to change his design. Product term editing allows the user to delete an unwanted product term and reprogram a previously unused product term to the desired fuse pattern. This feature is made possible by the product term sharing architecture. Since each product term can be routed to either output in a given pair by selecting one of two steering fuses, it is possible to blow both of the steering fuses thereby completely disabling that product term. Once disabled, that product term is powered down, saving typically 0.25mA. The desired change may now be programmed into one of the previously unused product terms corresponding to that output pair. Additional edits can be made as long as there are unused product terms for the output in question. #### PRESET Feature (PAL64R32 only) Register banks of eight may be PRESET to all highs on the outputs by setting the PRESET pin (PS) to a Low level. Note from the Logic Diagram that when the state of an output is High, the state of the register is Low due to the inverting tristate buffer. ## TTL-Level Preload Features (RA, MegaPAL Devices) Preload pins have been added to enable the testability of each state in state-machine design. Typically, for a modulo-n counter or a state machine there are many unreachable states for the registers. These states, and the logic which controls them are untestable without a way to "set-in" the desired starting state of the registers. In addition, long test sequences are sometimes needed to test a state machine simply to reach those starting states which are legal. Since complete logic verification is needed to ensure the proper exit from "illegal" or unused states, a way to enter these states must be provided. The ability to preload a given bank of registers is provided in this device. To use the preload feature, several steps must be followed. First, a high level on an assertive-low output enable pin disables the outputs for that bank of registers. Next, the data to be loaded is presented at the output pins. This data is then loaded into the register by placing a low level on the PRELOAD pin, PRELOAD is asynchronous with respect to the clock. ## Programmable Set and Reset (RA Family only) In each SMAC, two product lines are dedicated to asynchronous set and reset. If the set product line is high, the register output becomes a logic 1. If the reset product line is high, the register output becomes a logic 0. The operation of the programmable set and reset overrides the clock. Note that set and reset are in reference to the register, independent of polarity. ## Individually Programmable Register Bypass (RA Family only) If both the set and reset product lines are high, the sum-ofproducts bypasses the register and appears immediately at the output, thus making the output combinatorial. This allows each output to be configured in the registered or combinatorial mode. #### Programmable Clock (RA Family only) One of the product lines in each group is connected to the clock. This provides the user with the additional flexibility of a programmable clock, so each output can be clocked independently of all the others. #### Small 20 Series | | | | | STAN | IDARD | HALF POWER | | | |---------|--------|---------|----------|-------------------------|----------------------|-------------------------|-------------------------|--| | | INPUTS | OUTPUTS | POLARITY | t <sub>PD</sub><br>(ns) | I <sub>CC</sub> (mA) | t <sub>PD</sub><br>(ns) | I <sub>CC</sub><br>(mA) | | | PAL10H8 | 10 | 8 | HIGH | 35 | 90 | 65 | 40 | | | PAL12H6 | 12 | 6 | HIGH | 35 | 90 | 65 | 40 | | | PAL14H4 | 14 | 4 | HIGH | 35 | 90 | 65 | 40 | | | PAL16H2 | 16 | 2 | HIGH | 35 | 90 | 65 | 40 | | | PAL16C1 | 16 | 2 | вотн | 40 | 90 | 65 | 40 | | | PAL10L8 | 10 | 8 | LOW | 35 | 90 | 65 | 40 | | | PAL12L6 | 12 | 6 | LOW | 35 | 90 | 65 | 40 | | | PAL14L4 | 14 | 4 | LOW | 35 | 90 | 65 | 40 | | | PAL16L2 | 16 | 2 | LOW | 35 | 90 | 65 | 40 | | #### **Description** The Small 20 Series is made up of nine combinatorial 20-pin PAL devices. They implement simple combinatorial logic, with no feedback. Each has sixteen product terms total, divided among the outputs, with two to sixteen product terms per output. #### **Polarity** Both active high and active low versions are available for each architecture. The 16C1 offers both polarities of its single output. #### **Performance** Two performance options are available. The standard series has a propagation delay (tpd) of 35 nanoseconds (ns), except for the 16C1 at 40ns. Standard supply current is 90 milliamps (mA). The half-power version consumes only 40mA, with a speed of 65ns. #### **PLCC Pinouts** #### Small 20 Series 10H8, 12H6, 14H4, 16H2, 16C1, 10L8, 12L6, 14L4, 16L2 #### **Operating Conditions** | | | 18: | M | ILITAR | Y | СО | | | | |-----------------|--------------------------------|-----------|-----|--------|------|------|-----|------|------| | SYMBOL | PARAMETER | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | a Company | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V | | T <sub>A</sub> | Operating free-air temperature | *194 | -55 | | A.H. | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | 125 | | | | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TEST CONDITIONS | | | | TYP | MAX | UNIT | |-----------------------|------------------------------|--------------------------------------|-----|------------------------|-----|-------|-------|------| | ν <sub> L</sub> 1 | Low-level input voltage | | | | | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | l <sub>IL</sub> | Low-level input current | V <sub>CC</sub> = MAX | 14. | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> (333) | High-level input current | V <sub>CC</sub> = MAX | | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | 4 | Maximum input current | V <sub>CC</sub> = MAX | | V <sub>I</sub> = 5.5V | | | 1. | mA | | V 3 | | 37 - 84181 | MIL | I <sub>OL</sub> = 8mA | | 00 | 0.5 | v | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | СОМ | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | V V | | V | High-level output voltage | V/ * - MINI | MIL | I <sub>OH</sub> = -2mA | 0.4 | 0.0 | | v | | V <sub>OH</sub> | | $V_{CC} = MIN$ COM $I_{OH} = -3.2mA$ | | | 2.4 | 2.8 | | V | | los² | Output short-circuit current | V <sub>CC</sub> = 5V | | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | loc | Supply current | V <sub>CC</sub> = MAX | | | | 55 | 90 | mA | #### **Switching Characteristics** | SYMBOL | [연기: 12] 그렇게 했다. 그는 사람. | | TEST | MILITARY | | | COMMERCIAL | | | | |-----------------|-------------------------|--------------------|-------------------|----------|-----|-----|------------|-----|-----|------| | SYMBOL | PARAN | METER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | | Input or | Except 16C1 | $R_1 = 560\Omega$ | | 25 | 45 | | 25 | 35 | | | t <sub>PD</sub> | feedback to output 16C1 | $R_2 = 1.1k\Omega$ | | 25 | 45 | | 25 | 40 | ns | | These are absolute values with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. <sup>2.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Small 20-2 Series 10H8-2, 12H6-2, 14H4-2, 16H2-2, 16C1-2, 10L8-2, 12L6-2, 14L4-2, 16L2-2 #### **Operating Conditions** | 0,41001 | | MILITARY | | | co | | | | |-----------------|--------------------------------|----------|-----|-----|------|-----|------|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | > | | T <sub>A</sub> | Operating free-air temperature | -55 | | 125 | 0 | | 75 | °C | #### **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARAMETER | Т | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------|------------------------------|-----------------------|----------------------------|-----------------------------|-------|-------|-------------------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | կլ | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | II. | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | t e e egide<br>se e e egide | | 1 | mA | | | | N/ - NAINI | Mil I <sub>OL</sub> = 4mA | | 0.3 | ٥. | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 4mA | | 0.3 | 0.5 | V<br>12-71 | | V | High level output voltage | V = AAINI | Mil I <sub>OH</sub> = -1mA | 2.4 | 2.8 | 300 | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -1mA | 74 | 2.0 | | , :: <b>Y</b><br> | | los <sup>2</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | | | 30 | 45 | mA | #### Switching Characteristics Over Operating Conditions | | | | MILITARY | | | co | | | | |-----------------|-----------------------------|----------------------------------------|----------|-----|-----|-----|-----|-----|------| | SYMBOL | PARAMETER | TEST | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | $R_1 = 1.12k\Omega$ $R_2 = 2.2k\Omega$ | | 45 | 80 | | 45 | 60 | ns | <sup>.</sup> These are absolute values with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. <sup>2.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 20 Series 16L8, 16R8, 16R6, 16R4 #### Medium 20 Series | | | | ОUТ | PUTS | |---------|----------|----------|---------------|------------| | | DEDICATE | D INPUTS | COMBINATORIAL | REGISTERED | | PAL16L8 | 10 | | 8 (6 1/0) | 0 | | PAL16R8 | 8 | | 0 | 8 | | PAL16R6 | 8 | | 2 1/0 | 6 | | PAL16R4 | 8 | | 4 1/0 | 4 | ## Description The Medium 20 Series offers the four most popular PAL device architectures. It also provides the fastest PAL devices in the industry. The Medium 20 Series consists of four devices, each with sixteen array inputs and eight outputs. The devices have either 0, 4, 6, or 8 registered outputs, with the remaining being combinatorial. Each of the registered outputs feeds back into the array, for sequential designs. The combinatorial outputs also feed back into the array, except for two of the outputs on the 16L8. This feedback allows the output to also operate as an input if the output is disabled. #### **Enable** The combinatorial outputs are enabled by a product term. The registered outputs are enabled by a common enable pin. #### **Polarity** All outputs are active low. #### **Performance** Several speed/power versions are available: | I <sub>CC</sub><br>(mA) | |-------------------------| | | | 180 | | 180 | | 90 | | 50 | | 180 | | 90 | | 55 | | 180 | | | <sup>\*</sup> contact Monolithic Memories for datasheet The D Series offers the fastest TTL programmable logic devices in the industry, at 10ns tpd. ## Preload and Power-up Reset The BP Series offers register preload for device testability. The registers can be preloaded from the outputs by using supervoltages (see waveforms at end of section) in order to simplify functional testing. The PAL20BP Series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. #### **DIP Pinouts** CD00111M ## **Medium 20 Series** 16L8, 16R8, 16R6, 16R4 ## **Operating Conditions** | OVMDOL | | | co | MMERC | IAL <sup>1</sup> | | |-----------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|------------------|-----| | SYMBOL | PARA | MIN | TYP | MAX | UNIT | | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | - V | | | Width of clock | Low | 25 | 10 | | | | t <sub>w</sub> | Width of clock | High | 25 | 10 | | ns | | t <sub>su</sub> | Set up time from input or feedback to clock | 16R8, 16R6, 16R4 | 35 | 25 | | ns | | t <sub>h</sub> | Hold time | | 0 | -15 | | ns | | TA | Operating free-air temperature | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | The state of s | r dwe p | 1.4900 | | °C | ## **Electrical Characteristics** | SYMBOL | PARAMETER | Т | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|------------------------------|------------|------------------------------------------|-------|-------------| | V <sub>IL</sub> 2/ | Low-level input voltage | | | 1.00 | | 0.8 | * V | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | tana a jual najir | | 2 | 11.763 | | <b>'V</b> , | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | Sec. 31 24 | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | 4 | 25 | μΑ | | 4 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>j</sub> = 5.5V | | # 1 to t | . 1 | mΑ | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | 5.00 | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | 4.5.4 | ٧ | | I <sub>OZL</sub> <sup>3</sup> | Off-state output current | V - MAY | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>3</sup> | 7 On-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA∕ | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | 16R4, 16R6, 16R8, 16L8 | | 120 | 180 | mA | | OVMDO | | | СО | | | | | |------------------|-----------------------------|------------------|-------------------|-----|-----|------|-----| | SYMBOL | PARA | TEST CONDITIONS | MIN | TYP | MAX | UNIT | | | t <sub>PD</sub> | Input or feedback to output | 16R6, 16R4, 16L8 | | | 25 | 35 | ns | | t <sub>CLK</sub> | Clock to output or feedba | | | 15 | 25 | ns | | | t <sub>PZX</sub> | Pin 11 to output enable e | xcept 16L8 | | | 15 | 25 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable e | except 16L8 | $R_1 = 200\Omega$ | | 15 | 25 | ns | | t <sub>PZX</sub> | Input to output enable | 16R6, 16R4, 16L8 | $R_2 = 390\Omega$ | | 25 | 35 | ns | | t <sub>PXZ</sub> | Input to output disable | 16R6, 16R4, 16L8 | | | 25 | 35 | ns | | f <sub>MAX</sub> | Maximum frequency | 16R8, 16R6, 16R4 | | 16 | 25 | | MHz | - The PAL20 Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of $I_{\rm IL}$ and $I_{\rm OZL}$ (or $I_{\rm IH}$ and $I_{\rm OZH}$ ). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 20A Series 16L8A, 16R8A, 16R6A, 16R4A ## **Operating Conditions** | | | | | MILITAR | łΥ | co | MMERC | IAL | | |-----------------|---------------------------------------------|---------------------|-----|---------|--------|------|-------|------|------| | SYMBOL | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | . An 12- | tarint -2 -1il | Low | 20 | 10 | | 15 | 10 | | | | t <sub>w</sub> | Width of clock | High | 20 | 10 | 1 | 15 | 10 | | ns | | t <sub>su</sub> | Set up time from input or feedback to clock | 16R8A, 16R6A, 16R4A | 30 | 15 | 105.00 | 25 | 15 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air tempera | ature | -55 | | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | 125 | | | | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | Т | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------------------|-----|--------------|-------|------------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | G. W. | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | կ <u>լ</u> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 2 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | h | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V | | _ A21N1 | Mil I <sub>OL</sub> = 12mA | | 0.3 | 0.5 | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | , <b>,</b> | | N/ | Ulah laval autaut valtaas | V - NAINI | Mil I <sub>OH</sub> = -2mA | 2.4 | 2.8 | | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com $I_{OH} = -3.2 \text{mA}$ | 2.4 | 2.0 | | , × | | l <sub>OZL</sub> <sup>2</sup> | ALAN MARKATAN | V - 144V | V <sub>O</sub> = 0.4V | | to a will ye | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | l <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | | | 120 | 180 | mA | <sup>1.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. 2. I/O pin leakage is the worst case of $I_{\rm IL}$ and $I_{\rm OZL}$ (or $I_{\rm IH}$ and $I_{\rm OZH}$ ). <sup>3.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Medium 20A Series 16L8A, 16R8A, 16R6A, 16R4A | 01/11/01 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | TEST | N | MILITAR | Y | СО | 11807 | | | |------------------|---------------------------------------|------------------------|-------------------------------------|-----|---------|-----|------|-------|-----|------| | SYMBOL | PARAMETER | | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | 16R6A, 16R4A,<br>16L8A | | | 15 | 30 | | 15 | 25 | ns | | t <sub>CLK</sub> | Clock to output | or feedback | | | 10 | 20 | | 10 | 15 | ns | | t <sub>PZX</sub> | Pin 11 to output<br>16L8A | enable except | | | 10 | 25 | | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 11 to output<br>16L8A | disable except | $R_1 = 200\Omega$ $R_2 = 390\Omega$ | | 11 | 25 | | 11 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | 16R6A, 16R4A,<br>16L8A | | | 10 | 30 | | 10 | 25 | ns | | t <sub>PXZ</sub> | Input to output disable | 16R6A, 16R4A,<br>16L8A | | | 13 | 30 | | 13 | 25 | ns | | f <sub>MAX</sub> | Maximum frequency | 16R8A, 16R6A,<br>16R4A | | 20 | 40 | | 28.5 | 40 | | MHz | #### Medium 20A-2 Series 16L8A-2, 16R8A-2, 16R6A-2, 16R4A-2 ## **Operating Conditions** | | SYMBOL PARAMETER | | MILITARY | | | СО | IAL | UNIT | | |-----------------|---------------------------------------------|------------------------------|----------|-----|-----|------|-----|------|----| | SYMBOL | PARA | ANAMETER | | TYP | MAX | MIN | TYP | MAX | V | | V <sub>CC</sub> | CC Supply voltage | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | | | | 140-44411- | Low | 25 | 10 | | 25 | 10 | | | | Lw . | Width of clock | High | 25 | 10 | | 25 | 10 | | ns | | t <sub>su</sub> | Set up time from input or feedback to clock | 16R6A-2, 16R4A-2,<br>16R8A-2 | 50 | 25 | | 35 | 25 | | ns | | th | Hold time | | 0 | -15 | | 0 | -15 | | ns | | TA | Operating free-air temper | ature | -55 | | 125 | 0 | | 75 | °C | ## **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARAMETER | Т | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|------------------------------|-----|-------|-------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>1</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 2 | High-level input current | V <sub>CC</sub> = MAX | $V_{ } = 2.4V$ | | | 25 | μΑ | | 4 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V | Low lovel output voltage | V - MINI | Mil I <sub>OL</sub> = 12mA | | 0.3 | 0.5 | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | • | | V | High lavel output voltage | V - BAINI | Mil I <sub>OH</sub> = -2mA | 2.4 | 2.8 | | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -3.2mA | 2.4 | 2.0 | | ٧ | | l <sub>OZL</sub> <sup>2</sup> | 04 | V - MAY | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | $V_{CC} = MAX$ | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 60 | 90 | mA | | OVMOOL | PARAMETER | | TEST<br>CONDITIONS | ٨ | IILITAR | Y | co | MMERC | IAL. | LIMIT | |---------------------|-----------------------------|------------------------------------------------|--------------------|-----|---------|-----|-----|-------|------|-------| | SYMBOL | | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | 16L8A-2, 16R6A-2,<br>16R4A-2 | | | 25 | 50 | | 25 | 35 | ns | | t <sub>CLK</sub> | Clock to output | or feedback | | | 15 | 25 | | 15 | 25 | ns | | t <sub>PXZ/ZX</sub> | | Pin 11 to output disable/enable except 16L8A-2 | | | 15 | 25 | | 15 | 25 | ns | | t <sub>PZX</sub> | Input to output enable | 16L8A-2, 16R6A-2,<br>16R4A-2 | $R_2 = 390\Omega$ | | 25 | 45 | | 25 | 35 | ns | | t <sub>PXZ</sub> | Input to output disable | 16L8A-2, 16R6A-2,<br>16R4A-2 | | | 25 | 45 | | 25 | 35 | ns | | f <sub>MAX</sub> | Maximum frequency | 16R8A-2, 16R6A-2,<br>16R4A-2 | | 14 | 25 | | 16 | 25 | | MHz | <sup>1.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Medium 20A-4 Series 16L8A-4, 16R8A-4, 16R6A-4, 16R4A-4 ## **Operating Conditions** | | PARAMETER | | N | <b>IILITAR</b> | Υ . | СО | MMERC | IAL | | | |-----------------|---------------------------------------------|------------------------|--------|----------------|-----|----------|-------|-----|-------|----| | SYMBOL | | | MIN | ТҮР | MAX | MIN | TYP | MAX | UNIT | | | v <sub>cc</sub> | Supply voltage | | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V | | | Marial of alast | | Low | 40 | 20 | | 30 | 20 | 100 | | | w | Width of clock | | High | 40 | 20 | | 30 | 20 | | ns | | t <sub>su</sub> | Set up time from input or feedback to clock | 16R8A-4, 16<br>16R4A-4 | R6A-4, | 90 | 45 | 1 (A.S.) | 60 | 45 | | ns | | t <sub>h</sub> | Hold time | | | 0 | -15 | | 0 | -15 | 10.40 | ns | | T <sub>A</sub> | Operating free-air temperatur | е | | -55 | | 125 | 0 | 14 | 75 | °C | ## **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARAMETER | Till and the state of | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------|---------|-------|------| | ν <sub>IL</sub> 1 | Low-level input voltage | estration in 19 | | 7.0 | | 0.8 | ٧ | | V <sub>IH</sub> <sup>1</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> <sup>2</sup> | Low-level input current | V <sub>CC</sub> = MAX | $V_I = 0.4V$ | | -0.02 | -0.25 | mA | | l <sub>H</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | . 25 | μΑ | | l <sub>l</sub> erd for a | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | i Section | State 1 | 1. | mA | | <i>(</i> 44.0.18) | | N/ NAINI | Mil I <sub>OL</sub> = 4mA | 4 35 75 | | 0.5 | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | ٧ | | <b>,</b> 76, 67, | | NZ = NAINI | Mil I <sub>OH</sub> = -1mA | 0.4 | | | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -1mA | 2.4 | 2.8 | | ٧, | | I <sub>OZL</sub> <sup>2</sup> | <b>6.</b> | | V <sub>O</sub> = 0.4V | | | 100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | $V_{CC} = MAX$ | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | The sy | 30 | 50 | mA | | 0.74501 | PARAMETER | | TEST | MILITARY | | | СО | LIANT | | | |---------------------|------------------------------------|------------------------------|---------------------|----------|-----|-----|-------|-------|-----|------| | SYMBOL | PAR | AMEIER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | 16R6A-4, 16R4A-4,<br>16L8A-4 | | | 35 | ,75 | 100 L | 35 | 55 | ns | | t <sub>CLK</sub> | Clock to output | or feedback | | | 20 | 45 | | 20 | 35 | ns | | t <sub>PXZ/ZX</sub> | Pin 11 to output<br>- except 16L8A | | $R_1 = 800\Omega$ | | 15 | 40 | | 15 | 30 | ns | | t <sub>PZX</sub> | Input to output enable | 16R6A-4, 16R4A-4,<br>16L8A-4 | $R_2 = 1.56k\Omega$ | | 30 | 65 | | 30 | 50 | ns | | t <sub>PXZ</sub> | Input to output disable | 16R6A-4, 16R4A-4,<br>16L8A-4 | | | 30 | 65 | | 30 | 50 | ns | | f <sub>MAX</sub> | Maximum frequency | 16R8A-4, 16R6A-4,<br>16R4A-4 | | 8 | 18 | | 11 | 18 | | MHz | These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### **Medium 20B Series** 16L8B, 16R8B, 16R6B, 16R4B ## **Operating Conditions** | ava. | | | | COMMERCIAL1 | | | | |-----------------|--------------------------------------------|-------------------------|------|-------------|------|------|--| | SYMBOL | | PARAMETER | | | MAX | UNIT | | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | | | Width of clock | Low | 10 | 6 | | ns | | | t <sub>w</sub> | Width Of Clock | 10 | 5 | | " | | | | t <sub>su</sub> | Setup time from input or feedback to clock | 16R8B<br>16R6B<br>16R4B | 15 | 10 | | ns | | | t <sub>h</sub> | Hold time | | 0 | -10 | | ns | | | TA | Operating free-air temperature | | 0 | 25 | 75 | °C | | ## Electrical Characteristics Over Operating Conditions | | | | | COMMERCIAL | | | | |-------------------------------|------------------------------|-----------------------|--------------------------|------------|-------|-------|------| | SYMBOL | PARAMETER | TEST | TEST CONDITION | | | MAX | TINU | | V <sub>IL</sub> 2 | Low-level input voltage | | | A 33 1 | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>i</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>3</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | l <sub>l</sub> | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | I <sub>OZL</sub> <sup>3</sup> | <b>~</b> " | V - MAY | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 120 | 180 | mA | | OVMBOL | | | TEST | СО | MMERC | IAL | | |------------------|----------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------|-----|-------|-----|------| | SYMBOL | PA | RAMETER | CONDITIONS | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | 16L8B, 16R4B, 16R6B inp | ut or feedback to output | | | 12 | 15 | ns | | t <sub>CLK</sub> | Clock to output or feedbac | ck except 16L8B | | | 8 | 12 | ns | | t <sub>PZX</sub> | Pin 11 to output enable ex | ccept 16L8B | Commercial | | 10 | 15 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable e | xcept 16L8B | $R_1 = 200\Omega$ | | 10 | 15 | ns | | t <sub>PZX</sub> | Input to output enable | 16R6B, 16R4B, and 16L8B | $R_2 = 390\Omega$ | | 12 | 22 | ns | | t <sub>PXZ</sub> | Input to output disable | 16R6B, 16R4B, and 16L8B | la de la companya | | 12 | 15 | ns | | | 16R8B, 16R6B, 16R4B | Feedback | | 37 | 45 | | | | f <sub>MAX</sub> | Maximum frequency | No feedback | | 50 | 55 | | MHz | <sup>1.</sup> The PAL20B Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 20B-2 Series 16L8B-2, 16R8B-2, 16R6B-2, 16R4B-2 ## **Operating Conditions** | | | | | COI | MMERC | IAL <sup>1</sup> | | |-----------------|--------------------------------------------|-------------------------------|----------------------|------|-------|------------------|------| | SYMBOL | | PARAMETER | | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | | 4.75 | 5 | 5.25 | ٧ | | | \A#.dab | Low | | 15 | 10 | | | | t <sub>w</sub> | Width of clock | High | | 15 | 10 | 1.1 | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 16R8B-2<br>16R6B-2<br>16R4B-2 | | 25 | 15 | | ns | | t <sub>h</sub> | Hold time | | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air temperature | | toga velikazuat, 194 | 0 | 25 | 75 | °C | ## **Electrical Characteristics** Over Operating Conditions | | | | | COMMERCIAL | | | LIMIT | | |-------------------------------|------------------------------|-----------------------|---------------------------|------------|-------------|-------|-------|------| | SYMBOL | PARAMETER | | TEST CONDITION | | | TYP | MAX | UNIT | | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | | agair Na | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 1.1777.14 | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | - 1 | -0.8 | -1.5 | ٧ | | <sub> L</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | $V_1 = 0.4V$ | | V), it | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 1 | 25 | μΑ | | h | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | A Miles | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | $I_{OH} = -3.2 \text{mA}$ | | 2.4 | 2.8 | | ٧ | | l <sub>OZL</sub> 3 | <b>~</b> " | | V <sub>O</sub> = 0.4V | a francis | | | -100 | μΑ | | l <sub>ozh</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | - water 1 | -30 | -100 | -250 | mA | | loc | Supply current | V <sub>CC</sub> = MAX | | | i Mayor ari | 60 | 90 | mA | ## Switching Characteristics Over Operating Conditions | ovupo. | | TEST | СО | MMERC | IAL | | |------------------|-----------------------------------------------------------|-------------------|------|-------|-------------------|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | 25 15 20 20 25 25 | UNIT | | t <sub>PD</sub> | Input or feedback to output 16L8B-2, 16R4B-2, and 16R6B-2 | | .000 | 17 | 25 | ns | | t <sub>CLK</sub> | Clock to output or feedback except 16L8B-2 | | | 10 | 15 | ns. | | t <sub>PZX</sub> | Pin 11 to output enable except 16L8B-2 | Commercial | | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable except 16L8B-2 | $R_1 = 200\Omega$ | | .11 | 20 | ns | | t <sub>PZX</sub> | Input to output enable 16R6B-2, 16R4B-2, and 16L8B-2 | $R_2 = 390\Omega$ | | 10 | 25 | ns | | t <sub>PXZ</sub> | Input to output disable 16R6B-2, 16R4B-2, and 16L8B-2 | | | 13 | 25 | ns | | f <sub>MAX</sub> | Maximum frequency 16R8B-2, 16R6B-2, and 16R4B-2 | | 28.5 | 40 | | MHz | - The PAL20B-2 Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Medium 20B-4 Series 16L8B-4, 16R8B-4, 16R6B-4, 16R4B-4 ## **Operating Conditions** | | | PARAMETER | СО | MMERC | IAL <sup>1</sup> | | |-----------------|--------------------------------------------|-------------------------------|------|-------|------------------|------| | SYMBOL | | PARAMETER | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | | Width of clock | Low | 25 | 10 | | | | t <sub>w</sub> | WIGHT OF CIOCK | High | 25 | 10 | | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 16R8B-4<br>16R6B-4<br>16R4B-4 | 35 | 25 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air temperatu | re | О | 25 | 75 | °C | ## Electrical Characteristics Over Operating Conditions | ovupo. | | | | | COMMERCIAL | | | | |-------------------------------|------------------------------|-----------------------|------------------------|----------------------|------------|-------|------|--| | SYMBOL | PARAMETER | TEST CONDITION | | | TYP | MAX | UNIT | | | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | and and the state of | | 0.8 | ٧ | | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | $V_I = 0.4V$ | | -0.02 | -0.25 | mA | | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | 4576 | 25 | μΑ | | | lγ | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | i de lime : | 1, 34, 140 | 1 | mA | | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | ٧ | | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -1mA | 2.4 | 2.8 | | ٧ | | | l <sub>OZL</sub> 3 | <b>0</b> | V MAY | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | | l <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -100 | -250 | mA | | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 30 | 55 | mΑ | | | CVMDOL | | TEST | co | HAUT | | | |------------------|-----------------------------------------------------------|---------------------|----------|------|----------------------------|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | 35<br>25<br>25<br>25<br>35 | UNIT | | t <sub>PD</sub> | Input or feedback to output 16L8B-4, 16R4B-4, and 16R6B-4 | | | 25 | 35 | ns | | t <sub>CLK</sub> | Clock to output or feedback except 16L8B-4 | we should take | | 15 | 25 | ns | | t <sub>PZX</sub> | Pin 11 to output enable except 16L8B-4 | $R_1 = 800\Omega$ | | 15 | 25 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable except 16L8B-4 | $R_2 = 1.56K\Omega$ | princis. | 15 | 25 | ns | | t <sub>PZX</sub> | Input to output enable 16R6B-4, 16R4B-4, and 16L8B-4 | | | 25 | 35 | ns | | t <sub>PXZ</sub> | Input to output disable 16R6B-4, 16R4B-4, and 16L8B-4 | | 10000 | 25 | 35 | ns | | f <sub>MAX</sub> | Maximum frequency 16R8B-4, 16R6B-4, and 16R4B-4 | | 16 | 25 | | MHz | <sup>1.</sup> The PAL20B-4 Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. <sup>2.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. <sup>3.</sup> I/O pin leakage is the worst case of $\rm I_{IL}$ and $\rm I_{OZL}$ (or $\rm I_{IH}$ and $\rm I_{OZH}).$ <sup>4.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Medium 20D Series 16L8D, 16R8D, 16R6D, 16R4D ## **Operating Conditions** | | | | | COI | | | | |-----------------|--------------------------------------------|----------|---------------------|------|-----|------|------| | SYMBOL | | PARAMETE | | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | | 4.75 | 5 | 5.25 | ٧ | | | Mean at a land | Low | | 8 | 6 | | | | <sup>t</sup> w | Width of clock | High | | 8 | 5 | | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | | 16R8D, 16R6D, 16R4D | 10 | 8 | | ns | | t <sub>h</sub> | Hold time | | | 0 | -6 | | ns | | T <sub>A</sub> | Operating free-air temperatur | e · | | 0 | 25 | 75 | °C | ## **Electrical Characteristics** | SYMBOL | PARAMETER | TE | ST CONDITION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|----------------------------------|--------------------------|-----|-------|-------|------| | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | l <sub>IL</sub> <sup>3</sup> | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | 1 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 5.5V | | | 200 | μΑ | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 3.4 | | ٧ | | lozL <sup>3</sup> | | | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | I <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 120 | 180 | mA | | C <sub>IN</sub> | Input Capacitance | V <sub>IN</sub> = 2.0V@f = 1MHz | | | 2 | | | | C <sub>OUT</sub> | Output Capacitance | V <sub>OUT</sub> = 2.0V@f = 1MHz | | | 4 | | pF | | C <sub>CLK, EN</sub> | Clock/Enable Capacitance | V <sub>CLK, EN</sub> = 2.0 | /@f = 1MHz | | 9 | | | ## **Medium 20D Series** 16L8D, 16R8D, 16R6D, 16R4D | 0.71501 | Sangang and Caraching and Sangang Sang | PARAMETER | | CO | UNIT | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------|------|------|-----|------| | SYMBOL | PARA | AMETER | CONDITIONS | MIN | TYP | MAX | ONII | | t <sub>PD</sub> | Input or feedback to output | it 16L8D, 16R6D, 16R4D | | 3 | 8 | 10 | ns | | t <sub>CLK</sub> | Clock to output or feedbac | lock to output or feedback except 16L8D | | | 6 | 8 | ns | | t <sub>PZX</sub> | Pin 11 to output enable except 16L8D | | | 3 | 8 | 10 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable ex | xcept 16L8D | $R_1 = 200\Omega$ | 3 | 8 | 10 | ns | | t <sub>PZX</sub> | Input to output enable 16L | .8D, 16R6D, 16R4D | $R_2 = 390\Omega$ | 1 | 8 | 10 | ns | | t <sub>PXZ</sub> | Input to output disable 16L8D, 16R6D, 16R4D | | | 1 | 8 | 10 | ns | | | Maximum frequency | Feedback | | 55.5 | 70 | | MHz | | f <sub>MAX</sub> | MAX 16R8D, 16R6D, 16R4D | No feedback | | 62.5 | 75 | | MHZ | The PAL20D Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>IH</sub> and I<sub>OZI</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 20D Series 16L8D, 16R8D, 16R6D, 16R4D #### Metastability Metastability is a condition which can occur in any latch or flip-flop if the minimum setup or hold times are violated. In most cases, the flip-flop will either react to the input or remain in its current state, both of which are stable results. The flip-flop can also reach an "in-between" condition called the metastable state, which is stable only if there is no noise in the system and the flip-flop is perfectly balanced. This metastable condi- tion lasts until the flip-flop falls into one of its two stable states, which can take longer than the normal response time. The PAL20D Series exhibits better metastability characteristics than most other registered devices. It is less likely to enter the metastable state and recovers faster to a stable state. As a result, the PAL20D Series can make an excellent synchronizer circuit, and the metastability characteristics have been specified for designs in which the setup and hold times may not always be met. ## Metastability Characteristics Over Operating Conditions | OVMDOL | | TEST | СО | UNIT | | | |------------------|--------------------------------------------|-----------------------------------------|------|------|-----|------------------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | MAX | UNII | | р | Poisson process rate | | 0.85 | 1.05 | | ns <sup>-1</sup> | | k | MTBF constant | | | 0.8 | 1.0 | μs <sup>-1</sup> | | t <sub>MET</sub> | Minimum recovery time in asynchronous mode | MTBF = 10 years $f_d = (1/3)f d = 3$ | | 20 | 30 | ns | | fMET | Maximum frequency in asynchronous mode | MTBF = 10 years<br>$f_d = (1/3)f d = 3$ | 21 | 26 | | MHz | ## **Definition of Variables** MTBF (Mean Time Between Failures): the average time between metastable occurrences that cause a violation of the device specifications. Metastability characteristics are calculated at an arbitrary MTBF of 10 years for the convenience of the user. - p (Poisson process rate): experimentally calculated factor which determines the slope of the curve of probability of failure. - ${\bf k}$ (MTBF constant): experimentally calculated factor which determines the magnitude of the curve of probability of failure. tsu (setup time): the specified minimum time interval allowed between the application of a data signal at a specified device input pin (pin 9 on the device under test) and a subsequent clock transition. For the PAL20D Series, tsu is 10 nanoseconds. tCLK (clock to output time): the specified maximum time interval between a clock transition and the availability of valid signals at an output pin. For the PAL20D Series, tCLK is 8 nanoseconds. fMAX (maximum frequency): specified maximum frequency for the device under test. Calculated as 1/(tsu + tCLK). For the PAL20D Series, this calculates to 55.5 Megahertz. f(clock frequency): actual clock frequency for the device under test. - $\mathbf{f_d}$ (data frequency): actual data frequency for a specified input to the device under test. - **d** (data ratio): the ratio of the clock frequency to the data frequency $(f/f_a)$ . **t(time delay):** the additional time allowed per period beyond that required by the specifications. t is the actual time between clock transitions beyond the required period of (tsu + tCLK). tMET (metastability recovery time): minimum t required to guarantee recovery from metastability, with specified test conditions. fMET (metastability frequency): maximum f clock frequency to limit metastability failures, with specified test conditions. ## **Metastability Equations** MTBF = k (d/3) $(1/f)^2 e^{(p/f)}$ fMAX = 1/(tsu + tCLK) f = 1/(tsu + tCLK + t) $f = d(f_d)$ ## Metastability vs. Clock Frequency <sup>\*</sup>Normalized to d = 3; multiply by 3/d for other data frequencies. ## **Metastability Waveforms** # #### **Metastability Test Circuit** Section of the Property of the Contract ## Metastability Test Pattern File CHIP Metastability Test PAL16R4 CLOCK RESET SYNC MODE NC NC NC NC NC /D GND /OE NC NC /ERROR /B /A /Q NC NC VCC #### EQUATIONS Q := /Q\* SYNC MODE ; TOGGLE SYNCHRONOUS INPUT (TESTS f MAX) + D\*/SYNC MODE ; TOGGLE ASYNCHRONOUS INPUT (TESTS META.) A := A\*/Q ;HOLD A (IF NOT ERROR) + /A\* Q ;TOGGLE A (IF NOT ERROR) + ERROR ;SET A IF ERROR B := B\*/Q\*/ERROR ; HOLD B IF NOT ERROR, OR RESET + /B\* Q\*/ERROR ; TOGGLE B IF NOT ERROR, OR RESET ERROR := /A\*/B ; COMPARE A AND B, + A\* B ; ERROR GOES HIGH IF A EQUALS B + RESET ; INITIALIZE A AND B TO OPPOSITE PHASES 16L8 #### Medium 20PA Series 16P8A, 16RP8A, 16RP6A, 16RP4A #### Medium 20PA Series | | | | OUT | PUTS | t <sub>PD</sub> * | Icc | |-----------|--------------|--------|----------|------------|-------------------|------| | | ARRAY INPUTS | COMBIN | IATORIAL | REGISTERED | (ns) | (mĂ) | | PAL16P8A | 16 | | 8 | 0 | 25/30 | 180 | | PAL16RP8A | 16 | | 0 | 8 | 25/30 | 180 | | PAL16RP6A | 16 | | 6 | 2 | 25/30 | 180 | | PAL16RP4A | 16 | | 4 | 4 | 25/30 | 180 | <sup>\* 25</sup>ns active low, 30ns active high ## **Description** The Medium 20PA Series is equivalent to the Medium 20 Series, with the addition of programmable polarity. With programmable polarity unused, these devices are equivalent to the Medium 20A Series. ## **Polarity** Each of these devices offers programmable polarity on each output. If the polarity fuse is unused, the output is active low. If the polarity fuse is programmed, the output is inverted to active high. ## Preload and Power-up Reset Each device also offers register preload for device testability. The registers can be preloaded from the outputs by using supervoltages (see waveforms at end of section) in order to simplify functional testing. This series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. ## Performance Performance varies according to the use of the programmable polarity. Active low outputs have a tpd of 25ns, while active high outputs have a tpd of 30ns due to the extra inversion. All devices consume 180mA maximum ICC. #### **DIP Pinouts** 16P8A 16RP8A **16RP6A 16RP4A** T 5 6 5 6 AND OR (INVERT) LOGIC ARRAY AND OR (INVERT LOGIC ARRAY AND OR (INVERT) LOGIC ARRAY AND OR INVERT LOGIC ARRAY 8 7 [6 [7 Œ CD004308 CD00410N 2 A ## **Medium 20PA Series** 16P8A, 16RP8A, 16RP6A, 16RP4A ## **Operating Conditions** | | CYMPOL | | DADAMETED | | COMMERCIAL1 | | | | |-----------------|--------------------------------|------------------|----------------------|------|-------------|------|------|--| | SYMBOL | | PARAMETER | | MIN | TYP | MAX | UNIT | | | V <sub>CC</sub> | Supply voltage | | | 4.75 | 5 | 5.25 | V | | | | Width of clock | Low | | 20 | 14 | | | | | Lw . | Width of clock | High | | 10 | 6 | | ns | | | | Setup time from input | 16RP8A | Polarity fuse intact | 25 | 15 | | ns | | | <sup>T</sup> su | or feedback to clock | 16RP6A<br>16RP4A | Polarity fuse blown | 30 | 20 | | ns | | | t <sub>h</sub> | Hold time | <del>-1,</del> | | 0 | -10 | | ns | | | TA | Operating free-air temperature | | | 0 | | 75 | °C | | ## Electrical Characteristics Over Operating Conditions | SYMBOL | | | co | | | | | |-------------------------------|------------------------------|-----------------------|--------------------------|-----|-------|-------|------| | | PARAMETER | TE | TEST CONDITION | | | MAX | UNIT | | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | | 0.8 | ٧ | | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 2.4V | | | 25 | μΑ | | 4 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | l <sub>OZL</sub> <sup>3</sup> | 0" | | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>3</sup> | Off-state output current | $V_{CC} = MAX$ | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | | | 120 | 180 | mA | - The PAL20PA Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>IP</sub> and I<sub>OZI</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Medium 20PA Series 16P8A, 16RP8A, 16RP6A, 16RP4A | CVMPOL | | PARAMETER | | СО | HAUT | | | |------------------|---------------------------------------|------------------------------|-------------------|--------|------|-----|------| | SYMBOL | PAR | PARAMETER | | | TYP | MAX | UNIT | | | Input or feedback to | Polarity fuse intact | | | 15 | 25 | | | t <sub>PD</sub> | output 16P8A, 16RP6A,<br>16RP4A | Polarity fuse blown | | | 20 | 30 | ns | | t <sub>CLK</sub> | Clock to output or feedba | ck, | | | 10 | 15 | ns | | t <sub>PZX</sub> | Pin 11 to output enable except 16P8A | | $R_1 = 200\Omega$ | No. 1 | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable except 16P8A | | $R_2 = 390 KΩ$ | | 11 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | 16RP6A, 16RP4A, and<br>16P8A | | | 10 | 25 | ns | | t <sub>PXZ</sub> | Input to output disable | 16RP6A, 16RP4A, and<br>16P8A | | 10.000 | 13 | 25 | ns | | | Maximum frequency | Polarity fuse intact | | 28.5 | 40 | | MIL | | f <sub>MAX</sub> | 16RP8A, 16RP6A,<br> 16RP4A | Polarity fuse blown | | 25 | 33 | | MHz | #### 16P8A #### **16RP8A** ## Large 20 Arithmetic Series | | | OUTPUTS | | | |--------------------|--------------|---------------|------------|---------------| | | ARRAY INPUTS | COMBINATORIAL | REGISTERED | PRODUCT TERMS | | PAL16X4<br>PAL16A4 | 16<br>16 | 4 4 | 4 4 | 64<br>74 | ## **Description** The PAL16X4 and PAL16A4 have arithmetic gated feedback. These are specialized devices for arithmetic applications. #### **Arithmetic Gated Feedback** The arithmetic functions (add, subtract, greater than, and less than) are implemented by addition of gated feedback to the features of the XOR PAL device. The XOR at the input of the D-type flip-flop allows carrys from previous operations to be XORed with two variable sums generated by the PAL device array. The flip-flop Q output is fed back to be gated with input terms A (Figure 13). This gated feedback provides any one of the sixteen possible Boolean combinations which are mapped in the Karnaugh map (Figure 14). Figure 15 shows how the PAL device array can be programmed to perform these sixteen operations. These features provide for versatile operations on two variables and facilitate the parallel generation of carrys necessary for fast arithmetic operations. Figure 13 Figure 14 Figure 15 ## **DIP Pinouts** ## **PLCC Pinouts** ## Large 20 Arithmetic Series 16X4, 16A4 ## **Operating Conditions** | OVMDOL | SYMBOL PARAMETER CC Supply voltage | | MILITARY | | | co | LIMIT | | | |-----------------|-------------------------------------|----------------|----------|---------|----------------|--------------------|--------------|------|------| | SYMBOL | | | MIN 4.5 | TYP | <b>MAX</b> 5,5 | <b>MIN</b><br>4.75 | <b>TYP</b> 5 | MAX | UNIT | | V <sub>CC</sub> | | | | 5 | | | | 5.25 | ٧ | | | Width of clock | Low | 25 | 10 | | 25 | 10 | | ns | | t <sub>w</sub> | Width of clock | High | 25 | 10 | | 25 | 10 | | | | t <sub>su</sub> | Set up time from input or fee | dback to clock | 55 | 30 | | 45 | 30 | | ns | | t <sub>h</sub> | Hold time | | 0 | -15 | | 0 | -15 | | ns | | T <sub>A</sub> | Operating free-air temperature | | -55 | C DRY I | 2.5 | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | 125 | | | | °C | ## **Electrical Characteristics** | SYMBOL | PARAMETER | T | EST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|------------------------------|-----|-------|-------|------| | V <sub>IL</sub> <sup>1</sup> | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>1</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 2.4V | | | 25 | μΑ | | lı . | Maximum input current | V <sub>CC</sub> = MAX | V <sub>j</sub> = 5.5V | | | 1 | mA | | V | | | Mil I <sub>OL</sub> = 12mA | | 0.0 | | ., | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V *** | | | Mil I <sub>OL</sub> = -2mA | | 0.0 | | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | I <sub>OZL</sub> <sup>2</sup> | 04 | V = MAY | V <sub>O</sub> = 0.4V | 300 | | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | I <sub>CC</sub> Supply | Cumply augrent | V - MAY | 16X4 | | 160 | 225 | 4 | | | Supply current | V <sub>CC</sub> = MAX | 16A4 | | 170 | 240 | mA | | SYMBOL | PARAMETER | TEST<br>CONDITIONS | MILITARY | | | COMMERCIAL | | | | |------------------|-----------------------------|-------------------------------------|----------|-----|-----|------------|-----|-----|------| | | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | | | 30 | 45 | | 30 | 40 | ns | | t <sub>CLK</sub> | Clock to output or feedback | | | 15 | 25 | | 15 | 25 | ns | | t <sub>PZX</sub> | Pin 11 to output enable | | | 15 | 25 | | 15 | 25 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable | $R_1 = 200\Omega$ $R_2 = 390\Omega$ | | 15 | 25 | | 15 | 25 | ns | | t <sub>PZX</sub> | Input to output enable | | | 30 | 45 | | 30 | 40 | ns | | t <sub>PXZ</sub> | Input to output disable | | | 30 | 45 | | 30 | 40 | ns | | f <sub>MAX</sub> | Maximum frequency | | 12 | 22 | | 14 | 22 | | MHz | These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>|H</sub> and I<sub>OZI</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. # Large 20RA (PAL16RA8) Description The PAL16RA8 is a 20-pin registered asynchronous PAL device. It is a 20-pin version of the original asynchronous PAL device, the PAL20RA10. This versatile device features programmable clock, enable, set, and reset, all of which can operate asynchronously to other flip-flops in the same device. It also has individual flop-flop bypass, allowing this one device to provide any combination of registered and combinatorial outputs. #### **Programmable Clock** The clock input to each flip-flop comes from the programmable array, allowing the flip-flops to be clocked independently if desired. #### **Programmable Set and Reset** Each flip-flop has a product line for asynchronous set and one product for asynchronous reset. If the chosen product line is high, the flip-flop will set (become a logic HIGH), or reset (become a logic LOW). The sense of the output pin is inverted if the output is active low. #### **Programmable Polarity** Each flip-flop has individually programmable polarity. The unprogrammed state is active low. #### Programmable Flip-flop Bypass If both the set and reset product lines are high, the flip-flop is bypassed and the output becomes combinatorial. Thus each output can be configured to be registered or combinatorial. # Programmable and Hard-Wired Three-State Outputs The PAL16RA8 provides a product term dedicated to output control. There is also an output control pin (pin 11). The output is enabled if both the output control pin is low and the output control product term is high. If the output control pin is high all outputs will be disabled. If an output control product term is low, then that output will be disabled. ## Register Preload and Power-up Reset Each device also offers register preload for device testability. The registers can be preloaded from the outputs by using TTL level signals in order to simplify functional testing. This series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. ### **DIP Pinout** ### **PLCC Pinout** #### Large 20RA Series 16RA8 ### **Operating Conditions** | | PARAMETER | | COL | | | | |------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|--------|------| | SYMBOL | PARAMETER | | | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | t <sub>w</sub> | Width of clock | and the second section of the second section of the second section of the second section of the | 20 | 13 | | ns | | t <sub>wp</sub> | Preload pulse width | | 35 | 15 | | ns | | t <sub>su</sub> | Setup time for input or feedback to clock | | 20 | 10 | 14 442 | ns | | t <sub>sup</sub> | Preload setup time | | 25 | 5 | | ns | | | Hold time | Polarity fuse intact | 10 | -2 | | | | t <sub>h</sub> | Proid time | Polarity fuse blown | 0 | -6 | | ns | | t <sub>hp</sub> | Preload hold time | | 25 | 5 | | ns | | TA | Operating free-air temperature | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | | °C | ### Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | , т | EST CONDITION | MIN | TYP | MAX | UNIT | |------------------------------|------------------------------|-----------------------|-----------------------------|------|-------|-------|------| | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | 4 7.7 | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>1</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | $V_1 = 0.4V$ | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | 11 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 5.5V | | | - 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | V | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | l <sub>oz</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | $V_{O} = 2.4V/V_{O} = 0.4V$ | -100 | 4 | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 135 | 170 | mA | | ovunou | | PARAMETER | | co | | | | |---------------------------------------------|------------------------------------------------------------------|-----------------------------|--------------------|------|-----|-----|------| | SYMBOL | PAHAME | :IEM | CONDITIONS | MIN | TYP | MAX | UNIT | | | | Polarity fuse intact | | | 20 | 30 | | | t <sub>PD</sub> Input or feedback to output | Polarity fuse blown | | | 25 | 35 | ns | | | t <sub>CLK</sub> | Clock to output or feedback | Clock to output or feedback | | 10 | 17 | 30 | ns | | t <sub>S</sub> | Input to asynchronous set | | 7 | | 22 | 35 | ns | | t <sub>R</sub> | Input to asynchronous reset | | $R_1 = 560\Omega$ | | 27 | 40 | ns | | t <sub>PZX</sub> | Pin 11 to output enable | | $R_2 = 1.1K\Omega$ | 44.7 | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 11 to output disable | | | | 10 | 20 | ns | | t <sub>PZX</sub> | Input to output enable Input to output disable Maximum frequency | | | | 18 | 30 | ns | | t <sub>PXZ</sub> | | | | | 15 | 30 | ns | | f <sub>MAX</sub> | | | | 20 | 35 | | MHz | - 1. The PAL20RA Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of $I_{\rm IL}$ and $I_{\rm OZL}$ (or $I_{\rm IH}$ and $I_{\rm OZH}$ ). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Small 24 Series 12L10, 14L8, 16L6, 18L4, 20L2, 20C1 #### Small 24 Series | | | INPUTS | OUTPUTS | POLARITY | T <sub>PD</sub> (ns) | I <sub>CC</sub><br>(mA) | |------|----------|--------|---------|----------|----------------------|-------------------------| | | PAL12L10 | 12 | 10 | LOW | 40 | 100 | | 1.50 | PAL14L8 | 14 | 8 | LOW | 40 | 100 | | 1.4 | PAL16L6 | 16 | 6 | LOW | 40 | 100 | | 14.4 | PAL18L4 | 18 | 4 | LOW | 40 | 100 | | | PAL20L2 | 20 | 2 | LOW | 40 | 100 | | | PAL20C1 | 20 | 2 | LOW | 40 | 100 | #### Description The Small 24 Series is made up of six combinatorial 24-pin PAL devices. They implement simple combinatorial logic, with no feedback. ## **Performance** The standard series has a propagation delay (tpd) of 40 nanoseconds (ns). Standard supply current is 100 milliamps (mA). CD00190M ### Small 24 Series 12L10, 14L8, 16L6, 18L4, 20L2, 20C1 # **Operating Conditions** | OVMDOL | | ı | MILITAR | Y | со | MMERC | IAL | 11607 | |-----------------|--------------------------------|-----|---------|-----|------|-------|------|-------| | SYMBOL | PARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | T <sub>A</sub> | Operating free-air temperature | -55 | | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | 125 | | | | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TE | ST CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------|------------------------------|-----------------------|------------------------------|-----|------|-------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>1</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | l <sub>i</sub> = -18mA | | -0.8 | -1.5 | V | | ارر | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | 0.02 | -0.25 | mA | | I <sub>IH</sub> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | կ | Maximum input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 5.5V | | | 1 | mA | | ., | | | MIL I <sub>OL</sub> = 8mA | * | 0.3 | 0.5 | | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | COM I <sub>OL</sub> = 8mA | 1 | 0.3 | 0.5 | V | | V | Lijah lawal a stavit valtaas | 17 _ NIN | MIL I <sub>OH</sub> = -2mA | 0.4 | 2.8 | | v | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | COM I <sub>OH</sub> = -3.2mA | 2.4 | 2.0 | | V | | l <sub>OS</sub> <sup>2</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 60 | 100 | mA | | 0.74501 | | TEST | | IILITAR | Y | co | MMERC | IAL | | |-----------------|-----------------------------|------------------------------------|-----|---------|-----|-----|-------|-----|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output | $R1 = 560\Omega$ $R2 = 1.1k\Omega$ | | 25 | 45 | | 25 | 40 | ns | These are absolute values with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. <sup>2.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ### Small 24A Decoder Series 6L16A, 8L14A #### **Small 24A Decoder Series** | | INPUTS | OUTPUTS | t <sub>PD</sub><br>(ns) | I <sub>CC</sub><br>(mA) | |----------|--------|---------|-------------------------|-------------------------| | PAL6L16A | 6 | 16 | 25 | 90 | | PAL8L14A | 8 | 14 | 25 | 90 | ### **Description** The Small 24A Decoder Series provides a wide number of outputs, especially useful in decoding applications. These two parts implement simple combinatorial logic. #### **Performance** These devices offer 25ns speed at only 90mA supply current. #### **DIP Pinouts** #### **PLCC Pinouts** #### Small 24A Decoder Series 6L16A, 8L14A ## **Operating Conditions** | | | COI | AL <sup>1</sup> | | | |-----------------|--------------------------------|------|-----------------|------|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | 4.75 | 5 | 5.25 | > | | TA | Operating free-air temperature | 0 | 25 | 75 | °C | ### Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | | TEST CONDITION | MIN | TYP | MAX | UNIT | |------------------------------|------------------------------|-----------------------|--------------------------|-----|-------|-------|------| | V <sub>IL</sub> <sup>2</sup> | Low-level input voltage | | | | | 0.8 | V . | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | V | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | V | | I <sub>IL</sub> | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | l <sub>l</sub> | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 60 | 90 | mA | | | | TEST | СО | MMERC | IAL | | |-----------------|-----------------------------------|--------------------------------------|-----|-------|-----|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input to output propagation delay | $R_1 = 560\Omega$ $R_2 = 1.1K\Omega$ | | 15 | 25 | ns | - 1. The PAL24A Decoder Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - 3. No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 24 Series | | OUTPUTS | |--------------------------|--------------------------| | DEDICATED INPUTS | COMBINATORIAL REGISTERED | | PAL20L8 12<br>PAL20R8 10 | 8 (6 I/O) 0<br>0 8 | | PAL20R6 10 10 10 | 2 I/O 6<br>4 I/O 4 | #### Description The Medium 24 Series consists of four devices, each with twenty array inputs and eight outputs. The devices have either 0, 4, 6, or 8 registered outputs, with the remaining being combinatorial. Each of the registered outputs feeds back into the array, for sequential designs. The combinatorial outputs also feed back into the array, except for two of the outputs on the 20L8. This feedback allows the output to also operate as an input if the output is disabled. #### Fnable The combinatorial outputs are enabled by a product term. The registered outputs are enabled by a common enable pin. #### **Polarity** All outputs are active low. #### **Performance** Several speed/power versions are available: | Suffix | t <sub>PD</sub><br>(ns) | I <sub>CC</sub><br>(mA) | |--------|-------------------------|-------------------------| | Α | 25 | 210 | | A-2 | 35 | 105 | | В | 15 | 210 | | B-2 * | 25 | 105 | <sup>\*</sup> contact Monolithic Memories for datasheet #### Preload and Power-up Reset The B-2 Series offers register preload for device testability. The registers can be preloaded from the outputs by using supervoltages (see waveforms at end of section) in order to simplify functional testing. The B-2 Series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. ZPAL circuits to be used for direct replacement of discrete # CMOS ZPAL<sup>TM</sup> 24 Series Features/Benefits - CMOS technology provides zero standby power - Lowest power 24-pin PAL® device family; consumes only 3mA/MHz - 35ns maximum propagation delay - Programmable replacement for CMOS/TTL logic - · Reduces chip count by greater than six to one - Instant prototyping and easier board layout - HC/HCT compatible for use in CMOS or TTL systems - Offered over both the Commercial and Industrial temperature ranges - Low-cost, one-time programmable SKINNYDIP® and PLCC packages save board space #### Description The CMOS ZPAL24 Series offers the first family of PAL devices with true CMOS power consumption. Under standby conditions (inputs and clock not changing), the devices consume a maximum current of $100\mu$ A, less than 1% that of the quarter-power PAL devices. This low power consumption allows the devices to be powered by a battery almost indefinitely. While operating, the devices consume additional power only when the inputs or clock change. Power consumption is directly proportional to the frequency of changes to the inputs. $I_{\rm CC}$ is therefore specified as 3mA per 1MHz of operating frequency, starting from 5mA at 1MHz. Thus, the maximum current at 8MHz would be 5mA + 7x3mA, or 26mA. # CMOS as well as TTL logic. Areas of Application - Portable computers - Battery-operated instrumentation - Low-power industrial equipment - Standard CMOS/TTL logic replacement #### **Features** Medium 24 Series 20L8, 20R8, 20R6, 20R4 The CMOS ZPAL24 Series includes the four standard 24-pin PAL device architectures. All four devices have twenty array inputs and eight outputs, with varying numbers of registers: zero (20L8), four (20R4), six (20R6), and eight (20R8). The combinatorial outputs on the registered devices, and six of the outputs on the 20L8, are I/O pins that can be individually programmed as inputs or outputs. Each output register, a D-type flip-flop, also feeds back into the array, for implementation of synchronous state machine designs. Registered outputs are enabled by an external input, while the combinatorial outputs use a product term to control the enable function. The basic PAL device architecture is a programmable AND array feeding a fixed OR array. The programmable AND array consists of a set of cells similar to those used in EPROMs. Erasable by UV light, the cells can be programmed and erased in the factory to ensure 100% programming and functional yields. Windowed packages will be made available in the future, allowing erasure in the field. Windowed packages allow easy prototype testing and reconfiguration. #### **DIP Pinouts** #### **PLCC Pinouts** #### **Medium 24A Series** 20L8A, 20R8A, 20R6A, 20R4A ## **Operating Conditions** | OVMDOL | | | | <b>IILITAR</b> | Y | co | MMERC | IAL | | |-------------------------------|---------------------------------------------|-------------------|-----|----------------|-----|------|-------|------------|------| | SYMBOL | SYMBOL PARAMETER | | | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | C Supply voltage 4 | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | | Wilder of State | Low | 20 | 7 | | 15 | 7 | No. of the | | | t <sub>w</sub> Width of clock | High | 20 | 7 | 24 | 15 | 7 | | ns | | | t <sub>su</sub> | Set up time from input or feedback to clock | 20R8A 20R6A 20R4A | 30 | 15 | | 25 | 15 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | TA | Operating free-air temperatur | 9 | -55 | | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | 13.74% | 125 | | | | °C | ### **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARAMETER | TE | ST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|------------------------------|-----|-------|-------|----------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | V | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | l <sub>IH</sub> 2 | High-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 2.4V | | | 25 | μΑ | | l <sub>k</sub> | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V | Low lovel output valtage | V - MINI | Mil I <sub>OL</sub> = 12mA | | 0.3 | 0.5 | v | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | <b>V</b> | | V | Ulab laval autaut altaa | LV - VIN | Mil I <sub>OH</sub> = -2mA | | | | v | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | <b>,</b> | | l <sub>OZL</sub> <sup>2</sup> | 04 | V - MAY | $V_O = 0.4V$ | | | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -90 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 160 | 210 | mA | These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ### Medium 24A Series 20L8A, 20R8A, 20R6A, 20R4A | | | | TEST | N | MLITAF | łΥ | СО | MMERC | IAL | | |------------------|-----------------------------|----------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|------|-------|-----|------| | SYMBOL | PARAMETER | | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PĎ</sub> | Input or feedback to output | 20R6A 20R4A<br>20L8A | | | 15 | 30 | | 15 | 25 | ns | | t <sub>CLK</sub> | Clock to output | or feedback | | | 10 | 20 | 7.65 | 10 | 15 | ns | | t <sub>PZX</sub> | Pin 13 to output<br>20L8A | t enable except | $R_1 = 200\Omega$ $R_2 = 390\Omega$ | | 10 | 25 | | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 13 to output<br>20L8A | t disable except | | | 11 | 25 | | 11 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | 20R6A 20R4A<br>20L8A | | | 10 | 30 | | 10 | 25 | ns | | t <sub>PXZ</sub> | Input to output disable | 20R6A 20R4A<br>20L8A | | i in the State of | 13 | 30 | | 13 | 25 | ns | | f <sub>MAX</sub> | Maximum frequency | 20R8A 20R6A<br>20R4A | | 20 | 40 | | 28.5 | 40 | | MHz | #### Medium 24A-2 Series 20L8A-2, 20R8A-2, 20R6A-2, 20R4A-2 ### **Operating Conditions** | t <sub>w</sub> | 1.00 | CO | COMMERCIAL1 | | | | | |-----------------|--------------------------------------------|---------------------------|-------------|-----|------|------|--| | | PARAMETER | | MIN | TYP | MAX | UNIT | | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | | | | Low | 25 | 10 | | | | | t <sub>w</sub> | Width of clock | High | 25 | 10 | | ns | | | t <sub>su</sub> | Setup time from input or feedback to clock | 20R8A-2, 20R6A-2, 20R4A-2 | 35 | 25 | | ns | | | t <sub>h</sub> | Hold time | | 0 | -15 | | ns | | | TA | Operating free-air temperature | | 0 | 25 | 75 | °C | | #### Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TE | ST CONDITION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|--------------------------|----------------------------------------------------------------------------------------------------------------|--------|-------|------| | V <sub>IL</sub> 2 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | 1, 2, 11, 15 | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | Y | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | and a first of the same | 700 | 25 | μΑ | | l <sub>l</sub> , | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | I <sub>OZL</sub> 3 | 0.4 | _ MAY | V <sub>O</sub> = 0.4V | | yello. | -100 | μΑ | | I <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | loc | Supply current | V <sub>CC</sub> = MAX | | | 80 | 105 | mA | | 0)/44501 | | TEST | | <b>ILITAR</b> | Υ | СО | MMERC | IAL | | |---------------------|--------------------------------------------------------|------------------------------|-----|---------------|-----|--------|-------|-----|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output<br>20L8A-2 20R6A-2 20R4A-2 | | | 25 | 50 | | 25 | 35 | ns | | t <sub>CLK</sub> | Clock to output or feedback except 20L8A-2 | | | 15 | 25 | | 15 | 25 | ns | | t <sub>PXZ/ZX</sub> | Pin 13 to output disable/enable except 20L8A-2 | Commercial $R_1 = 200\Omega$ | | 15 | 25 | | 15 | 25 | ns | | t <sub>PZX</sub> | Input to output enable 20L8A-2<br>20R6A-2 20R4A-2 | $R_2 = 390\Omega$ | | 25 | 45 | | 25 | 35 | ns | | t <sub>PXZ</sub> | Input to output disable 20L8A-2<br>20R6A-2 20R4A-2 | | | 25 | 45 | 7. ya. | 25 | 35 | ns | | f <sub>MAX</sub> | Maximum frequency 20R8A-2<br>20R6A-2 20R4A-2 | | 14 | 19 | | 16 | 19 | | MHz | - The PAL24A-2 Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### **Medium 24B Series** 20L8B, 20R8B, 20R6B, 20R4B ## **Operating Conditions** | OVMDOL | | COI | | | | | | |-----------------|--------------------------------------|-------|---------------------|------|-----|------|------| | SYMBOL | PAHA | METER | | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | | 4.75 | 5 | 5.25 | ٧ | | | Width of clock | Low | | 10 | 6 | | | | ₩. | Width of clock | High | 20R8B, 20R6B, 20R4B | 12 | 8 | | ns | | t <sub>su</sub> | Setup time from input or feedback to | clock | | 15 | 10 | 4.5 | ns | | t <sub>h</sub> | Hold time | | | 0 | -10 | | ns | | TA | Operating free-air temperature | | 0 | 25 | 75 | °C | | ## **Electrical Characteristics** Over Operating Conditions | | | | | СО | MMERC | IAL | | |-------------------------------|------------------------------|-----------------------|--------------------------|-----|-------|-------|------| | SYMBOL | PARAMETER | TES | TEST CONDITION | | | | UNIT | | V <sub>IL</sub> 2 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | 4 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | I <sub>OZL</sub> <sup>3</sup> | <b>A</b> | | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>ozh</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | | | 140 | 210 | - mA | | | | | TEST | co | UNIT | | | |------------------|----------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------|-------------|------|-----|------| | SYMBOL | PARAME | - JEK | CONDITIONS | MIN | TYP | MAX | UNII | | t <sub>PD</sub> | Input or feedback to output 2 | 20L8B, 20R6B, 20R4B | | | 12 | 15 | ns | | t <sub>CLK</sub> | Clock to output or feedback | Clock to output or feedback except 20L8B | | | 8 | 12 | ns | | t <sub>PZX</sub> | Pin 13 to output enable except 20L8B Pin 13 to output disable except 20L8B | | Commercial | 100 | 10 | 15 | ns | | t <sub>PXZ</sub> | | | $\begin{array}{c} R_1 = 200\Omega \\ R_2 = 390\Omega \end{array}$ | | 8 | 12 | ns | | t <sub>PZX</sub> | Input to output enable<br>20R6B, 20R4B, 20L8B | | 7 | | 12 | 18 | ns | | t <sub>PXZ</sub> | Input to output disable 20R6B, 20R4B, 20L8B | | | \$4.27 F.A. | 12 | 15 | ns | | | Maximum frequency | Maximum frequency Feedback | | 37 | 40 | | | | †MAX | 20R8B, 20R6B, 20R4B | No feedback | | 45 | 50 | | MHz | <sup>1.</sup> The PAL24B Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. <sup>2.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### Medium 24X Series 20L10, 20X10, 20X8, 20X4 #### **Medium 24X Series** | | | OUT | PUTS | STAN | IDARD | HIGH | SPEED | |----------|--------------|---------------|------------|----------------------|----------------------|-------------------------|-------------------------| | | ARRAY INPUTS | COMBINATORIAL | REGISTERED | t <sub>PD</sub> (ns) | I <sub>CC</sub> (mA) | t <sub>PD</sub><br>(ns) | I <sub>CC</sub><br>(mA) | | PAL20L10 | 20 | 10 | 0 | 50 | 165 | 30 | 165 | | PAL20X10 | 20 | 0 | 10 | 50 | 180 | 30 | 180 | | PAL20X8 | 20 | 2 | 8 | 50 | 180 | 30 | 180 | | PAL20X4 | 20 | 6 | 4 | 50 | 180 | 30 | 180 | #### Description The PAL24X Series offers Exclusive-OR (XOR) gates preceding each register. The XOR gate has as its inputs two sums, each of two product terms. The XOR gate is very efficient for counting applications. #### Enable The combinatorial outputs are enabled by a product term. The registered outputs are enabled by a common enable pin. #### **Polarity** All outputs are active low. #### Preload and Power-up Reset The 24XA Series offers register preload for device testability. The registers can be preloaded from the outputs by using supervoltages (see waveforms at end of section) in order to simplify functional testing. The 24XA Series also offers Powerup Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. 21 20 19 18 17 16 15 CD001408 ## **DIP Pinouts** ### **PLCC Pinouts** #### **Medium 24X Series** 20L10, 20X10, 20X8, 20X4 ## **Operating Conditions** | A | | | , | <b>VILITAR</b> | Υ | СО | IAL | UNIT | | |-------------------------------|--------------------------------------------|-------------------|-----|----------------|-----|-------------|-----------|------|-----| | SYMBOL | PARAMETER | | | TYP | MAX | MIN | TYP | | MAX | | V <sub>CC</sub> | Supply voltage 4 | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | | Middle of alask | Low | 40 | 20 | | 35 | 20 | | | | t <sub>w</sub> Width of clock | High | 30 | 10 | | 25 | 10 | | ns | | | t <sub>su</sub> | Setup time from input or feedback to clock | 20X10, 20X8, 20X4 | 60 | 38 | | 50 | 38 | | ns | | t <sub>h</sub> | Hold time | | 0 | -15 | | 0 | -15 | | ns | | T <sub>A</sub> | Operating free-air temperat | ure | -55 | | | 0 | S 8 9 5 6 | 75 | °C | | T <sub>C</sub> | Operating case temperature | 9 | | 14.5.5 | 125 | N. W. G. L. | 100 | | °C | ## Electrical Characteristics (Over Operating Conditions) | SYMBOL | PARAMETER | τ | TEST CONDITIONS | | | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|-----------------|--------------------------|-----|-------|-------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>1</sup> | High-level input voltage | | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | l <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | η. | Maximum input current | V <sub>CC</sub> = MAX | | V <sub>I</sub> = 5.5V | | | 1 | mA | | | | | Mil | I <sub>OL</sub> = 12mA | | 0.3 | 0.5 | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com | I <sub>OL</sub> = 24mA | | | | ٧ | | | | | Mil | I <sub>OH</sub> = -2mA | | 2.8 | | | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com | I <sub>OH</sub> = -3.2mA | 2.4 | | | V | | l <sub>OZL</sub> <sup>2</sup> | <b>4.</b> | | | $V_{O} = 0.4V$ | | | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | 20X10 | 20X8 20X4 | | 120 | 180 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | 20L10 | | | 90 | 165 | mA | These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>L</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ### Medium 24X Series 20L10, 20X10, 20X8, 20X4 | SYMBOL | PARAMETER | TEST<br>CONDITIONS | MILITARY | | | COMMERCIAL | | | | |---------------------|--------------------------------------------------|--------------------|----------|-----|-----|---------------------------------------|-----|-----|------| | | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedback to output<br>20X8, 20X4, 20L10 | | | 35 | 60 | A 1844. | 35 | 50 | ns | | t <sub>CLK</sub> | Clock to output or feedback except 20L10 | | | 20 | 35 | um (34) a<br>(3)<br>(3) (4) (4) | 20 | 30 | ns | | t <sub>PXZ/ZX</sub> | Pin 13 to output disable/enable except 20L10 | $R_1 = 200\Omega$ | | 20 | 45 | | 20 | 35 | ns | | t <sub>PZX</sub> | Input to output enable except 20X10 | $R_2 = 390\Omega$ | | 35 | 55 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 35 | 45 | ns | | t <sub>PXZ</sub> | Input to output disable except 20X10 | | | 35 | 55 | | 35 | 45 | ns | | f <sub>MAX</sub> | Maximum frequency<br>20X10, 20X8, 20X4 | | 10.5 | 16 | | 12.5 | 16 | | MHz | #### **Medium 24XA Series** 20L10A, 20X10A, 20X8A, 20X4A ## **Operating Conditions** | | | | | COMMERCIAL1 | | | | |----------------------|--------------------------------------------|----------------------|-----|-------------|------|----|--| | SYMBOL | PARAM | MIN | TYP | MAX | UNIT | | | | V <sub>CC</sub> | Supply voltage | | | | 5.25 | V | | | t <sub>w</sub> Width | Width of clock Low High | Low | 25 | 15 | | ns | | | | | High | 15 | 7 | | | | | t <sub>su</sub> | Setup time from input or feedback to clock | 20X10A, 20X8A, 20X4A | 30 | 20 | | ns | | | t <sub>h</sub> | Hold time | | 0 | -15 | | ns | | | TA | Operating free-air temperature | | 0 | 25 | 75 | °C | | ## Electrical Characteristics (Over Operating Conditions) | SYMBOL | PARAMETER | TES | T CONDITION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|--------------------------|-----|-------|-------|------| | V <sub>IL</sub> 2 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>3</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | l <sub>i</sub> | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 24mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -3.2mA | 2.4 | 2.8 | | ٧ | | l <sub>OZL</sub> <sup>3</sup> | <b>~</b> : | V <sub>CC</sub> = MAX | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>3</sup> | Off-state output current | | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply Current | | 20X10A,20X8A,20X4A | | 140 | 180 | | | | | V <sub>CC</sub> = MAX | 20L10A | | 115 | 165 | mA | | SYMBOL | PARAMETER Input or feedback to output 20L10A, 20X8A, and 20X4A Clock to output or feedback Pin 13 to output enable except 20L10A Pin 13 to output disable except 20L10A | | | СО | | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------|------|-----|-----|------| | | | | TEST CONDITIONS | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | | | Commercial $R_1 = 200\Omega$ | | 23 | 30 | ns | | t <sub>CLK</sub> | | | | | 10 | 15 | ns | | t <sub>PZX</sub> | | | | | 11 | 20 | ns | | t <sub>PXZ</sub> | | | | | 10 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | 20X8A, 20X4A, and<br>20L10A | $R_2 = 360\Omega$ | | 19 | 30 | ns | | t <sub>PXZ</sub> | Input to output disable | 20X8A, 20X4A, and<br>20L10A | | | 15 | 30 | ns | | f <sub>MAX</sub> | Maximum frequency | 20X10A, 20X8A, and<br>20X4A | | 22.2 | 32 | | MHz | - 1. The PAL24XA Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### 20X10 #### 20X4 #### Large 24RS Series 20S10, 20RS10, 20RS8, 20RS4 #### Large 24RS Series | | | ООТ | STANDARD | | | |-----------|--------------|---------------|------------|---------------------------|-------------------------| | | ARRAY INPUTS | COMBINATORIAL | REGISTERED | t <sub>PD</sub> *<br>(ns) | l <sub>CC</sub><br>(mA) | | PAL20S10 | 20 | 10 | 0 | 35/40 | 240 | | PAL20RS10 | 20 | 0 | 10 | 35 | 240 | | PAL20RS8 | 20 | 2 | 8 | 35/40 | 240 | | PAL20RS4 | 20 | 6 | 4 | 35/40 | 240 | <sup>\*35</sup>ns active low, 40ns active high #### Description The Large 24RS Series offers product term sharing, which allows up to sixteen product terms to be used at a single output. #### **Enable** The combinatorial outputs are enabled by a product term. The registered outputs are enabled by a common enable pin. #### **Programmable Polarity** Each flip-flop has individually programmable polarity. The unprogrammed state is active low. #### **Product Term Sharing** Product term sharing allows each pair of outputs to share its product terms with one output or the other (not both). Each pair has a total of sixteen product terms; thus, one output can use zero to sixteen terms while the other has sixteen to zero. Product terms can only be shared mutually exclusively. If both outputs need the same term, it must be created twice, once for each output. #### Preload and Power-up Reset The 24RS Series offers register preload for device testability. The registers can be preloaded from the outputs by using supervoltages (see waveforms at end of section) in order to simplify functional testing. The 24RS Series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. #### Large 24RS Series 20\$10, 20R\$10, 20R\$8, 20R\$4 ## **Operating Conditions** | 0.01001 | YMBOL PARAMETER | | | MILITAR | lY . | co | MMERC | IAL | UNIT | |-----------------|--------------------------------------------|--------------------------|-----|---------|------|------|-------------|------|------| | SYMBOL | | | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | V <sub>CC</sub> | C Supply voltage | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | | NAME AND ASSESSED. | Low | 20 | 10 | | 15 | 10 | 1.7 | 3.52 | | t <sub>w</sub> | Width of clock | High | | 10 | | 15 | 10 | | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 20RS10<br>20RS8<br>20RS4 | 40 | 25 | | 35 | 25 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | TA | Operating free-air temperature | | | | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | 125 | | MAN AND AND | | °C | ### Electrical Characteristics (Over Operating Conditions) | SYMBOL | PARAMETER | Т | EST CONDI | TION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|----------------------------------------------|--------------------------|----------------------------|---------------|----------|--------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | | | .36 | 1025 | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | V <sub>CC</sub> = MIN I <sub>I</sub> = -18mA | | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>CC</sub> = MAX V <sub>I</sub> = 0.4V | | 3 (4 (4) (4)<br>(4 (4) (4) | -0.02 | -0.25 | mA | | l <sub>IH</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | | 25 | μA., | | 4 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | | 1 | mA | | | I am I amai a mana malama | V - 141N1 | Mil | I <sub>OL</sub> = 12mA | | 0.3 | 0.5 | v | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 24mA | | | 0.3 | 0.5 | V. | | y and | Llight lovel output valtees | V - MINI | Mil | I <sub>OH</sub> = -2mA | 2.4 | 2.8 | | , | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com | I <sub>OH</sub> = -3.2mA | 2.4 | 2.0 | y 345 ** | V<br>A | | l <sub>OZL</sub> <sup>2</sup> | 0" | V - MAY | | V <sub>O</sub> = 0.4V | | | -100 | | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | | V <sub>O</sub> = 2.4mA | | Far par de la | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | a Pagean I | | 175 | 240 | mA | <sup>1.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>jH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. # Large 24RS Series 20S10, 20RS10, 20RS4 ## Switching Characteristics (Over Operating Conditions) | 0.4450 | | <u> </u> | TEST | N | <b>ILITAR</b> | Y | СО | MMERC | IAL | | |------------------|-------------------------------|-------------------------|--------------------------------------|-----|---------------|-----|-----|-------|-----|------| | SYMBOL | PARA | PARAMETER | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | | Input or Folarity fuse intact | | | | 25 | 40 | | 25 | 35 | | | t <sub>PD</sub> | output 20S10,<br>20RS8, 20RS4 | Polarity fuse<br>blown | | | 30 | 45 | | 30 | 40 | ns | | t <sub>CLK</sub> | Clock to output | or feedback | Commercial | | 12 | 20 | | 12 | 17 | ns | | t <sub>PZX</sub> | Pin 13 to output<br>20S10 | enable except | $R_1 = 200\Omega$ $R_2 = 390K\Omega$ | | 10 | 25 | | 10 | 20 | ns | | t <sub>PXZ</sub> | Pin 13 to output<br>20S10 | disable except | | | 11 | 25 | | 11 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | 20S10, 20RS8,<br>20RS4 | | | 25 | 35 | | 25 | 35 | ns | | t <sub>PZX</sub> | Input to output disable | 20S10, 20RS8,<br>20RP4 | Military | | 13 | 30 | | 13 | 25 | ns | | f <sub>MAX</sub> | Maximum frequency | 20RS10,<br>20RS8, 20RS4 | $R_1 = 390\Omega$ $R_2 = 750\Omega$ | 18 | 28 | | 20 | 28 | | MHz | #### 20RS10 ## Large 24RA (PAL20RA10) Description The PAL20RA10 is a 24-pin registered asynchronous PAL device. This versatile device features programmable clock, enable, set, and reset, all of which can operate asynchronously to other flip-flops in the same device. It also has individual flop-flop bypass, allowing this one device to provide any combination of registered and combinatorial outputs. #### **Programmable Clock** The clock input to each flip-flop comes from the programmable array, allowing the flip-flops to be clocked independently if desired. #### **Programmable Set and Reset** Each flip-flop has a product line for asynchronous set and one product for asynchronous reset. If the chosen product line is high, the flip-flop will set (become a logic HIGH), or reset (become a logic LOW). The sense of the output pin is inverted if the output is active low. #### **Programmable Polarity** Each flip-flop has individually programmable polarity. The unprogrammed state is active low. #### **Programmable Flip-flop Bypass** If both the set and reset product lines are high, the flip-flop is bypassed and the output becomes combinatorial. Thus each output can be configured to be registered or combinatorial. ## Programmable and Hard-Wired Three-State Outputs The PAL20RA10 provides a product term dedicated to output control. There is also an output control pin (pin 13). The output is enabled if both the output control pin is low and the output control product term is high. If the output control pin is high all outputs will be disabled. If an output control product term is low, then that output will be disabled. #### Register Preload and Power-up Reset Each device also offers register preload for device testability. The registers can be preloaded from the outputs by using TTL level signals in order to simplify functional testing. This series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting the active-low outputs to a logic HIGH. #### **DIP Pinout** ### **PLCC Pinout** ## **Operating Conditions** | | | <u> 11</u> | | MILITARY | | | COMMERCIAL | | | | |------------------|-------------------------------------------|----------------------|-----|----------|-----|------|------------|------|------|--| | SYMBOL | PARAMETER | | | TYP | MAX | MIN | TYP | MAX | TINU | | | V <sub>CC</sub> | Supply voltage | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | | | 147.311 -2 -1 -1 | Low | 25 | 13 | | 20 | 13 | | | | | τ <sub>w</sub> | Width of clock High | | 25 | 13 | | 20 | 13 | | ns | | | t <sub>wp</sub> | Preload pulse width | | 45 | 15 | | 35 | 15 | | ns | | | t <sub>su</sub> | Setup time for input or feedback to clock | | 25 | 10 | | 20 | 10 | | ns | | | t <sub>sup</sub> | Preload setup time | | 30 | 5 | | 25 | 5 | | ns | | | | | Polarity fuse intact | 10 | -2 | | 10 | -2 | | | | | t <sub>h</sub> | Hold time | Polarity fuse blown | 0 | -6 | | 0 | -6 | | ns | | | t <sub>hp</sub> | Preload hold time | | 30 | 5 | | 25 | 5 | | ns | | | T <sub>A</sub> | Operating free-air temperature | | -55 | | | 0 | | 75 | °C | | | Τ <sub>C</sub> | Operating case temperature | | | | 125 | | | | °C | | #### Electrical Characteristics (Over Operating Conditions) | SYMBOL | PARAMETER | TEST CONDITION | | | TYP | MAX | UNIT | |------------------------------|------------------------------|-----------------------|----------------------------------------------|------|-------|-------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>1</sup> | High-level input voltage | | | 2 | | | V | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 2 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | -0.02 | -0.25 | mA | | l <sub>IH</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 2.4V | | | 25 | μΑ | | 4.50 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> : Mil-2mA Com-3.2mA | 2.4 | 2.8 | | ٧ | | l <sub>OZ</sub> <sup>2</sup> | Off-state output current | V <sub>CC</sub> = MAX | $V_{O} = 2.4 \text{ V/V}_{O} = 0.4 \text{V}$ | -100 | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | ar contains we contain | | 155 | 200 | mA | These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Switching Characteristics (Over Operating Conditions) | | | | TEST | N | MILITAR | Y | CO | MMERC | IAL | | |------------------|----------------------------------------|----------------------|--------------------|------|---------|-----|-----|-------|-----|------| | SYMBOL | PARA | METER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | | Input or | Polarity fuse intact | | | 20 | 35 | 20 | | 30 | | | t <sub>PD</sub> | feedback to output Polarity fuse blown | | | | 25 | 40 | | 25 | 35 | ns | | t <sub>CLK</sub> | Clock to output or feedback | | | 10 | 17 | 35 | 10 | 17 | 30 | ns | | t <sub>S</sub> | Input to asynchro | nous set | | | 22 | 40 | | 22 | 35 | ns | | t <sub>R</sub> | Input to asynchro | nous reset | $R_1 = 560\Omega$ | 1,14 | 27 | 45 | | 27 | 40 | ns | | t <sub>PZX</sub> | Pin 13 to output | enable | $R_2 = 1.1K\Omega$ | | 10 | 25 | | 10 - | 20 | ns | | t <sub>PXZ</sub> | Pin 13 to output | disable | | | 10 | 25 | | 10 | 20 | ns | | t <sub>PZX</sub> | Input to output enable | | | | 18 | 35 | | 18 | 30 | ns | | t <sub>PXZ</sub> | Input to output disable | | | | 15 | 35 | | 15 | 30 | ns | | f <sub>MAX</sub> | Maximum frequency | | | 16 | 35 | | 20 | 35 | | MHz | #### Features/Benefits - Dual independent feedback paths allow buried state registers or input registers - Programmable flip-flops allow J-K, S-R, T or D types for the most efficient use of product terms - 10 input/output macrocells for flexibility - Programmable registered or combinatorial outputs - Programmable output polarity - Global register asynchronous preset/synchronous reset or synchronous preset/asynchronous reset - Automatic register preset on power up - Preloadable output registers for testability - Varied product term distribution - -Up to 16 product terms per output - High speed - -25ns "A" version - -30ns standard version - Space-saving 24-pin 300-mil SKINNYDIP® package or 28pin chip carrier - Pin-compatible functional superset of 22V10 #### Pin Configurations **SKINNYDIP Package** Plastic Leaded Chip Carrier #### **Ordering Information** #### **General Description** The PAL32VX10 is a high-density Programmable Array Logic (PAL®) device which implements a sum-of-products transfer function via a user-programmable AND logic array and a fixed OR logic array. Featured are ten highly flexible input/output macrocells which are user-configurable for combinatorial or registered operation. Each flip-flop can be programmed to be either a J-K, S-R, T, or D-type for optimal design of state machines and other synchronous logic. In addition, a unique dual feedback architecture allows I/O capability for each macrocell in both combinatorial and registered configurations. This can be achieved even when register feedback is present, and allows implementation of buried flip-flops while preserving the external macrocell input. Supplied in space-saving 300-milwide dual in-line packages or 28-pin chip carriers, the PAL32VX10 offers a powerful, space saving alternative to SSI/MSI logic devices, while providing the advantage of instant prototyping. Security fuses defeat readout after programming and make proprietary designs difficult to copy. The PAL32VX10 is fabricated using Monolithic Memories' advanced oxide-isolated bipolar process for high speed and low power. TiW fuse links provide high reliability and programming yields. Special on-chip test circuits allow full AC, DC, and functional testing before programming. Preloadable output registers facilitate functional testing. The PAL32VX10 can be programmed on standard PAL device programmers, fitted with appropriate programming modules and configuration software. Design development is supported by Monolithic Memories' PALASM® 2 software as well as by other programmable logic CAD tools available from third party vendors. Approved development tools are listed on page 10. #### **Block Diagram** Note: PLCC pin numbers are indicated in parentheses. PLCC pins 1, 8, 15, and 22 are not connected. #### **Description of Architecture** The PAL32VX10 has twelve dedicated input lines and ten programmable I/O macrocells. Pin 1 serves either as an array input or as a clock for all flip-flops. Buffers for device inputs have complementary outputs to provide user-programmable input signal polarity. The fuse matrix implements a programmable AND logic array, which drives a fixed OR logic array. The high level of flexibility built into each macrocell, shown in Figure 1, allows the PAL32VX10 to implement over thirty different architecture options. Each macrocell can be individually programmed to implement a variety of combinatorial or registered logic functions. #### **Dual Output Feedback** Dual feedback paths associated with each macrocell provide independent feedback paths directly into the array from both the flip-flop output and the output pin. Unlike other devices which have a single feedback path, the PAL32VX10 allows each output to have full I/O capability when configured as either a combinatorial output or a registered output, even if register feedback to the array is used. Thus registers can be loaded from their outputs. If a macrocell is configured as a dedicated input, by disabling the three-state output buffer, the dual feedback architecture allows use of the associated register as an input register or as a "buried" state register, avoiding waste of the flip-flop, as shown in Figure 2. Figure 1. PAL32VX10 Macrocell Figure 2. Buried Flip-Flops with Dedicated Inputs #### Programmable Flip-Flops Each output macrocell contains a unique programmable flipflop consisting of a basic D-type flip-flop driven by an XOR gate. This allows the user to choose the optimal flip-flop for the design, since either J-K, S-R, or T-type flip-flops can be synthesized from such a structure without wasting product terms As indicated in the macrocell logic diagram, one input of the XOR gate is connected to a single product term, while the second input is connected to the output of the OR logic array. The XOR gate output feeds the input of the D flip-flop. The way in which the XOR gate is used to synthesize the different flip-flop types is described in detail below. **D Flip-Flop.** The D flip-flop option is implemented directly. In this configuration, the XOR gate on the input of the flip-flop can be used to program the logic polarity of the transfer function. **J-K Flip-Flop.** The J-K flip-flop option can be easily synthesized with a more sophisticated manipulation of the XOR gate inputs and the D flip-flop output. The transfer function of a J-K flip-flop can be mapped in the Karnaugh Map of Figure 3, where Q + represents the next state of the flip-flop: Figure 3. J-K Flip-Flop Transfer Function Dropping the ( $\pm$ ) for simplicity, the equivalent Boolean expression for Q $\pm$ is: $$Q: = \overline{K}^*Q + J^*\overline{Q}$$ In general, J and K can be sum-of-product expressions which are provided in the PAL architecture only in active-high form. Thus, a direct implementation of $\overline{K}$ expressions must invoke a DeMorgan transformation, which can use excessive product terms. This can be avoided by rewriting the equation for Q without inversions on the J or K inputs. The XOR gate can be used to construct a logically equivalent expression without any inversions on the J or K inputs. The rewritten Boolean expression is: $$Q: = Q: + :(J^*\overline{Q} + K^*Q)$$ To check that these expressions are logically equivalent, change the XOR to its equivalent sum of products form (remember A: +: B = A\* $\overline{B}$ + $\overline{A}$ \*B) and reduce (using DeMorgan's theorem): $$\begin{array}{lll} Q:=Q^*(J^*\overline{Q}+K^*Q) & +\overline{Q}^*(J^*\overline{Q}+K^*Q)\\ Q:=Q^*((\overline{J}+Q)^*(\overline{K}+\overline{Q})) & +\overline{Q}^*J^*\overline{Q}+\overline{Q}^*K^*Q\\ Q:=Q^*(\overline{J}^*\overline{K}+\overline{J}^*\overline{Q}+Q^*\overline{K}+Q^*\overline{Q})+J^*\overline{Q}\\ Q:=\overline{J}^*\overline{K}^*Q+\overline{K}^*Q+J^*\overline{Q}\\ \text{which simplifies to} & Q:=\overline{K}^*Q+J^*\overline{Q}. \end{array}$$ Since J and K are, in general, sums of products, J and K in either expression can be substituted with (J1 + J2 + ... + Jm) and (K1 + K2 + ... + Kn – m), where n is the total number of product terms associated with a given output macrocell. Thus, the total n-product term resource is shared between the J and K control inputs (Figure 4). Note that all J terms will contain $\overline{\Omega}$ and all K terms will contain $\Omega$ . Figure 4. J-K Flip-Flop Logic Equivalent; J and K Can Also be Active-Low The above discussions have assumed that it was most convenient to "group ones" in the Karnaugh Map. Sometimes it takes fewer product terms to "group zeros", i.e., implement the inversion of the desired function. The equations shown in Table 1 are equivalent and can be interchanged to optimize product term utilization. This can be readily proved through logic reductions similar to that above. | J and K active high | $Q: = Q: + : (J^*\overline{Q} + J^*Q)$ | |-----------------------------|-------------------------------------------------------------------------| | J active high, K active low | $Q:=J^*\overline{Q}+\overline{K}^*Q$ | | J active low, K active high | $\overline{Q}$ : = $\overline{J}^*\overline{Q}$ + K*Q | | J and K active low | $Q: = \overline{Q}: + : (\overline{J}^*\overline{Q} + \overline{K}^*Q)$ | Note: J = sum of products J1 + J2 + ... + Jm K = sum of products K1 + K2 + ... + Kn - m n = total number of available product terms for a given macrocell (8 to 16) Table 1. J-K Flip-Flop Transfer Functions **S-R Flip-Flop.** The S-R flip-flop has a truth table identical to that of the J-K flip-flop, with the exception that the J=K=1 (toggle) condition is not allowed. The S-R flip-flop implementation is identical to that of the J-K flip-flop, with J-K replaced by S-R, and the S=R=1 condition avoided. **T Flip-Flop.** A T (toggle) flip-flop either holds its state or toggles, depending on the logic state of the T input. The T flip-flop is a subset of the J-K flip-flop and can be considered equivalent to a J-K type with J=K. The general transfer function and its active-low T equivalent are both given in Table 2. $$Q: = Q: + :T$$ $$Q: = \overline{Q}: + :\overline{T}$$ Note: T = sum of products T1 + T2 + T3 + ... + Tn Table 2. T Flip-Flop Transfer Functions ## High Speed Programmable Array Logic PAL32VX10, PAL32VX10A #### Summary The PAL32VX10 can synthesize J-K, S-R, T, and D flip-flops, whichever is most convenient for the application, without sacrificing product terms. Additionally, the synthesized equations can use the active-high or active-low forms of the inputs, allowing the designer to minimize product term requirements. #### Flip-Flop Bypass Any output in the PAL32VX10 can be configured to be combinatorial by bypassing the output flip-flop. This is done by setting the output multiplexer to the appropriate state. The multiplexer is controlled by a product term which can be set unconditionally for a permanent combinatorial (all fuses opened, product term high) or registered (all fuses intact, product term low) output configuration, or can be programmed to bypass the output flip-flop "on the fly," allowing signals to be routed directly to output pins under user-specified conditions. #### **Varied Product Term Distribution** An increased number of product terms has been provided in the PAL32VX10 over previous generation PAL devices. These terms are distributed among the ten macrocells in a varied manner, ranging from eight to sixteen terms per output. The five output pairs have 8, 10, 12, 14, or 16 product terms available for the OR gate within each macrocell. In addition, each macrocell has one XOR product term and two architecture control product terms. #### Programmable I/O Each macrocell has a three-state output buffer with programmable three-state control. Control is implemented by a single product term, allowing specification of enable/disable functions controlled by any device input or output. Each macrocell can be configured as a dedicated input by disabling the buffer drive capability. When this is done, the associated register can still be used as an input register or buried state register, due to the independent register feedback path. #### **Programmable Preset and Reset** The ten macrocell flip-flops share common programmable preset and reset control for easy system initialization. The Q outputs of the register will go to the logic low state following a low-to-high transition on pin 1 (I0/CLK) when the synchronous reset (SR) product term is asserted. The register will be forced to the logic high state independent of the clock when the asynchronous preset (AP) product term is asserted. #### **Programmable Polarity** The polarity of each macrocell output can be set active high or active low. Combinatorial Outputs. The XOR gate provides polarity control for combinatorial outputs, with the single product term to the XOR gate controlling the invert/not invert function. With all fuses intact, there is no inversion through the XOR gate, creating an active low output. Opening all fuses forces the product term high, inverting data and creating an active high output. Registered Outputs. Output polarity for registered outputs can be determined in two ways. For D-type registered outputs, polarity can be set by the XOR gate, as is the case with combinatorial outputs. Using this method to set polarity, preset and reset will not be affected. Polarity, as observed from the output pin, can also be determined by the flip-flop output multiplexer. Note that this does not affect the polarity of the register feedback signal, but does affect preset and reset. By changing the flip-flop output multiplexer, the preset and reset functions are exchanged, relative to the controlling product terms. With the multiplexer fuse intact, the Q output is routed to the output pin, configuring an active low output. With the multiplexer fuse opened, $\overline{\mathbf{Q}}$ is routed to the output pin, and synchronous reset becomes synchronous preset. Similarly, asynchronous reset becomes asynchronous preset. Polarity options for J-K, S-R, and T flip-flops have been discussed in the section on programmable flip-flops. #### **Power-Up Preset** All flip-flops power up to a logic high for predictable system initialization. Outputs of the PAL32VX10 will be high or low depending on the state of the register output multiplexers. #### Register Preload The register on the PAL32VX10 can be preloaded to facilitate functional testing of complex state machine designs. This feature allows direct loading of arbitrary states, thereby making it unnecessary to cycle through long test vector sequences to reach a desired state. In addition, transitions from illegal states can be verified by loading in illegal states and observing proper recovery. #### **Security Fuse** After programming and verification, a PAL32VX10 design can be secured by programming the security fuses. Once programmed, these fuses defeat readback of the internal fuse pattern by a device programmer, making proprietary designs very difficult to copy. #### **Quality and Testability** The PAL32VX10 offers a very high level of built-in quality. Special on-chip test circuitry provides a means of verifying performance of all AC and DC parameters prior to programming. In addition, these built-in test paths verify complete functionality of each device to provide the highest post-programming functional yields in the industry. ## High Speed Programmable Array Logic PAL32VX10, PAL32VX10A #### Absolute Maximum Ratings | and the could be a controlled the country of co | Operating Programming | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | Supply voltage V <sub>CC</sub> | -0.5V to 7V -0.5V to 12V | | Input voltage | 1.5V to 5.5V1.0V to 22V | | Off-state output voltage | 5.5V 12V | | Storage temperature | −65°C to +150°C | #### Operating Conditions | | | | | | СОММЕ | RCIAL | r a ays | | | |---------------------------------|----------------------------------|---------------------------------------------------|------|-----|-------|-------|---------|------------------------------|------| | SYMBOL | PARAMETER | | | STD | | | A | ejaka kupat 19.<br>Masa hari | UNIT | | gerwij bered | | | | TYP | MAX | MIN | TYP | MAX | | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | ν | | t <sub>w</sub> Width of clock - | | Low | 20 | 10 | ye. s | 18 | 10 | a dia s | | | | | High | 20 | 10 | | 18 | 10 | | ns | | | Setup time from input | Product terms P <sub>1</sub> -P <sub>n</sub> , SR | 30 | 20 | | 25 | 20 | | 1.5 | | t <sub>su</sub> | or feedback to clock | Product term XOR | 35 | 25 | | 30 | 25 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | t <sub>aw</sub> | Asynchronous preset with | dth | -30 | 20 | | 25 | 20 | | ns | | t <sub>ar</sub> | Asynchronous preset re- | covery time | -30 | 20 | | 25 | 20 | | ns | | t <sub>sr</sub> | Asynchronous reset recovery time | | | 20 | | 25 | 20 | | ns | | TA | Operating case temperature | | | 25 | 75 | 0 | 25 | 75 | °C | #### Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TEST | CONDITION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-------------------------------------|--------------------------|------------------|------------------------------------------|------------|------| | V <sub>IL</sub> 2 | Low-level input voltage | | | | 3 S. S. S. S. | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | CONTRACTOR OF | -0.8 | -1.5 | ٧٠ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | l <sub>IH</sub> 3 | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | 1 | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | 1 11 10 10 10 10 10 10 10 10 10 10 10 10 | 200 | μΑ | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 16mA | | 0.35 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | l <sub>OH</sub> = -3,2mA | 2.4 | 3.4 | 197 - 1947 | ٧ | | l <sub>OZL</sub> <sup>3</sup> | | | $V_0 = 0.4V$ | 0.744 | . 3g s. | -100 | μΑ | | I <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | V <sub>O</sub> = 2.4V | 100 | 164 | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -30 | -70 | -130 | mA | | lcc | Supply current | V <sub>CC</sub> = MAX | | CMILE<br>I DATE: | 140 | 180 | mA | | C <sub>IN</sub> | Input capacitance | V <sub>IN</sub> = 2.0V at f = | 1MHz | | 6 | | pF | | C <sub>OUT</sub> | Output capacitance | V <sub>OUT</sub> = 2.0V at f = 1MHz | | | 11 | | Pi | <sup>1.</sup> The PAL32VX10/A is designed to operate over the full military operating conditions. For availability and specifications contact Monolithic Memories. <sup>2.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and or tester noise. Do not attempt to test these values without suitable equipment. <sup>3.</sup> I/O pin leakage is the worst case of $\rm I_{IL}$ and $\rm I_{OZL}$ (or $\rm I_{IH}$ and $\rm I_{OZH}$ ). <sup>4.</sup> No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### High Speed Programmable Array Logic PAL32VX10, PAL32VX10A #### Switching Characteristics Over Operating Conditions | | | | | TEST | | STD | | | Α | | | |------------------|--------------|----------------------------------------------------------------|----------------------------------------------|-------------------|------|-----|-----|------|-----|------|------| | SYMBOL | PARAMETER | | CONDITION | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | | | Input or fee | edback to | Product terms P <sub>1</sub> -P <sub>n</sub> | | 15 | 30 | | 15 | 25 | | | | t <sub>PD</sub> | output | SUDACK TO | Product term XOR | | | 25 | 35 | | 20 | 30 | ns | | t <sub>CLK</sub> | Clock to ou | tput or feedb | ack | | | 10 | 15 | | 10 | 15 | ns | | t <sub>PZX</sub> | Input to ou | tput enable | | | 20 | 30 | | 20 | 25 | ns | | | t <sub>PXZ</sub> | Input to ou | ut to output disable | | $R_1 = 200\Omega$ | | 20 | 30 | | 20 | 25 | ns | | t <sub>AP</sub> | Asynchrono | | | $R_2 = 390\Omega$ | | 20 | 30 | | 20 | 25 | ns | | t <sub>CR</sub> | | edback to reg<br>natorial confi | istered output<br>guration | | | 75 | 90 | | 75 | 90 | ns | | t <sub>RC</sub> | | t or feedback to combinatorial output registered configuration | | | | 75 | 90 | | 75 | 90 | ns | | | Maximum | Feedback | Product terms P <sub>1</sub> -P <sub>0</sub> | | 22.5 | 35 | | 25 | 35 | | | | f <sub>MAX</sub> | frequency | (1/t <sub>P1</sub> ) | Product term XOR | | 20 | 30 | | 22.2 | 30 | | MHz | | | | No feedbac | ck (1/t <sub>P2</sub> ) | | 25 | 40 | | 27.7 | 40 | | 5V ] | ### **Switching Test Load** ### Schematic of Inputs and Outputs - Notes: 1. t<sub>PD</sub> is tested with switch S<sub>1</sub> closed. C<sub>L</sub> = 50pF and measured at 1.5V output level. 2. t<sub>PZX</sub> is measured at the 1.5V output level with C<sub>L</sub> = 50pF. S<sub>1</sub> is open for high impedance to "1" test, and closed for high impedance to "0" test. 3. t<sub>PXZ</sub> is tested with C<sub>L</sub> = 5pF. S<sub>1</sub> is open for "1" to high impedance test, measured at V<sub>OH</sub> -0.5V output level; S<sub>1</sub> is closed for "0" to high impedance test measured at V<sub>OL</sub> +0.5V output level. #### **Switching Waveforms** ### **Output Register Preload** The preload function allows the register to be loaded from the output pins. This feature aids functional testing of sequential designs by allowing direct setting of output states. The procedure is: - 1. Raise V<sub>CC</sub> to 4.5V. - 2. Disable output registers by setting pin 2 to $V_{\rm IHH}(12V)$ . - Apply V<sub>IL</sub>/V<sub>IH</sub> to all registered output pins. Leave combinatorial outputs floating. - 4. Pulse pin 10 to $V_{IHH}$ , then back to 0V. - 5. Remove V<sub>IL</sub>/V<sub>IH</sub> from all output registers. - 6. Remove high voltage from pin 2. - 7. Enable registered outputs per programmed pattern. - 8. Verify for $V_{OL}/V_{OH}$ at all registered output pins. Note: $V_{IHH}$ = 11.0 (MIN), 11.5 (TYP) and 12.0 (MAX). ### **Key to Timing Diagrams** | WAVEFORM | INPUTS | OUTPUTS | |--------------------|---------------------------------|----------------------------------------| | <b>XXXXXXXXXXX</b> | DON'T CARE;<br>CHANGE PERMITTED | CHANGING;<br>STATE UNKNOWN | | <b>&gt;&gt;</b> -≪ | NOT<br>APPLICABLE | CENTER LINE IS<br>HIGH IMPEDANCE STATE | | | MUST BE STEADY | WILL BE STEADY | ## High Speed Programmable Array Logic PAL32VX10, PAL32VX10A #### **f**<sub>MAX</sub> Parameters The parameter fMAX is the maximum speed at which the PAL device is guaranteed to operate. Because flexibility inherent to PAL devices allows a choice of clocked flip-flop designs, for the convenience of the user, fMAX is specified to address two major classes of synchronous designs. The simplest type of synchronous design can be described as a data path application. In this case, data is presented to the data terminal of the flip-flop and clocked through; no feedback is employed (Figure 1). Under these conditions, the frequency of operation is limited by the greater of the data setup time (tsu) or the minimum clock period (tw high + tw low, or tP2). This parameter is designated fMAX (no feedback). For synchronous sequential designs, i.e., state machines, where logical feedback is required, inputs to flip-flop data terminals originate from the device input pins or flip-flop outputs via the internal feedback paths (Figure 2). Under these conditions, fMAX is defined as the reciprocal of (tsu + tCLK), or tP1, and is designated fMAX (feedback). Figure 1. Data Path Register Configuration Without Feedback, Q: = I LD01070M Figure 2. State Machine Configuration With Feedback, $Q: = I + \overline{Q}$ 001080M #### Use of XOR Product Term The speed of the PAL32VX10 is specified according to the use of the Exclusive-OR (XOR) product term in the macrocell. Note that the macrocell data input is a function of the two-input XOR gate, whose inputs are the OR of the product terms P1-Pn and the single additional XOR product term (Figure 3). The specification for the path through the single XOR product term is 5ns slower than through the P1-Pn product terms and the OR gate. As a result, if the single XOR product term is changing, the macrocell data input will not be available until 5ns later than if only the P1-Pn product terms were changing. This difference between paths affects tPD, tsu, and fMAX (feedback). As a result, these three parameters are specified both for only the P1-Pn product terms changing ("Product terms P1-Pn") and with the single XOR product term changing ("Product term XOR") (Figure 4). Figure 3. | SPECIFIC | ATION | EXPLANATION | |-----------------------------------------------------------------|---------------------|-------------------------------------------------------------------------| | t <sub>PD</sub> , t <sub>su</sub> , f <sub>MAX</sub> (feedback) | Product terms P1-Pn | If only the P1-Pn product terms are changing (XOR term is not changing) | | TPD, tsu, TMAX (Teedback) | Product term XOR | If XOR term is changing | Figure 4. # High Speed Programmable Array Logic PAL32VX10, PAL32VX10A | MANUFACTURER | PROGRAMMER CONFIGURATION | | | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--| | Data I/O Corp.<br>10525 Willows Rd. NE, PO Box 97046<br>Redmond, WA 98073-9746<br>(800) 247-5700 | System 29A, 29B Family/Pinout Code:<br>LogicPak <sup>TM</sup> 303A<br>Adapter 303A-011A/B-V01 22-77 | | | | | | | Digelec Inc.<br>1602 Lawrence Ave., Suite 113<br>Ocean, NJ 07712<br>(201) 493-2420 | Contact manufacturer | | | | | | | Digital Media<br>11770 East Warner Ave., Suite 225<br>Fountain Valley, CA 92708<br>(714) 751-1373 | Contact manufacturer | | | | | | | Japan Macnics Corp.<br>2999 Monterey/Salinas Hwy.<br>Monterey, CA 93940<br>(408) 373-3607 | Contact manufacturer | | | | | | | Kontron Electronics Inc.<br>1230 Charleston Rd.<br>Mountain View, CA 94039-7230<br>(415) 965-7020 | System EPP-80<br>Module UPM-B rev. 1.48 or later | | | | | | | Micropross<br>Parc d'activite des Pres<br>5, rue Denis-Papin<br>59650 Villeneuve-d'Ascq<br>(20) 47.90.40 | Contact manufacturer | | | | | | | Stag Microsystems Inc.<br>528-5 Weddell Dr.<br>Sunnyvale, CA 94089<br>(408) 745-1991 | Contact manufacturer | | | | | | | Storey Systems<br>3201 N. Hwy 67, Suite H<br>Mesquite, TX 75150<br>(214) 270-4135 | Contact manufacturer | | | | | | | Structured Design<br>988 Bryant Way<br>Sunnyvale, CA 94087<br>(408) 988-0725 | Contact manufacturer | | | | | | | Valley Data Sciences<br>Charleston Business Park<br>2426 Charleston Rd.<br>Mountain View, CA 94043<br>(415) 968-2900 | Contact manufacturer | | | | | | | Varix Corp.<br>1210 E. Campbell Rd., Suite 100<br>Richardson, TX 75081<br>(214) 437-0777 | Contact manufacturer | | | | | | | MANUFACTURER | SOFTWARE DEVELOPMENT SYSTEM | | | | | | | Monolithic Memories, Inc.<br>IdeaLogic® Exchange M/S 09-25<br>2175 Mission College Blvd.<br>Santa Clara, CA 95054-1592<br>(800) 247-6527 ext. 6105 | PALASM® 2 Software rev. 2.21 and later | | | | | | | Data I/O Corp.<br>10525 Willows Rd. NE, PO Box 97046<br>Redmond, WA 90873-9746<br>(800) 247-5700 | ABEL <sup>TM</sup> Software — Contact manufacturer | | | | | | | Personal CAD Systems<br>Assisted Technology Division<br>1290 Parkmoor Ave.<br>San Jose, CA 95126<br>(408) 971-1300 | CUPL <sup>TM</sup> Software — Contact manufacturer | | | | | | IdeaLogic is a trademark of Monolithic Memories. LogicPak and ABEL are trademarks of Data I/O Corporation. CUPL is a trademark of Personal CAD Systems. #### Features/Benefits - User-programmable synchronous state machine - 25MHz maximum frequency for compatibility with 12.5MHz processors - 14 inputs (8 external), 8 outputs, 128 states - PAL® array optimizes product terms and states - Internal feedback adds versatility and control - Optimized for four-way branching - User-selectable asynchronous preset or asynchronous enable function - Power-up preset for start-up in known state - Diagnostics-On-Chip<sup>TM</sup> shadow register eases chip and board-level testing - PROSE<sup>TM</sup> device software makes it easy to "write your sequencer in PROSE" - Programmed on standard logic programmers - Security fuse prevents pattern duplication - Space-saving 24-pin 300-mil SKINNYDIP® and 28-pin PLCC and LCC packages #### Description The PMS14R21 programmable sequencer is the first member of the PROSE (PROgrammable SEquencer) family. The PMS14R21 is a high-speed, 14-input, 8-output state machine. It consists of a 128x21 PROM array preceded by a 14H2 PAL array. The PAL array is efficient for a large number of input conditions, while the PROM array is optimal for a large number of product terms and states. The combination allows a very efficient state machine with a large number of inputs and state bits. The PAL array, with eight product terms per output, operates on the eight conditional and six state inputs to select two control bits to the PROM. Two Exclusive-OR gates between the two arrays help to minimize product terms and redundant states. Five lines feed back from the PROM to form the primary address for the next state. The PROM stores up to 128 states of eight outputs and thirteen feedback control signals. #### **Applications** - High speed sequential logic - Peripheral controller - Cache control sequencer - Signal processing sequencer - Industrial control #### **Block Diagram** #### **Definition of Signals** 10-17 Q0-Q7 P/E Primary inputs to the PAL array Outputs from the register Programmable asynchronous preset (P) or asynchronous enable (E) CLK DCLK MODE SDI SDO Clock for output register Clock for diagnostic register Selects diagnostic functions Serial data input to shadow register Serial data output from shadow register PROSE<sup>TM</sup> and Diagnostics-On-Chip<sup>TM</sup> are trademarks of Monolithic Memories, Inc. ## PROSE Part Numbering System PMS 14 R 21 A C NS STD #### **Diagnostics-On-Chip Feature** The PMS14R21 is the newest member of the Diagnostics-On-Chip family. These devices incorporate a serial shadow register on-chip which facilitates board-level testing. The shadow register has a Serial Data Input (SDI), Serial Data Output (SDO) and its own clock (DCLK). The MODE control configures the shadow register either in parallel with the output register or in serial shift mode (see function table). Other devices with this feature are listed below. #### **Diagnostics Family Members** | PART<br>NUMBER | DESCRIPTION | |----------------|-------------------------------------| | 53/63DA441 | 1K x 4 PROM (async. enables) | | 53/63DA442 | 1K x 4 PROM (async/sync. enables) | | 53/63DA841 | 2K x 4 PROM | | 53/63D1641 | 4K x 4 PROM (async. enable) | | 53/63DA1643 | 4K x 4 PROM (async. initialization) | | 54/74S818 | 8-bit register | #### **Software Support** PROSE device software from Monolithic Memories provides full support for the PMS14R21. Based on PALASM®2 syntax, the software automatically converts a state machine description directly into the PAL and PROM array fuse maps, for downloading to a programmer. The syntax supports both Mealy and Moore state machine models, and makes optimal use of the features of the PROSE device. Simulation support is also provided, both for design checking and for generation of test vectors for device testing. Additional support is available from third-party software vendors, including the ABEL<sup>TM</sup> package from Data I/O. #### **Programming** Both the PAL and PROM arrays are programmed on standard logic programmers using the JEDEC programming format. The TiW fuses program from the low to the high state. Programming also sets the architectural fuse which selects between asynchronous preset or asynchronous output enable; the unprogrammed state is preset. If asynchronous preset is selected, asserting the pin low will set all outputs and feedback bits high. #### **Power-up Preset** Power-up preset is provided for system start-up in a known state. It has the same effect as preset; all output register bits go high. #### **Diagnostic Function Table** | | INP | UTS | | 01 | UTPUTS | | | |------|-----|-----|------|----------------------------------|-----------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------| | MODE | SDI | CLK | DCLK | Q <sub>20</sub> - Q <sub>0</sub> | S <sub>20</sub> - S <sub>0</sub> | SDO | OPERATION | | L | Х | 1 | * | $Q_n \leftarrow PROM$ | HOLD | S <sub>20</sub> | Load output register from PROM array | | L | х | • | 1 | HOLD | $\begin{array}{c} S_n \leftarrow S_{n-1} \\ S_0 \leftarrow SDI \end{array}$ | S <sub>20</sub> | Shift shadow register data | | L | X | 1 | 1 | Q <sub>n</sub> ← PROM | $S_n \leftarrow S_{n-1}$<br>$S_0 \leftarrow SDI$ | S <sub>20</sub> | Load output register from PROM array while shifting shadow register data | | Н | Х | 1 | • | $Q_n \leftarrow S_n$ | HOLD | SDI | Load output register from shadow register | | Н | L | • | 1 | HOLD | $s_n \leftarrow Q_n$ | SDI | Load shadow register from output bus and feedback | | Н | Н | | 1 | HOLD | HOLD | SDI | † No operation | Clock must be steady or falling. <sup>†</sup> Reserved operation for 54/74S818 8-Bit Diagnostic Register. ## 2 #### Features/Benefits - 20 logic inputs: 12 external, 8 feedback - 8 outputs with programmable polarity - ECL technology for ultra-high speed max tpD = 6ns - 32 product terms with term sharing - 10KH ECL compatible - Fully AC tested - Input pull-down resistors - Voltage compensated - Space-saving 24-pin SKINNYDIP® and 28-pin PLCC packages - Programmable using standard TTL programmers with adapter - Greater than 99% programming yield - Security fuse prevents unauthorized copying ### Description The PAL10H20P8 is a 10KH family compatible ECL PAL device having twelve dedicated inputs and eight outputs with feedback. A programmable AND array and a fixed OR array make possible the implementation of a wide variety of logic functions with far fewer packages than with SSI devices. The logic is implemented by opening metal fuse connections within the AND array. Designs can be specified by using any of a variety of software packages which accept the design and assemble a file that can be downloaded into a device programmer. Fuses are programmed using any of the qualified PAL device programmers. The outputs are equipped with programmable polarity. They can drive a $50\Omega$ termination (to $V_{CC}$ – 2.0V). Product term sharing is provided to allow greater flexibility in assigning product terms to outputs. The input pins have $50k\Omega$ internal pull-down resistors, which allow unused inputs to be left open. Open inputs will assume a logic low state. #### **Features** Each output has a programmable polarity fuse, allowing for more efficient representation of many logic functions. Each output is active high with polarity fuse intact, and active low with the polarity fuse blown. The programmable AND array contains a total of thirty-two product terms. Product terms are arranged in groups of eight. The terms in each group can be shared mutually exclusively between two adjacent output cells. If a particular product term is needed for two outputs, then two identical product terms are generated: one for each output. A security fuse is provided to help protect the fuse pattern from unauthorized copying. Once the security fuse has been programmed, it is no longer possible to verify the contents of the fuse array electrically. The security fuse has no effect on functionality. #### **DIP Pinout** #### **PLCC Pinout** #### **Absolute Maximum Ratings** medically conti These ratings specify the conditions above which the device may be permanently damaged. AC and DC specifications are not necessarily guaranteed over this range. | Supply voltage V <sub>EE</sub> (V <sub>CC1</sub> = | $= V_{CC2} = V_{CC3} = 0V$ | /) | <br> | 8.0V to 0V | |-----------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------| | Input voltage V <sub>1</sub> (V <sub>CC1</sub> = V <sub>C</sub> | $_{\sim 2} = V_{\sim 2} = 0V)$ | | <br> | 0V to V <sub>EE</sub> | | Output current, IOUT | JO2 CO3 / | | | | | Continuous | | | | 35mA | | Surge | Av. 1 11 | | | 100mA | | Storage temperature range | | and the second control of | | 65°C to 150°C | | o to tage to the orallation taking o | , stg | | | | ## Operating Conditions | | | со | MMERC | IAL | | |-----------------|---------------------------------------|-------|-------|-------|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | UNIT | | V <sub>EE</sub> | Supply voltage (V <sub>CC</sub> = 0V) | -5.46 | -5.2 | -4.94 | ٧ | | TA | Operating free-air temperature | 0 | | 75 | °C | ## Electrical Characteristics $v_{EE} = -5.2V \pm 5\%$ (See note 1) | SYMBOL | | TEST | 0°C | | 25°C | | 75°C | | | |------------------|----------------------|-------------------------------------------------------------|-------|-------|-------|-------|-------|--------|-----------------| | | PARAMETER | CONDITIONS | MIN | MAX | MIN | MAX | MIN | MAX | UNIT | | I <sub>EE</sub> | Power supply current | Inputs V <sub>IN</sub> = V <sub>IH</sub> Max | - | 210 | | 210 | + | 210 | mA | | l <sub>inH</sub> | Input current high | V <sub>IH</sub> Min < V <sub>in</sub> < V <sub>IH</sub> Max | - | 425 | - | 265 | - 1 | 265 | μΑ | | l <sub>inL</sub> | Input current low | V <sub>IL</sub> Min < V <sub>in</sub> < V <sub>IL</sub> Max | 0.5 | - | 0.5 | - | 0.3 | - | μΑ | | V <sub>OH</sub> | High output voltage | (See Note 2) | -1.02 | -0.84 | -0.98 | -0.81 | -0.92 | -0.735 | V <sub>dc</sub> | | V <sub>OL</sub> | Low output voltage | (See Note 2) | -1.95 | -1.63 | -1.95 | -1.63 | -1.95 | -1.60 | V <sub>dc</sub> | | V <sub>IH</sub> | High input voltage | (See Note 2) | -1.17 | -0.84 | -1.13 | -0.81 | -1.07 | -0.735 | V <sub>dc</sub> | | V <sub>IL</sub> | Low input voltage | (See Note 2) | -1.95 | -1.48 | -1.95 | -1.48 | -1.95 | -1.45 | V <sub>dc</sub> | #### Switching Characteristics V<sub>FF</sub> = -5.2V ± 5% (See note 2) | SYMBOL | | 0°C | | 25°C | | 75°C | | | |-----------------|---------------------|-----|-----|------|-----|------|-----|------| | SYMBOL | PARAMETER | MIN | MAX | MIN | MAX | MIN | MAX | UNIT | | t <sub>PD</sub> | Propagation delay | 2.0 | 6.0 | 2.0 | 6.0 | 2.0 | 6.0 | ns | | t <sub>R</sub> | Rise time (20%-80%) | 0.7 | 2.2 | 0.7 | 2.0 | 0.7 | 2.2 | ns | | t <sub>F</sub> | Fall time (80%-20%) | 0.7 | 2.2 | 0.7 | 2.0 | 0.7 | 2.2 | ns | Note: - 1. Each ECL 10KH series circuit has been designed to meet the specifications shown in test table after thermal equilibrium has been established. The circuit is in test socket or mounted on a printed board and transverse air flow greater than 500 linear fpm is maintained. - Outputs are terminated through a 50Ω resistor to V<sub>CC</sub> 2.0V. Discrete carbon resistors should be used for terminations. Multiple-resistor packs and metal film discrete resistors are inductive and should be avoided. The single-ended nature of the outputs demands strict adherence to ground and termination plane design techniques. - 3. If pin 13 (PLCC pin 16) is not used, it should be left open or terminated to V<sub>TT</sub> ( = V<sub>CC</sub> 2.0V). It should not be terminated to V<sub>EE</sub>. ### Logic Diagram #### MegaPAL Devices | | | ARRAY INPUTS | REGISTERED OUTPUTS | t <sub>PD</sub><br>(ns) | I <sub>CC</sub><br>(mA) | |----------------------|--|--------------|--------------------|-------------------------|-------------------------| | PAL32R16<br>PAL64R32 | | 32<br>64 | 16<br>32 | 40<br>50 | 280<br>640 | #### Description The MegaPAL Devices offer very high density programmable logic. #### **Programmable Polarity** Each flip-flop has individually programmable polarity. The unprogrammed state is active low. #### **Product Term Sharing** Product term sharing allows each pair of outputs to share its product terms with one output or the other (not both). Each pair has a total of sixteen product terms; thus, one output can use zero to sixteen terms while the other has sixteen to zero. Product terms can only be shared mutually exclusively. If both outputs need the same term, it must be created twice, once for each output. #### **Register Bypass** Registers in either device can be bypassed in banks of eight, creating a set of combinatorial outputs. #### Reset The PAL64R32 also features asynchronous reset (previously called preset). The reset function sets a bank of eight registers to a logic LOW, setting the output HIGH if active low. #### Register Preload and Power-up Reset Both devices also offer register preload for device testability. The registers can be preloaded from the outputs by using TTL level signals in order to simplify functional testing. This series also offers Power-up Reset, whereby the registers power up to a logic LOW, setting active-low outputs to a logic HIGH. ## **Testing Conditions** | | | СО | | | | |------------------|----------------------|-----|-----|-----|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | UNIT | | t <sub>wp</sub> | Preload pulse width | 35 | 2 | | ns | | t <sub>sup</sub> | Preload setup time | 50 | | | ns | | t <sub>hp</sub> | Preload hold time | 5 | | | ns | | t <sub>PRW</sub> | Preset pulse width | 25 | | | ns | | t <sub>PRR</sub> | Preset recovery time | 35 | | | ns | ### **Operating Conditions** | SYMBOL | | | | <b>ILITAR</b> | Υ | COMMERCIAL | | | | |-------------------------------|---------------------------------|----------------------|-----|----------------|-----|------------|--------|------|------| | SYMBOL | PARAMET | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | 1 Width of alask | | Low | 25 | | 5/4 | 20 | DATE: | | | | t <sub>w</sub> Width of clock | High | 25 | | -Spr | 20 | 12.20 | | ns | | | t <sub>wp</sub> | Preload pulse width | | 45 | | | 35 | har et | | ns | | | Catus time the insult to alcale | Polarity fuse intact | 50 | | | 40 | | | | | <sup>L</sup> su | Setup time for input to clock | Polarity fuse blown | 50 | 4.120 - 1.12 V | | 40 | | | ns | | t <sub>sup</sub> | Preload setup time | | 30 | | | 25 | | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | t <sub>hp</sub> | Preload hold time | | 10 | | | 5 | | | ns | | TA | Operating free-air temperature | | -55 | | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | 125 | | | | °C | ### Electrical Characteristics (Over Operating Conditions) | SYMBOL | PARAMETER | <b>∤</b> | EST CONDITION | MIN | TYP | MAX | UNIT | |-------------------------------|------------------------------|-----------------------|-------------------------------|-----|-------|-------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | | | 0.8 | > | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | | | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> <sup>2</sup> | Low-level input current | V <sub>CC</sub> = MAX | $V_{l} = 0.4V$ | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>2</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 2.4V | | | 25 | μΑ | | l <sub>i</sub> | Maximum input current | V <sub>CC</sub> = MAX | $V_1 = 5.5V$ | | | 1 | mA | | | | N/ - MINI | Mil I <sub>OL</sub> = 8mA | | 0.0 | 0.5 | V | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OL</sub> = 8mA | 1 | 0.3 | 0.5 | | | | | | Mil I <sub>OH</sub> = -2mA | | 0.0 | | ., | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com $I_{OH} = -3.2 \text{mA}$ | 2.4 | 2.8 | | ٧ | | l <sub>OZL</sub> <sup>2</sup> | 0" | V 844V | V <sub>O</sub> = 0.4V | | | -100 | μΑ | | l <sub>OZH</sub> <sup>2</sup> | Off-state output current | $V_{CC} = MAX$ | V <sub>O</sub> = 2.4V | | | 100 | μΑ | | los <sup>3</sup> | Output short-circuit current | V <sub>CC</sub> = MAX | $V_O = 0V$ | -30 | -70 | -130 | mA | | I <sub>CC</sub> | Supply current | V <sub>CC</sub> = MAX | | | 200 | 280 | mA | ### Switching Characteristics (Over Operating Conditions) | SYMBOL | | | TEST | N | <b>IILITAR</b> | Υ | COMMERCIAL | | | | |------------------|--------------|----------------------|--------------------|-----|----------------|-----|------------|-----|-----|------| | | | ARAMETER | CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | | Input to | Polarity fuse intact | | | | 50 | | | 40 | 1 | | | output | Polarity fuse blown | | | | 55 | | | 45 | ns | | t <sub>CLK</sub> | Clock to out | tput or feedback | $R_1 = 560\Omega$ | | | 30 | | | 25 | ns | | t <sub>PZX</sub> | Output enab | ole | $R_2 = 1.1K\Omega$ | | | 25 | | | 20 | ns | | t <sub>PXZ</sub> | Output disal | ole | | | 45.43 | 25 | est est | | 20 | ns | | f <sub>MAX</sub> | Maximum fr | equency | | 14 | | | 16 | | | MHz | <sup>1.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZI</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. #### **MegaPAL Devices** 64R32 ### **Operating Conditions** | | | ***** | COMMERCIAL <sup>1</sup> | | | | |-------------------------------|--------------------------------|----------------------|-------------------------|------|------|------| | SYMBOL | PAF | RAMETER | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | V | | A VAII-MAD of plants | | Low | 20 | | | | | t <sub>w</sub> Width of clock | Width of clock | High | 20 | | \$ | ns | | | | Polarity fuse intact | 40 | 1 10 | 100 | | | <sup>T</sup> su | Setup time from input to clock | Polarity fuse blown | 40 | 3 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air temperature | | 0 | | 75 | °C | | T <sub>C</sub> | Operating case temperature | | | | | °C | ### Electrical Characteristics (Over Operating Conditions) | | | | | COMMERCIAL MIN TYP MAX 0.8 2 | | | | |-------------------------------|-----------------------------------------------|-----------------------|--------------------------|-------------------------------|-------|-------|------| | SYMBOL | PARAMETER | TES | T CONDITION | MIN | TYP | MAX | UNIT | | V <sub>IL</sub> 2 | Low-level input voltage | | | | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | | 400 | ٧ | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | -0.8 | -1.5 | ٧ | | I <sub>IL</sub> 3 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 0.4V | | -0.02 | -0.25 | mA | | I <sub>IH</sub> <sup>3</sup> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 2.4V | | | 25 | μΑ | | l <sub>l</sub> | Maximum input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = 5.5V | | | 1 | mA | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.3 | 0.5 | ٧ | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -0.4mA | 2.4 | 2.8 | | ٧ | | I <sub>OZL</sub> <sup>3</sup> | <b>~</b> ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | $V_{O} = 0.4V$ | | | -100 | μΑ | | I <sub>OZH</sub> <sup>3</sup> | Off-state output current | V <sub>CC</sub> = MAX | $V_0 = 2.4V$ | | | 100 | μΑ | | los <sup>4</sup> | Output short-circuit current | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | -10 | -40 | -60 | mA | | Icc | Supply current | V <sub>CC</sub> = MAX | | | 400 | 640 | mA | ### Switching Characteristics (Over Operating Conditions) | SYMBOL | 스레스 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 이 시 - 기 - 기 - 기 - 기 - 기 - 기 - 기 - 기 - 기 - | | | COMI | | | l | |-------------------|-----------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------------|------|-----|-----|------| | | PAI | RAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> I | | Polarity fuse intact | | | 50 | 50 | 100 | | | Input to output | Polarity fuse blown | | 55 | 55 | ns | | | t <sub>CLK</sub> | Clock to output or feedback | | | | | 22 | ns | | t <sub>PZX</sub> | Output enable | | $R_1 = 560\Omega$ $R_2 = 1.1K\Omega$ | | | 30 | ns | | t <sub>PXZ</sub> | Output disable | | $ R_2 = 1.1 \text{K}\Omega $ | | | 30 | ns | | t <sub>PRH</sub> | Preset to output | | | | | 35 | ns | | f <sub>MAX</sub> | Maximum frequency | | | 16 | 20 | | MHz | - 1. The PAL64R32 Series is designed to operate over the full military operating conditions. For availability and specifications, contact Monolithic Memories. - 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. - I/O pin leakage is the worst case of I<sub>IL</sub> and I<sub>OZL</sub> (or I<sub>IH</sub> and I<sub>OZH</sub>). No more than one output should be shorted at a time and duration of the short circuit should not exceed one second. # **f**MAX Parameters The parameter $f_{MAX}$ is the maximum speed at which the PAL device is guaranteed to operate. Because flexibility inherent to PAL devices allows a choice of clocked flip-flop designs, for the convenience of the user, $f_{MAX}$ for the B-speed devices is specified to address two major classes of synchronous designs. The simplest type of synchronous design can be described as a data path application. In this case, data is presented to the data terminal of the flip-flop and clocked through; no feedback is employed (Figure 1). Under these conditions, the frequency of operation is limited by the greater of the data setup time $(t_{su})$ or the minimum clock period $(t_w$ high + $t_w$ low). This parameter is designated $f_{MAX}$ (no feedback). For synchronous sequential designs, i.e., state machines, where logical feedback is required, inputs to flip-flop data terminals originate from the device input pins of flip-flop outputs via the internal feedback paths (Figure 2). Under these conditions, $f_{\mbox{\scriptsize MAX}}$ is defined as the reciprocal of $(t_{\mbox{\scriptsize su}} + t_{\mbox{\scriptsize CLK}})$ and is designated $f_{\mbox{\scriptsize MAX}}$ (feedback). Figure 1. No Feedback Figure 2. Feedback ### **Output Register PRELOAD** The PRELOAD function allows the register to be loaded from data placed on the output pins. This feature aids functional testing of sequential designs by allowing direct setting of output states. The procedure for PRELOAD is as follows: ### Series 20PA - 1. Raise V<sub>CC</sub> to 4.5V. - 2. Disable output registers by setting pin 11 to VIH. - 3. Apply V<sub>IL</sub>/V<sub>IH</sub> to all registered output pins. - 4. Pulse pin 8 to V<sub>p</sub>, then back to 0V. - 5. Remove V<sub>IL</sub>/V<sub>IH</sub> from all output registers. - 6. Lower pin 11 to V<sub>II</sub> to enable the output registers. - 7. Verify for VOL/VOH at all registered output pins. ### Series 24RS/24XA - 1. Raise V<sub>CC</sub> to 4.5V. - 2. Disable output registers by setting pin 13 to VIH. - 3. Apply V<sub>IL</sub>/V<sub>IH</sub> to all registered output pins. - 4. Pulse pin 10 to V<sub>p</sub>, then back to 0V. - 5. Remove V<sub>IL</sub>/V<sub>IH</sub> from all output registers. - 6. Lower pin 13 to $V_{\rm IL}$ to enable the output registers. - 7. Verify for VOL/VOH at all registered output pins. ### **Power-Up RESET** All devices with this PRELOAD feature also have power-up RESET. All registers power up to a logic high for predictable system initialization. ### **Switching Waveforms** Notes: 1. Input pulse amplitude 0V to 3.0V. 2. Input access measured at the 1.5V level. ### **Absolute Maximum Ratings** | and the second of the second of the second | | | Operating | Programming | | |--------------------------------------------|---|------|---------------|----------------|--| | Supply voltage V <sub>CC</sub> | , | <br> | -0.5V to 7V | 0.5V to 12V | | | Input voltage | | | -1.5V to 5.5V | 1.0V to 22V | | | | | | | 12V | | | Storage temperature | | <br> | | 65°C to +150°C | | ### **Switching Test Load** ## Schematic of Inputs and Outputs Notes: 1. t<sub>PD</sub> is tested with switch S<sub>1</sub> closed, C<sub>L</sub> = 50pF and measured at 1.5V output level. 2. t<sub>PZX</sub> is measured at the 1.5V output level with C<sub>L</sub> = 50pF. S<sub>1</sub> is open for high impedance to "1" test, and closed for high impedance to "0" test. 3. t<sub>PXZ</sub> is tested with C<sub>L</sub> = 5pF. S<sub>1</sub> is open for "1" to high impedance test, measured at V<sub>OH</sub> -0.5V output level; S<sub>1</sub> is closed for "0" to high impedance test measured at V<sub>OL</sub> +0.5V output level. | PAL® Device Introduction | 1 | |----------------------------------|-----| | PAL®/HAL® Device Specifications | 2 | | PAL Device Programmer Ref. Guide | 3 | | HAL/ZHAL™ Devices | 4. | | Logic Cell Array™ | 5 | | PALASM® Software Syntax | 6 | | PAL Device Applications | 7 | | Logic Tutorial | 8 | | PLE™ Devices | 9 | | PLE Circuit Applications | 10 | | Article Reprints | 11 | | General Information | 112 | | Package Drawings | 13 | | Representatives and Distributors | 14 | ### **Table of Contents** | 24 Pin and MegaPAL Device Families | | 3-4 | |----------------------------------------------------------------------------|----------|--------------------------| | | | | | | | | | Micropross 20 Pin Device Families24 Pin and MegaPAL Device Families | | 3-9<br>3-10 | | Promac 20 Pin Device Families | <u> </u> | 3-1 <sup>-</sup><br>3-12 | | Stag Microsystems 20 Pin Device Families24 Pin and MegaPAL Device Families | - 1 | 3-13<br>3-14 | | | | | | | | | | Valley Data Sciences 20 Pin Device Families | | 3-19<br>3-20 | | | | | # **Data I/O Corporation** 20 Pin Device Families 10525 Willows Road N.E. PO Box 97046 Redmond, WA 98073-9746 (800) 247-5700 Models 19, 29A, 29B Model 60 | Series | Part Number | System | LogicPak <sup>TM</sup> | Adapter | Family<br>Code | Pinout<br>Code | |------------------------------|------------------------|-------------------------|------------------------|-----------------|----------------|----------------| | | PAL10H8/-2 | | | | | 18 | | | PAL10L8/-2 | Model 60 | 303A | 303A-002-V08 | 22 | 13 | | | PAL12H6/-2 | Rev. V05 | | 303A-011A/B-V01 | | 19 | | | PAL12L6/-2 | | | | | 14 | | Small 20/-2<br>Combinatorial | PAL14H4/-2 | Models | | | | 20 | | | PAL14L4/-2 | 19 | | | | 15 | | | PAL16H2/-2 | 29A | | | | 22 | | | PAL16L2/-2 | 29B | | | | 16 | | | PAL16C1/-2 | | | | | 21 | | Medium 20/<br>20A/20A-2/4/ | PAL16L8/A/-2/-4/B-2/-4 | | | | | 17 | | | PAL16R8/A/-2/-4/B-2/-4 | | | | | 24 | | 20B-2/-4 | PAL16R6/A/-2/-4/B-2/-4 | | | | | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | * | ▼ * | | | | PAL16L8B/D | | | | 30 | 17 | | Medium | PAL16R8B/D | | | | in the Magazin | 24 | | 20B/D | PAL16R6B/D | | | | | | | | PAL16R4B/D | | <b>∀</b> | | <b>\psi</b> | <b>*</b> | | | PAL16L8BP | | 303A-V04 | | 22 | 17 | | Medium<br>20BP | PAL16R8BP | | | 44.5 | 4 : | 67 | | Standard | PAL16R6BP | | | | | 1 | | | PAL16R4BP | | | | | <b>+</b> | | | PAL16P8A | 1 1 | | | | 30 | | Medium 20PA<br>Programmable | PAL16RP8A | | | | | 31 | | Polarity | PAL16RP6A | Service of the Contract | | | | | | | PAL16RP4A | | + | | | | | Large 20 | PAL16X4 | 350 A 3 4 | 303A | | 2.7798 | 100 m | | Arithmetic | PAL16A4 | | | 4 | | 24 | | Large 20RA<br>Asynchronous | PAL16RA8 | ] \ | + | <b>.</b> | <b>\</b> | 30 | # Data I/O ## 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | System | LogicPak <sup>™</sup> | Adapter | Family<br>Code | Pinout<br>Code | |-----------------------------|-------------------------|----------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------| | | PAL12L10 | Model 60 | 303A | 303A-002-V08 | 22 | 01 | | | PAL14L8 | Rev. V05 | ha Dage | 303A-011A/B-V01 | 12441 | 02 | | Small 24 | PAL16L6 | Models | | | | 03 | | Combinatorial | PAL18L4 | 19 | | | | 04 | | | PAL20L2 | 29A | | 100 to 10 | | 05 | | | PAL20C1 | 29B | | | | 12 | | Small 24A | PAL6L16A | 4698 | | | | 48 | | Decoder | PAL8L14A | | - 70 A | | | 49 | | | PAL20L8A/-2/B | | | | | 26 | | Medium 24A/ | PAL20R8A/-2/B | | 84 D. N. | | | 27 | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | | | | and Po | | Stariuaru | PAL20R4A/-2/B | | | | | • + | | | PAL20L10 | | | | | 06 | | Medium 24X<br>Exclusive-OR | PAL20X10 | | | | | 23 | | | PAL20X8 | | | and was finely by San Symple | | and providing the | | | PAL20X4 | | <b>↓</b> | | | i jak <b>y</b> aji | | | PAL20L10A | | 303A-V04 | | | 06 | | Medium 24XA | PAL20X10A | | | | | 36 | | Exclusive-OR | PAL20X8A | | | | | est cesuel se s | | | PAL20X4A | | | | | | | | PAL20S10 | | | | | 43 | | Large 24RS | PAL20RS10 | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | Shared Product Terms | PAL20RS8 | Market Committee of | | la les de la | Section 1 Section 1 | 44 | | Product Terms | PAL20RS4 | | | <b>+</b> | | 46 | | Large 24A<br>Registered XOR | PAL22RX8A | | | 303A-011A/B-V01 | | 78 | | Large 24/A<br>Varied XOR | PAL32VX10/A | | | | | 77 | | Large 24RA<br>Asynchronous | PAL20RA10 | | 303A | 303A-002-V08<br>303A-011A/B-V01 | 930 | 45 | | ECL<br>Combinatorial | PAL10H20P8 <sup>1</sup> | provide a scarce out | 303A-V04 | 303A-ECL | an September 199 | 42 | | MegaPAL <sup>TM</sup> | PAL32R16 | | 303A | 303A-088-A/B | S4.45 | 47 | | Devices | PAL64R32 | Model 29B | 350 | A/-23/A/B | <b>!</b> ₩ | 84 | NOTE: The software and hardware revisions listed are the earliest revisions that support these products. Later software and hardware revisions can also be assumed to support these products. <sup>1</sup>Not supported on Model 19 # **Digelec** ### 20 Pin Device Families 1602 Lawrence Ave. Suite 113 Ocean, NJ 07712 (201) 493-2420 System UP803 | Series | Part Number | FAM 52 Rev. | Adapter | Adapter Rev. | |----------------------------|------------------------|-------------|---------------------------|--------------| | | PAL10H8/-2 | 5.4 | DA53 | A-3 | | | PAL10L8/-2 | | | | | | PAL12H6/-2 | | | | | Small 20/-2 | PAL12L6/-2 | | | | | Combinatorial | PAL14H4/-2 | | | | | | PAL14L4/-2 | | | | | | PAL16H2/-2 | | | | | | PAL16L2/-2 | | | | | | PAL16C1/-2 | | | | | Medium 20/ | PAL16L8/A/-2/-4/B-2/-4 | | | | | 20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | | | | 20B-2/-4<br>Standard | PAL16R6/A/-2/-4/B-2/-4 | | | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | | | PAL16L8B/D | | | | | Medium | PAL16R8B/D | | | | | 20B/D | PAL16R6B/D | | | | | | PAL16R4B/D | | | | | | PAL16L8BP | | | | | Medium | PAL16R8BP | | | | | 20BP<br>Standard | PAL16R6BP | | | | | Standard | PAL16R4BP | | <b>+</b> | <b>,</b> | | | PAL16P8A | 5.4 | DA53 | A-3 | | Medium 20PA | PAL16RP8A | | a com degrad kanada da da | harman I | | Programmable Polarity | PAL16RP6A | | | | | . Viai ity | PAL16RP4A | | | | | Large 20 | PAL16X4 | | and the second | 1000 | | Arithmetic | PAL16A4 | <b>∀</b> | + | <b>+</b> | | Large 20RA<br>Asynchronous | PAL16RA8 | | Under Development | | # Digelec # 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Numbers | FAM 52 | Adapter | Adapter Rev. | |-----------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------| | | PAL12L10 | 5.4 | DA55 | C-1 | | | PAL14L8 | | | | | Small 24 | PAL16L6 | | | | | Combinatorial | PAL18L4 | | | | | | PAL20L2 | | The early let the first | | | | PAL20C1 | ▼ | <b>▼</b> 356. | | | Small 24A | PAL6L16A | | Under Development | | | Decoder | PAL8L14A | | Orider Development | | | | PAL20L8A/-2/B | 5.4 | DA55 | C-1 | | Medium 24A/ | PAL20R8A/-2/B | | | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | | | | Standard | PAL20R4A/-2/B | | | | | | PAL20L10 | | | | | Medium 24X | PAL20X10 | | | | | Exclusive-OR | PAL20X8 | | | | | | PAL20X4 | | | | | | PAL20L10A | | | | | Medium 24XA | PAL20X10A | | | | | Exclusive-OR | PAL20X8A | | | | | | PAL20X4A | | | | | | PAL20S10 | | | | | Large 24RS | PAL20RS10 | | | | | Shared<br>Product Terms | PAL20RS8 | | | | | Floudet Tellis | PAL20RS4 | | | | | Large 24A<br>Registered XOR | PAL22RX8A | | | | | Large 24/A<br>Varied XOR | PAL32VX10/A | entes son differente de la companya de la companya de la companya de la companya de la companya de la companya<br>La companya de la | | | | Large 24RA<br>Asynchronous | PAL20RA10 | | | | | ECL<br>Combinatorial | PAL10H20P8 | | | | | MegaPAL <sup>TM</sup> | PAL32R16 | | Under Development | | | Devices | PAL64R32 | | Onder Development | | ## - # **Kontron** ### 20 Pin Device Families 1230 Charleston Road Mountain View, CA 94039-7230 (415) 965-7020 System MPP-80S System EPP-80 | Series | Part Number | Socket Adapter | UPM-B Rev. | |----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | SA-27 | 1.44 | | | PAL10L8/-2 | | | | l verske kere blak for til 1995 i 1995.<br>Heller i 1995 19 | PAL12H6/-2 | to recognisting a reliable of the agricultural relations of the second s | Tragger Samilyis Samur Amerika (Siling Samilyin)<br>Taking Samilyis (Samur Amerika Samilyin) | | Small 20/-2 | PAL12L6/-2 | | | | Combinatorial | PAL14H4/-2 | | | | | PAL14L4/-2 | | | | | PAL16H2/-2 | | [ 시 ] 설치 : 설립 : | | | PAL16L2/-2 | | | | | PAL16C1/-2 | the state of s | Professional State (State State Stat | | | PAL16L8/A/-2/-4/B-2/-4 | | | | Medium 20/<br>20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | | | 20B-2/-4 | PAL16R6/A/-2/-4/B-2/-4 | | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | | PAL16L8B/D | Under Development | | | Medium | PAL16R8B/D | | | | 20B/D | PAL16R6B/D | | | | | PAL16R4B/D | | yde og skiller i forskir fra far fra skiller samfæren.<br>De skiller for til skiller i s | | | PAL16L8BP | SA-27 | | | Medium<br>20BP | PAL16R8BP | Under Development | | | Standard | PAL16R6BP | | | | spaniski a tri osnovenski, og<br>Tillion | PAL16R4BP | | | | | PAL16P8A | | | | Medium 20PA<br>Programmable | PAL16RP8A | | | | Polarity | PAL16RP6A | | | | | PAL16RP4A | | | | Large 20 | PAL16X4 | | | | Arithmetic | PAL16A4 | | | | Large 20RA<br>Asynchronous | PAL16RA8 | | 1.47 | # Kontron ## 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Socket Adapter | UPM-B Rev. | |-----------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | PAL12L10 | | 1.44 | | | PAL14L8 | | | | Small 24 | PAL16L6 | SA-27-1 | | | Combinatorial | PAL18L4 | | | | | PAL20L2 | | | | | PAL20C1 | | | | Small 24A | PAL6L16A | | | | Decoder | PAL8L14A | Under Development | 1.48 | | | PAL20L8A/-2/B | SA-27-1 | 1.44 | | Medium 24A/<br>24A-2/B | PAL20R8A/-2/B | | | | Standard | PAL20R6A/-2/B | | | | | PAL20R4A/-2/B | | | | | PAL20L10 | | | | Medium 24X | PAL20X10 | | | | Exclusive-OR | PAL20X8 | | | | | PAL20X4 | | | | | PAL20L10A | a distribution of the state | | | Medium 24XA | PAL20X10A | | | | Exclusive-OR | PAL20X8A | | | | | PAL20X4A | | | | | PAL20S10 | Under Development | | | Large 24RS | PAL20RS10 | | | | Shared Product Terms | PAL20RS8 | | | | | PAL20RS4 | | <b>▼</b> | | Large 24A<br>Registered XOR | PAL22RX8A | | Under Development | | Large 24/A<br>Varied XOR | PAL32VX10/A | | 1.48 | | Large 24RA<br>Asynchronous | PAL20RA10 | | 1.44 | | ECL<br>Combinatorial | PAL10H20P8 | | 1.47 | | MegaPAL <sup>TM</sup> | PAL32R16 | | | | Devices | PAL64R32 | 7: 1: 20 E | Under Development | ### F) # **Micropross** 20 Pin Device Families Parc d'activite des Pres 5, rue Denis-Papin 59650 Villeneuve-d'Ascq Tel 20479040 ROM 5000 Programmer | Series | Part Number | Rev. | |----------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 3.5 | | e franciske ste ste se en en en en skippere. | PAL10L8/-2 | The state of s | | | PAL12H6/-2 | | | Small 20/-2 | PAL12L6/-2 | The control of co | | Combinatorial | PAL14H4/-2 | | | | PAL14L4/-2 | | | | PAL16H2/-2 | | | | PAL16L2/-2 | | | | PAL16C1/-2 | | | | PAL16L8/A/-2/-4/B-2/-4 | | | Medium 20/<br>20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | | 20B-2/-4 | PAL16R6/A/-2/-4/B-2/-4 | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | PAL16L8B/D | [ | | Medium | PAL16R8B/D | | | 20B/D | PAL16R6B/D | | | | PAL16R4B/D | | | | PAL16L8BP | | | Medium | PAL16R8BP | | | 20BP<br>Standard | PAL16R6BP | | | | PAL16R4BP | | | | PAL16P8A | | | Medium 20PA | PAL16RP8A | 기가 하는 사람들은 조건을 보냈다는 <mark>최근 사람들은 기계에 되었다. 현</mark> 경기<br> 10 10 10 10 10 10 10 10 | | Programmable Polarity | PAL16RP6A | | | | PAL16RP4A | | | Large 20 | PAL16X4 | | | Arithmetic | PAL16A4 | | | Large 20RA<br>Asynchronous | PAL16RA8 | Under Development | # **Micropross** ## 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Rev. | | |-----------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | PAL12L10 | 3.5 | | | | PAL14L8 | | | | Small 24 | PAL16L6 | 나는 몸이 있다면 그 생활의 다른 하나는 게 연락한 경찰 | | | Combinatorial | PAL18L4 | | | | | PAL20L2 | | | | | PAL20C1 | | | | Small 24A | PAL6L16A | | | | Decoder | PAL8L14A | Under Development | | | | PAL20L8A/-2/B | 3.5 (1) (1) (1) (1) (1) (1) (1) (1) (1) (1) | | | Medium 24A/ | PAL20R8A/-2/B | 발표하는 사람들이 보면 사람들이 사람들이 있다. 그리고 있다.<br> | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | | | Staridard | PAL20R4A/-2/B | | | | | PAL20L10 | 그 한국화 시간에 불러 맞았을 때문에 살린다. | | | Medium 24X | PAL20X10 | and the state of the second | | | Exclusive-OR | PAL20X8 | | | | | PAL20X4 | 요. 이번 그렇게 된 것이 되었다. 그런 | | | | PAL20L10A | | | | Medium 24XA | PAL20X10A | 가 있는 것이 있는 것들이 되었습니다. 그런 사람들은 모든 것을 보고 있는 것들은 것들이 되었습니다.<br>[1] 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 사람들은 | | | Exclusive-OR | PAL20X8A | 마스 그 교통을 내려가는 사람들은 모르게 함께 보고를 하셨다는 것이 되었다.<br>그는 이번 경기에 되었다고 하는 사람들을 들었다. [18] 이번 시간 사람들을 받는 | | | | PAL20X4A | | | | | PAL20S10 | | | | Large 24RS | PAL20RS10 | | | | Shared Product Terms | PAL20RS8 | 가는 사람들은 사람이 되었다. 그는 사람들이 하는 것은 것이 되었다.<br>그렇게 하실 사람이 하는 사람들이 없는 것을 모르는 것을 하는 것을 하는 것을 받았다. | | | | PAL20RS4 | 50, 10 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | Large 24A<br>Registered XOR | PAL22RX8A | | | | arge 24/A Varied<br>XOR | PAL32VX10/A | | | | Large 24RA<br>Asynchronous | PAL20RA10 | | | | CL Combinatorial | PAL10H20P8 | en en de de la company de<br>La company de la d | | | MegaPAL <sup>TM</sup> | PAL32R16 | | | | Devices | PAL64R32 | Under Development | | ### 3 # Promac 20 Pin Device Families Adams MacDonald Enterprises, Inc. 2999 Monterey/Salinas Highway Monterey, CA 93940 (408) 373-3607 Promac P3 Programmer | Series | Part Number | Software Rev. | S1/S2 | |--------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | | PAL10H8/-2 | 3.0 | 0/1 | | | PAL10L8/-2 | | 0/6 | | r og tog f<br>Jakon og skrivet blevet bygger for | PAL12H6/-2 | | 0/2 | | Small 20/-2 | PAL12L6/-2 | | 0/7 | | Combinatorial | PAL14H4/-2 | | 0/3 | | | PAL14L4/-2 | | 0/8 | | | PAL16H2/-2 | | 0/4 | | | PAL16L2/-2 | | 0/9 | | | PAL16C1/-2 | | 0/5 | | Medium 20/ | PAL16L8/A/-2/-4/B-2/-4 | | 0/10 | | 20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | 0/11 | | 20B-2/-4<br>Standard | PAL16R6/A/-2/-4/B-2/-4 | | 0/12 | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | 0/13 | | | PAL16L8B/D | | 5/0 | | Medium | PAL16R8B/D | | 5/1 | | 20B/D | PAL16R6B/D | | 5/2 | | | PAL16R4B/D | | 5/3 | | | PAL16L8BP | | 0/10 | | Medium | PAL16R8BP | | 0/11 | | 20BP<br>Standard | PAL16R6BP | | 0/12 | | | PAL16R4BP | Section 1 Sectio | 0/13 | | | PAL16P8A | | 1/0 | | Medium 20PA<br>Programmable | PAL16RP8A | | 1/3 | | Programmable Polarity | PAL16RP6A | | 1/2 | | | PAL16RP4A | | 1/1 | | Large 20 | PAL16X4 | | 0/14 | | Arithmetic | PAL16A4 | | 0/15 | | Large 20RA<br>Asynchronous | PAL16RA8 | *** | 1/12 | ## **Promac** ## 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Software Rev. | S1/S2 | |-----------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | PAL12L10 | 3.0 | 2/2 | | | PAL14L8 | | 2/3 | | Small 24 | PAL16L6 | | 2/4 | | Combinatorial | PAL18L4 | | 2/5 | | | PAL20L2 | | 2/6 | | | PAL20C1 | | 2/1 | | Small 24A | PAL6L16A | | 3/11 | | Decoder | PAL8L14A | | 3/10 | | | PAL20L8A/-2/B | | 2/8 | | Medium 24A/ | PAL20R8A/-2/B | | 2/9 | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | 2/10 | | | PAL20R4A/-2/B | | 2/11 | | | PAL20L10 | | 2/7 | | Medium 24X | PAL20X10 | | 2/12 | | Exclusive-OR | PAL20X8 | | 2/13 | | | PAL20X4 | | 2/14 | | | PAL20L10A | | 2/7 | | Medium 24XA | PAL20X10A | | 2/15 | | Exclusive-OR | PAL20X8A | | 3/0 | | | PAL20X4A | | 3/1 | | | PAL20S10 | | 3/5 | | Large 24RS | PAL20RS10 | | 3/6 | | Shared<br>Product Terms | PAL20RS8 | | 3/7 | | | PAL20RS4 | [ 2012 ] [ 1012 [ 1012 ] 101 [ 1012 ] 1012 [ 1012 ] 1012 [ 1012 ] 1012 [ 1012 ] 1012 [ 1012 ] 1012 [ 1012 ] 10<br>[ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ [ | 3/8 | | Large 24A<br>legistered XOR | PAL22RX8A | | Under Development | | Large 24/A<br>Varied XOR | PAL32VX10/A | Bart Marine Control of Property States and Property States | | | Large 24RA<br>Asynchronous | PAL20RA10 | | 3/4 | | ECL<br>Combinatorial | PAL10H20P8 | | Under Development | | MegaPAL <sup>TM</sup> | PAL32R16 | | | | Devices | PAL64R32 | Under Development | | # Stag Microsystems ### 20 Pin Device Families 1600 Wyatt Dr. Suite 3 Santa Clara, CA 95054 (408) 988-1118 ZL30 PPZ | Series | Part Number | Code | ZL30 Rev. | ZM2200 | |----------------------------|------------------------|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 20-20 | 30-35 | 14 | | | PAL10L8/-2 | 20-25 | | | | | PAL12H6/-2 | 20-21 | | | | Small 20/-2 | PAL12L6/-2 | 20-26 | | and a second | | Combinatorial | PAL14H4/-2 | 20-22 | | | | | PAL14L4/-2 | 20-27 | | | | | PAL16H2/-2 | 20-23 | | | | | PAL16L2/-2 | 20-28 | | | | | PAL16C1/-2 | 20-24 | | | | Medium 20/ | PAL16L8/A/-2/-4/B-2/-4 | 20-29 | | | | 20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | 20-30 | | | | 20B-2/-4<br>Standard | PAL16R6/A/-2/-4/B-2/-4 | 20-31 | | | | Gariuaru | PAL16R4/A-2/-4/B-2/-4 | 20-32 | | <b>+</b> | | | PAL16L8B/D | 22-29 | 30-39 | 12 | | Medium | PAL16R8B/D | 22-30 | | | | 20B/D | PAL16R68/D | 22-31 | | necessaria de la composição compos | | | PAL16R4B/D | 22-32 | | 4 | | | PAL16L8BP | 20-29 | 30-35 | 14 | | Medium | PAL16R8BP | 20-30 | | 19 | | 20BP<br>Standard | PAL16R6BP | 20-31 | | | | Gariuaru | PAL16R4BP | 20-32 | | <b>+</b> | | | PAL16P8A | 20-38 | | 12 | | Medium 20PA | PAL16RP8A | 20-11 | | | | Programmable<br>Polarity | PAL16RP6A | 20-12 | | | | · Olarity | PAL16RP4A | 20-13 | | + | | Large 20 | PAL16X4 | 20-33 | | 14 | | Arithmetic | PAL16A4 | 20-34 | <del></del> | Section 1997 | | Large 20RA<br>Asynchronous | PAL16RA8 | 20-19 | 30-37 | 12 | # **Stag Microsystems** ## 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Code | ZL30 Rev. | ZM2200 | |-----------------------------|----------------|---------|----------------------|--------| | | PAL12L10 21-50 | 30-35 | 14 | | | | PAL14L8 | 21-51 | | | | Small 24 | PAL16L6 | 21-52 | | 12 | | Combinatorial | PAL18L4 | 21-53 | | | | | PAL20L2 | 21-54 | | | | | PAL20C1 | 21-55 | <b>★</b> | + | | Small 24A | PAL6L16A | | | | | Decoder | PAL8L14A | | Under Development | | | | PAL20L8A/-2/B | 21-56 | 30-35 | 12 | | Medium 24A/ | PAL20R8A/-2/B | 21-57 | | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | 21-58 | | | | - Curradi d | PAL20R4A/-2/B | 21-59 | | | | | PAL20L10 | 21-60 | | | | Medium 24X | PAL20X10 | 21-61 | | | | Exclusive-OR | PAL20X8 | 21-62 | | | | | PAL20X4 | 21-63 | | | | | PAL20L10A | 21-60 | | | | Medium 24XA | PAL20X10A | 21-61 | | | | Exclusive-OR | PAL20X8A | 21-62 | | | | | PAL20X4A | 21-63 | | | | | PAL20S10 | 21-81 | 30-39 | | | Large 24RS | PAL20RS10 | 21-80 | | | | Shared<br>Product Terms | PAL20RS8 | 21-79 | | | | | PAL20RS4 | 21-78 | | | | Large 24A<br>Registered XOR | PAL22RX8A | Under D | Pevelopment | | | Large 24/A<br>Varied XOR | PAL32VX10/A | | ↓<br>• | | | Large 24RA<br>Asynchronous | PAL20RA10 | 21-77 | 30-37 | | | ECL<br>Combinatorial | PAL10H20P8 | Under D | Pevelopment | | | MegaPALTM | PAL32R16 | | Hadar Dalifferenside | | | Devices | PAL64R32 | | Under Development | | ### ٤ # **Storey Systems** 20 Pin Device Families 3201 North Hwy. 67 Suite H Mesquite, TX 75150 (214) 270-4135 P240 Programmer | Series | Part Number | | |----------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 2.0 | | | PAL10L8/-2 | apadad ka terrifa da jawa i daga ang itawa a dama a lamba a tangga ang ang dagada ay i daga daga a lamba a gar<br>Tangga da ka terrifa da jawa i daga ang itawa a dama a lamba a da jawa da jawa ang ang dagada ay i daga ka pag | | | PAL12H6/-2 | | | Small 20/-2 | PAL12L6/-2 | | | Combinatorial | PAL14H4/-2 | | | | PAL14L4/-2 | 사용 이 보이는 것이 되었다. 이 이 아들은 경우 이 등록하다고 있다.<br>19 - 19 - 19 - 19 - 19 - 19 - 19 - 19 - | | | PAL16H2/-2 | 마음 등 경기 등 기계 등 경기 등 기계 등 기계 등 기계 등 기계 등 기계 | | | PAL16L2/-2 | | | | PAL16C1/-2 | 등 이 경우를 하는데 되었다. 그는 사람들은 사람들은 사람들은 사람들은 사람들은 사람들이 되었다. 그는 사람들은 사람들은 사람들은 사람들이 되었다. 그는 사람들은 사람들은 기를 받는다면 보다 되었다.<br> | | Medium 20/ | PAL16L8/A/-2/-4/B-2/-4 | 그리고 하는데 있다. 그는 그를 들었다. 그를 모르는 모르는 그를 다 했다. | | 20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | | 20B-2/-4<br>Standard | PAL16R6/A/-2/-4/B-2/-4 | en al anticolo de la parte de la companya del companya del companya de la del la companya de compan | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | PAL16L8B/D | 4.0 | | Medium | PAL16R8B/D | | | 20B/D | PAL16R6B/D | | | | PAL16R4B/D | <b>*</b> | | | PAL16L8BP | 2.0 | | Medium | PAL16R8BP | | | 20BP<br>Standard | PAL16R6BP | Under Development | | | PAL16R4BP | | | | PAL16P8A | 4.0 | | Medium 20PA | PAL16RP8A | | | Programmable Polarity | PAL16RP6A | en de la companya de<br>La companya de la co | | rolailty | PAL16RP4A | | | Large 20 | PAL16X4 | an again an an an ann an an an an an an an an a | | Arithmetic | PAL16A4 | 2.0 | | Large 20RA<br>Asynchronous | PAL16RA8 | 4.04 | # **Storey Systems** # 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Rev. policina de la companya del companya del companya de la compa | |-----------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL12L10 | 2.0 | | | PAL14L8 | | | Small 24 | PAL16L6 | | | Combinatorial | PAL18L4 | | | | PAL20L2 | | | | PAL20C1 | | | Small 24A | PAL6L16A | | | Decoder | PAL8L14A | Under Development | | | PAL20L8A/-2/B | 2.0 | | Medium 24A/ | PAL20R8A/-2/B | | | 24A-2/B | PAL20R6A/-2/B | | | Standard | PAL20R4A/-2/B | | | | PAL20L10 | | | Medium 24X<br>Exclusive-OR | PAL20X10 | | | | PAL20X8 | 는 사람들이 모르는 일보다 12세계 및 실고하는 것이라는 생생한 수 있다.<br> | | | PAL20X4 | | | | PAL20L10A | 마다 마다 하다 다른 회사의 하는 □▼ 보고 그렇게 보고 바쁜 개념되는 것.<br>그렇게 하는 이 구선 경찰 시간을 보냈다면서 보고 보고 보고 있다. | | Medium 24XA | PAL20X10A | Under Development | | Exclusive-OR | PAL20X8A | | | | PAL20X4A | | | | PAL20S10 | | | Large 24RS | PAL20RS10 | | | Shared Product Terms | PAL20RS8 | | | | PAL20RS4 | | | Large 24A<br>Registered XOR | PAL22RX8Aa | | | Large 24/A Varied<br>XOR | PAL32VX10/A | 2 | | Large 24RA<br>Asynchronous | PAL20RA10 | 4.04 | | ECL Combinatorial | PAL10H20P8 | | | MegaPAL <sup>TM</sup> | PAL32R16 | Under Development | | Devices | PAL64R32 | 보는 사람이 많은 수는 사람들은 소프로 가는 사람들은 경우를 가장하는 것이 되는 것이 되었다.<br> | # **Structured Design** ### 20 Pin Device Families 1700 Wyatt Drive Suite 7 Santa Clara, CA 95054 (408) 988-0725 SD 20/24 System SD 1000 System | Series | Part Number | SD 20/24 | SD 1000 | |--------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 1.6 | 1.05 | | kan di Jank ka di 1991 bilan di<br>Majarah | PAL10L8/-2 | | | | | PAL12H6/-2 | | | | | PAL12L6/-2 | | | | Small 20/-2<br>Combinatorial | PAL14H4/-2 | | | | | PAL14L4/-2 | | | | | PAL16H2/-2 | | | | | PAL16L2/-2 | | | | | PAL16C1/-2 | | | | Medium 20/ | PAL16L8/A/-2/-4/B-2/-4 | | | | 20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | | | | 20B-2/-4<br>Standard | PAL16R6/A/-2/-4/B-2/-4 | 2000년 전 100년 - 120년 중에 전환경환경 (1982년 - 120년 )<br>1987년 - 1987년 - 1982년 | | | | PAL16R4/A/-2/-4/B-2/-4 | | | | | PAL16L8B/D | Under Development | | | Medium | PAL16R8B/D | | | | 20B/D | PAL16R6B/D | | | | | PAL16R4B/D | | <b>.</b> | | | PAL16L8BP | 1.6 | 1.05 | | Medium | PAL16R8BP | | | | 20BP<br>Standard | PAL16R6BP | | | | Juliudia | PAL16R4BP | Under Devel | onment | | | PAL16P8A | Onder Devel | opinont | | Medium 20PA | PAL16RP8A | | ng Salah Berada Selah Selah Japan Selah Salah | | Programmable Polarity | PAL16RP6A | | | | · Janky | PAL16RP4A | | The state of s | | Large 20 | PAL16X4 | | ** | | Arithmetic | PAL16A4 | 1.6 | 1.05 | | Large 20RA<br>Asynchronous | PAL16RA8 | Under Devel | opment | # **Structured Design** # 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | SD 20/24 | SD 1000 | |-----------------------------|---------------|------------|--------------------------------------------| | Small 24 | PAL12L10 | 1.6 | 1.05 | | | PAL14L8 | | | | | PAL16L6 | | | | Combinatorial | PAL18L4 | | | | | PAL20L2 | | | | | PAL20C1 | | | | Small 24A | PAL6L16A | | | | Decoder | PAL8L14A | Under Deve | elopment | | | PAL20L8A/-2/B | 1.6 | 1.05 | | Medium 24A/ | PAL20R8A/-2/B | | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | | | Standard | PAL20R4A/-2/B | | | | Medium 24X<br>Exclusive-OR | PAL20L10 | | | | | PAL20X10 | | | | | PAL20X8 | | | | | PAL20X4 | | | | | PAL20L10A | | | | Medium 24XA | PAL20X10A | | | | Exclusive-OR | PAL20X8A | | | | | PAL20X4A | | <b>↓</b> | | | PAL20S10 | Under Deve | elopment | | Large 24RS | PAL20RS10 | | | | Shared | PAL20RS8 | | | | Product Terms | PAL20RS4 | | | | Large 24A<br>Registered XOR | PAL22RX8A | | | | Large 24/A<br>Varied XOR | PAL32VX10/A | | | | Large 24RA<br>Asynchronous | PAL20RA10 | | | | ECL<br>Combinatorial | PAL10H20P8 | | | | MegaPAL <sup>TM</sup> | PAL32R16 | | | | Devices | PAL64R32 | | 소개별로 발표되고 기업을 받아 있다. 그는 사람은 그리고 말했다.<br>지하 | ### Y) # **Valley Data Sciences** ### 20 Pin Device Families Charleston Business Park 2426 Charleston Road Mountain View, CA 94043 (415) 968-2900 160 Series Programmer | Series | Part Number | Rev. | |------------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 1.03 | | aktorijsta i marak krijotek. | PAL10L8/-2 | til en i gjer i det skrivet i de skrivet en gjere en gjere en g | | Small 20/-2<br>Combinatorial | PAL12H6/-2 | | | | PAL12L6/-2 | | | | PAL14H4/-2 | | | | PAL14L4/-2 | | | | PAL16H2/-2 | | | | PAL16L2/-2 | | | | PAL16C1/-2 | | | Medium 20/<br>20A/20A-2/4/ | PAL16L8/A/-2/-4/B-2/-4 | | | | PAL16R8/A/-2/-4/B-2/-4 | | | 20B-2/-4 | PAL16R6/A/-2/-4/B-2/-4 | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | PAL16L8B/D | | | Medium | PAL16R8B/D | 그리는 그 사람이 있는 것 같아 하는 것 같아 다른 것이 되었다.<br>- 그런 그 사람이 있는 것 같아 나는 것 같아 나는 것 같아 나는 것 같아 나는 것 같아. | | 20B/D | PAL16R6B/D | | | | PAL16R4B/D | | | | PAL16L8BP | 마이 등 보고 있는 것 같아. 그런 그런 그런 그런 그런 그런 그렇게 바꾸었다.<br>그는 그 전에 가는 물건을 하는 것이라고 있었다는 것이라고 있다. 그 사람들은 사회 유명한 것이다. | | Medium | PAL16R8BP | | | 20BP<br>Standard | PAL16R6BP | Under Development | | | PAL16R4BP | | | | PAL16P8A | 1.03 | | Medium 20PA | PAL16RP8A | | | Programmable | PAL16RP6A | | | Polarity | PAL16RP4A | | | Large 20 | PAL16X4 | | | Large 20<br>Arithmetic | PAL16A4 | a province and the communication and so the state of the first of the state of the sound of the state of the sound of the state | | Large 20RA<br>Asynchronous | PAL16RA8 | Under Development | # **Valley Data Sciences** # 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Rev. | |-----------------------------|---------------|-----------------------------------------| | Small 24 | PAL12L10 | 1.03 | | | PAL14L8 | | | | PAL16L6 | 그 그들은 이 이 사는 사람들이 얼마나 하는 아들이 가장하는 싫었다. | | Combinatorial | PAL18L4 | | | | PAL20L2 | 등로 하다는 이 경기를 위해 보고 있다. 그 사람들은 그 없다.<br> | | | PAL20C1 | | | Small 24A | PAL6L16A | | | Decoder | PAL8L14A | Under Development | | | PAL20L8A/-2/B | 1.03 | | Medium 24A/ | PAL20R8A/-2/B | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | 보고 아이들은 얼마를 하게 됐다고 있는데 하다 하다. | | Staridard | PAL20R4A/-2/B | | | | PAL20X10 | | | Medium 24X | PAL20L10 | | | Exclusive-OR | PAL20X8 | | | | PAL20X4 | 그는 그 사이를 잃어 있다. [일시 그는 그리고 함께 가장 ] | | | PAL20X10A | | | Medium 24XA | PAL20L10A | | | Exclusive-OR | PAL20X8A | | | | PAL20X4A | | | | PAL20RS10 | | | Large 24RS | PAL20S10 | | | Shared<br>Product Terms | PAL20RS8 | | | | PAL20RS4 | 하늘을 십 일을 다쳤다면 하는 모양 사람들이는 | | Large 24A<br>Registered XOR | PAL22RX8A | | | Large 24/A Varied<br>XOR | PAL32VX10/A | | | Large 24RA<br>Asynchronous | PAL20RA10 | | | ECL<br>Combinatorial | PAL10H20P8 | Under Development | | MegaPAL <sup>TM</sup> | PAL32R16 | 1.04 + 1.1 Adapter | | Devices | PAL64R32 | Under Development | ### Ł # **Varix** ### 20 Pin Device Families 1210 E. Campbell Road Richardson, TX 75081 (214) 437-0777 OMNI Programmer | Series | Part Number | Rev. | |----------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | PAL10H8/-2 | 3.18 | | | PAL10L8/-2 | | | | PAL12H6/-2 | 사용 기계 | | Small 20/-2 | PAL12L6/-2 | | | Combinatorial | PAL14H4/-2 | 사는 사용하다 사용하다 가는 사용하다 생각을 하는 것이 되었다. 그런 사용하는 사용하는 것이 함께 되었다.<br>그런 사용하는 사용하는 사용하는 사용하는 것이 되었다. 그런 사용하는 것이 되었다. | | | PAL14L4/-2 | 그 병원이 그렇지 그리지 한 사람이 없다. | | | PAL16H2/-2 | | | | PAL16L2/-2 | | | | PAL16C1/-2 | | | | PAL16L8/A/-2/-4/B-2/-4 | | | Medium 20/<br>20A/20A-2/4/ | PAL16R8/A/-2/-4/B-2/-4 | 보는 그 하지 않아야 있다는 물부모시다. | | 20B-2/-4 | PAL16R6/A/-2/-4/B-2/-4 | | | Standard | PAL16R4/A/-2/-4/B-2/-4 | | | | PAL16L8B/D | | | Medium | PAL16R8B/D | 지근에 하고 하이번 하루 나는 나는 이 남쪽 바셨다는다. | | 20B/D | PAL16R6B/D | - 기타고 발하다 교육상당시 전공급하는 시크는 경기 기타.<br>- 교육시 기타, 교기 대기 기타. | | | PAL16R4B/D | | | | PAL16L8BP | 3.18 | | Medium | PAL16R8BP | 5.00 | | 20BP<br>Standard | PAL16R6BP | | | | PAL16R4BP | | | | PAL16P8A | 3.18 | | Medium 20PA | PAL16RP8A | | | Programmable Polarity | PAL16RP6A | | | r Giarity | PAL16RP4A | | | Large 20 | PAL16X4 | paraganan karangan keringan berangan berangan berangan berangan berangan berangan berangan berangan berangan b<br>Berangan berangan be | | Arithmetic | PAL16A4 | | | Large 20RA<br>Asynchronous | PAL16RA8 | Under Development | # Varix # 24 Pin and MegaPAL<sup>TM</sup> Device Families | Series | Part Number | Rev. | | |-----------------------------|---------------|----------------------------------|--| | Small 24<br>Combinatorial | PAL12L10 | 3.18 | | | | PAL14L8 | | | | | PAL16L6 | | | | | PAL18L4 | | | | | PAL20L2 | 함께 되었다면서 얼마를 들었다는데 다. | | | | PAL20C1 | | | | Small 24A | PAL6L16A | | | | Decoder | PAL8L14A | 의 화가 하는데 하는데 하는데 하는데 얼마를 살아야 한다. | | | | PAL20L8A/-2/B | | | | Medium 24A/ | PAL20R8A/-2/B | | | | 24A-2/B<br>Standard | PAL20R6A/-2/B | | | | | PAL20R4A/-2/B | 소설 시민들 내려고 밝혔다는 결국에 그리지 않는 | | | | PAL20L10 | | | | Medium 24X | PAL20X10 | | | | Exclusive-OR | PAL20X8 | | | | | PAL20X4 | | | | | PAL20L10A | | | | Medium 24XA | PAL20X10A | 마음을 하고 그렇게 많은 그 거리에 갔다. | | | Exclusive-OR | PAL20X8A | 그렇지 말하다면 하는 사람들이 되고 있죠? 함께 | | | | PAL20X4A | | | | | PAL20S10 | Under Development | | | Large 24RS | PAL20RS10 | 불리장은 이번에 발표되었다. 이번 회에 | | | Shared<br>Product Terms | PAL20RS8 | 하는 사람은 사내용 네 교육하고 하는 없었다. | | | | PAL20RS4 | 원물 내용이 없었다면 상황이 그 전 사람들은 | | | Large 24A<br>Registered XOR | PAL22RX8A | | | | Large 24/A<br>Varied XOR | PAL32VX10/A | | | | Large 24RA<br>Asynchronous | PAL20RA10 | 3:18 | | | ECL<br>Combinatorial | PAL10H20P8 | | | | MegaPAL <sup>TM</sup> | PAL32R16 | Under Development | | | Devices | PAL64R32 | | | **PAL®** Device Introduction **General Information** **Package Drawings** **Representatives and Distributors** ### HAL®/ZHALTM Devices ### **Table of Contents** | HAL/ZHAL Devices | | |-------------------------------------------------------------------------|------| | ProPAL, <sup>TM</sup> HAL and ZHAL Devices: The Logical Solutions Logic | | | ZHAL20A Series — Zero Power CMOS Hard Array Logic | 4-7 | | ZHAL64R32 — Zero Power CMOS Hard Array Logic | 4-15 | | ZHAL24A Series — Zero Power CMOS Hard Array Logic | 4-24 | ### ProPAL<sup>TM</sup>, HAL<sup>®</sup>, and ZHAL<sup>TM</sup> Devices: The Logical Solutions for Volume Programmable Logic So you have discovered the convenience and flexibility of designing with PAL® devices from Monolithic Memories. You have implemented a design using PAL devices, and taken that design into production. Now may be the time to consider ways of reducing the efforts you put into programming, testing, and marking large volumes of PAL devices. Wouldn't it be more convenient if you could be relieved of the duties and costs of volume programming and testing and still reap the benefits afforded by programmable logic? Or perhaps you are considering a semicustom product, but you're a little nervous about going to a gate array. Wouldn't it be preferable if you could find a semicustom product which allows easy, inexpensive prototyping, provides fast prototype turnaround, comes fully tested, can have a custom marking, has low NRE charges, provides design flexibility, and has an assured second source? Well, Monolithic Memories, the inventor of the PAL device, offers the logical solutions. ProPAL, HAL, and ZHAL devices make the transition from user-programmed devices to customized production-ready devices easy and risk free. #### **ProPAL Devices** ProPAL (Programmed PAL) devices are simply PAL devices that Monolithic Memories programs and tests for you. You receive a fully functional unit without having to do the programming and testing. But you still have the flexibility to handle design changes easily. #### **HAL Devices** HAL (Hard Array Logic) devices are to PAL devices as ROMs are to PROMs. Instead of fuses in the logic array, your pattern is implemented using metal links that are masked in during wafer fabrication. So your need to program devices is eliminated. And because the devices have their functionality masked in, Monolithic Memories can provide full functional testing before shipping the product. You can place the devices in your boards with a minimum of handling and the highest level of confidence. Monolithic Memories offers a HAL device for every PAL device. Any PAL device design you program can be imple- mented in a HAL version, allowing you to move smoothly into volume production. #### **ZHAL Devices** Monolithic Memories now provides a third alternative for the programmable logic user: new Zero-Standby-Power CMOS HAL devices. For the first time there are HAL devices which can implement any pattern from the Series 20 and Series 24 PAL devices with the greatly reduced power consumption only CMOS can offer. For high complexity designs reaching into the thousands of gates, Zero Power MegaHAL<sup>TM</sup> devices provide the natural semicustom VLSI alternative to gate arrays. The MegaPAL<sup>TM</sup> devices provide the flexibility and fast design turn-around you need for prototyping. Once you are ready for production, the CMOS MegaHAL devices provide the same functionality with Zero Power. All of the ZHAL devices are fully HC/HCT compatible, making them easy to use in TTL and CMOS environments. # Should You Use a PAL, ProPAL, or HAL Device? PAL devices offer the flexibility and convenience needed for prototyping your innovative designs. They provide a means for designing an efficient system by integrating functions and saving you board space. For flexible production, it makes sense to program and test your own PAL devices. This is especially true if you need low volumes per pattern. You always have the option of making last minute design tweaks as you fine tune your system design. Once your production volumes reach a moderate volume of a few thousand devices per year for each pattern, you may wish to dedicate your production resources to newer designs, instead of programming and testing production volumes. Yet in order to be able to make quick design updates, you might not want to commit to a HAL mask. ProPAL devices provide the ideal solution by eliminating programming and testing needs while retaining enough flexibility to accommodate design changes. When you feel that your design has stabilized and your volume has ramped up to several thousand devices per year, a HAL device becomes the most cost effective way to purchase your programmable logic. By shifting the burdens to Monolithic Memories, who can handle large volumes easily, you can concentrate your energies on more productive projects. ### **How Does MMI Do This?** Monolithic Memories takes your proven PAL device design and either arranges to program ProPAL devices in volume, or generates a custom mask for a HAL or ZHAL device. And all # ProPAL<sup>TM</sup>, HAL<sup>®</sup>, and ZHAL<sup>TM</sup> Devices: The Logical Solutions for Volume Programmable Logic without the normal risks inherent in purchasing a semicustom product. Why? Because: - You can prototype your system and initiate production using standard Monolithic Memories PAL devices. You don't have to worry about making a mistake that could put your design schedule in jeopardy. - The nominal Non-Recurring Engineering (NRE) charges for ProPAL and HAL devices are far lower than those normally required for a semicustom circuit. And they can even be amortized over your first production quantity. - You save on the costs of programming devices. This will also shorten your production cycle, since you can plug the devices into the socket with no additional processing. - All of the devices are tested for full functionality before they leave Monolithic Memories. You save on the costs of testing and generating test programs. - Monolithic Memories is geared towards providing volumes of high quality devices. No one knows how to test programmable logic as well as Monolithic Memories. Between the thorough, efficient testing and marking capabilities and the option to provide burn-in for extra reliability, you can obtain a higher quality device that if you did the programming and testing yourself. - MMI can provide custom marking. This saves you the added expense of stripping the mark from standard devices and then remarking them with your own mark. - HAL devices are secure by design. If you prefer ProPAL devices, they can also be secured for you at the factory. - ProPAL device lead time is only 1 to 2 weeks longer than that of unprogrammed PAL devices. - HAL device turn-around time is a mere 6 to 8 weeks or less from acceptance of your design package to receipt of first units \*Floppy disks are accepted in standard DEC® AT-11 (RX01) or RSX-11M®, files 11 format, or an IBM PCTM 5-1/4 in. diskette. IBM compatible (800 or 1600 BPI) nine track magnetic tapes are accepted in unlabeled (card image), files-11, or VAX VMS® backup format. If magnetic media absolutely cannot be provided, legible printouts (signed and dated) from PALASM will be accepted. Please note that magnetic media are required if you have more than 50 vectors. If you find yourself with an unexpected demand, you need not turn away business for lack of HAL device stock. You can always use ProPAL devices to make up for any temporary shortfall. ### How Can You Take Advantage of This? The following are some guidelines which you can use to help convert your designs to ProPAL, HAL or ZHAL devices. #### 1. Send in Your Design You will need to provide your logic equations from either PALASM®, PALASM 2 or ABEL<sup>TM</sup> on magnetic media\*. When Monolithic Memories generates vectors for use in functionally testing your pattern, "seed" vectors are helpful in providing the foundation upon which the final test vectors will be based. A master PAL device containing your design is needed for Monolithic Memories to verify that the pattern you submitted has been correctly processed. If you cannot provide a Monolithic Memories master PAL device, Monolithic Memories will accept your design inputs and provide ProPAL samples for your approval. For your convenience, a checklist is included to help you prepare all of the necessary materials to be submitted to Monolithic Memories. This will also help Monolithic Memories process your design, resulting in smoother and faster turnaround. Copies of this form are available from your Sales Representative, or you can simply copy the attached form. #### 2. MMI Will Verify the Design Upon receiving your design package, Monolithic Memories will enter your design into their computer and verify that there are no format or syntax problems. A fuse map will be generated, and sample ProPAL devices programmed. If any questions are encountered at this stage, they will be resolved with you before any further processing takes place. #### 3. MMI Will Check the Samples If you have approved immediate production of your devices, Monolithic Memories will make a fuse for fuse comparison between the samples and the master device you provide. If there are no discrepancies, test generation will be started immediately (or upon receipt of your purchase order). If you prefer to see programmed sample ProPAL devices prior to initiating production, Monolithic Memories can provide them for your approval before proceeding further. Sample approval is also needed when no master devices are provided or when a discrepancy is found during verification. #### 4. MMI Will Generate Test Vectors A functional test sequence is generated using TGEN<sup>TM</sup>, a proprietary software package. Any seed vectors you provide will be used to help initiate test generation. TGEN will check for hazards and race conditions, monitor fault coverage and systematically add vectors until test coverage goals are met. Monolithic Memories has a test quality standard that sets as a minimum goal 90% coverage of all stuck-at faults. Lower coverage patterns can sometimes be processed as HAL monolithic Memories has a test quality standard that sets as a minimum goal 90% coverage of all stuck-at faults. Lower coverage patterns can sometimes be processed as HAL devices, or it is possible to handle them as ProPAL devices only, but your approval will be needed. If acceptable coverage cannot be obtained, ways of increasing the testability of the design may have to be considered before Monolithic Memories can process the pattern. ### ProPAL<sup>™</sup>, HAL<sup>®</sup>, and ZHAL<sup>™</sup> Devices: The Logical Solutions for Volume Programmable Logic For more detail on exactly how the test coverage is determined, refer to the article "PAL Design Function and Test Vectors" in this Handbook. When suitable test coverage is obtained, as is normally the case, there is no need for you to be involved with vector generation. If, however, you wish to approve the test vectors before production units are generated, the vectors will be made available to you. #### 5. MMI Will Generate Production Units After an acceptable test sequence has been generated, Monolithic Memories will generate the appropriate HAL or ZHAL mask and build the devices. Or, in the case of a ProPAL device, Monolithic Memories will arrange to program and test blank units. ### **Having Your Devices Marked** The standard Monolithic Memories mark consists of the device type, the package type, the date code, and the Monolithic Memories logo. If you wish, you can have the standard marking replaced by a custom marking. The logo and date code are standard, but any other markings can be as you desire. The character and line limitations for the most common packages are in Table 1. If the package you want is not listed, your local representative can help you determine the guidelines you need. #### Whom to Contact When you are ready to put the power of the Monolithic Memories factory to work for you, just contact your local Monolithic Memories sales representative. And let Monolithic Memories take care of your production programming, testing, and marking needs. | PLASTIC | 20 pin (300 mil) | 2 lines/13 characters per line | |---------|------------------|--------------------------------| | 41 | 24 pin (300 mil) | 2 lines/17 characters per line | | CERDIP | 20 pin (300 mil) | 2 lines/16 characters per line | | | 24 pin (300 mil) | 2 lines/17 characters per line | | PLCC | 20 lead | 4 lines/11 characters per line | | | 28 lead | 5 lines/12 characters per line | | | | | Table 1 PAL, HAL and PALASM are registered trademarks of Monolithic Memories, Inc. ProPAL, ZHAL, MegaPAL, MegaHAL and TGEN are trademarks of Monolithic Memories, Inc. ABEL is a trademark of Data I/O Corp. DEC, RSX, VAX, and VMS are registered trademarks of Digital Equipment Corp. IBM PC is a trademark of International Business Machines, Inc. ### HAL/ProPAL CHECKLIST | Company name: | | |---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1982년 1982년 전 1일 | | | Address: | . 그는 그렇게 되는 것 같아. 아이들 그 모든 그 그 모든 그는 그는 그는 그는 그는 것이다. 그 것이다. 그들은 그는 그 그는 그<br>그는 그는 그를 가는 것을 하는 것을 하는 것을 하는 것이 되었다. 그는 것을 하는 | | Contact: | Phone Number: | | | 마르막 등 보통 이 중앙에 발표되었다. 현실 사람들은 동생 그 바라를 가입니다. 그 말라.<br> | | Do you want:HALProPAL | ZHAL | | Part Type: | 마리 B. 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 되는 살림하는 사람들은 사람들은 그는 그를 들어 내린 이렇게 하다. | Customer Part Number: | | What package type do you want? | | | How do you want the devices marked? | | | Standard | 마시 (1986년 1일 전 1987년 1일 전 1987년 1일 | | Custom mark: please specify the mark below. | 는 기업을 받았다. 이 사람들은 1996년 등 기업을 발표하는 것이 가입니다.<br>1987년 - 1984년 전시에 본 기업을 가입하는 전체 1984년 등 전체 1987년 1987년 1 | | Refer to previous page | | | | | | | | | | | | For ProPAL devices, do you want the security fuse blown?_ | e like the cities in the executive constant we will be the | | | | | Design Specification Format: | 가 있는 것이 되었다. 그런 그런 그런 그런 그런 그런 그런 생각하는 것이 되었다.<br>그런 그런 그 | | PALASM PALASM 2 | andrige finance, en electrica de meneral como la companya de la meneral de la companya de la companya de la co<br>En consecuenta de la companya de la companya de la companya de la companya de la companya de la companya de la | | | | | Input medium: 1. 9-track Magnetic (Choose 1 of 3) card image | c Tape 2. Floppy Disk 2. Annual 2. RT-11 | | tard image files-11 | RSX-11M | | VAX VMS b | 그는 그는 이번 사람들이 얼마를 가면 하는 것이 되었다. 그는 사람들이 되었다면 하는 사람들이 되었다면 하는 사람들이 되었다면 살아 없다. | | 2 DALASM prin | tout (signed and dated) | | 3PALASINI PIIII | tout (signed and dated) | | The following items are requested but not required Disease | | | The following items are requested but not required. Please of | crieck if provided: | | | eed vectors | | | Master PAL device | | | <del>ng pagparathing and lead a secondary and a lead and a secondary and a secondary and a secondary and a secondary</del><br>The secondary and a secondary and a secondary and a secondary and a secondary and a secondary and a secondary a | | OP | TIONS | | A I want to start production immediately | B I want to verify the MMI generated sample | | (or upon submittal of purchase order) if: | devices prior to production implementation. | | 1. Design is acceptable; | I want to approve the test vectors prior to | | 2. MMI samples match my master device | production implementation. | | fuse for fuse; | | | 3. Minimum test coverage goals are met. | | | (Master device must be provided.) | | | | | | Please complete this form for each pattern submitted to Mo | | | Submitted by: | Date: | | Title: | | | | | # **Zero Power CMOS Hard Array Logic** ZHAL™ 20A Series #### Features/Benefits - Zero standby power - 25-ns maximum propagation delay - HC and HCT compatible - Space saving PLCC available - Low power alternative for Small and Medium 20-pin PAL® devices, including 16L8/16R8/16R6/16R4 ### Description The Zero Hard Array Logic (ZHAL) devices are ideal in lowpower applications that require high-speed operation. These attributes are achieved through the use of Monolithic Memories' advanced high-speed CMOS process. Now system designers have the option of using a ZHAL device that matches fast PAL device speeds, but with the added advantage of zero standby power. These features are ideal for power-critical areas such as portable digital equipment or lap-top computers. This family of ZHAL devices utilizes a unique architecture that is designed for a high degree of flexibility in implementing most patterns of the listed 20-pin PAL/HAL® devices. Prototyping can be done using standard PAL devices before converting to ZHAL circuits for production. ZHAL devices are fabricated by Monolithic Memories with custom metallization masks defined by a user-supplied HAL Design Specification. The ZHAL option in the PALASM®2 CAD package will confirm whether a design specification will fit within the ZHAL20 architecture. For more information on the ZHAL software, refer to the PALASM 2 User Manual. For evaluation of the ZHAL20A circuit, sample patterns are available. See page 4-13 for details. ### Ordering Information | PART NUMBER | | 40044 | OUTPUTS | | |-------------|-----------------------|-------|---------|-----| | | PACKAGE | ARRAY | СОМВ | REG | | ZHAL10H8A | and the second second | 10 | 8 | | | ZHAL12H6A | | 12 | 6 | | | ZHAL14H4A | | 14 | 4 | | | ZHAL16H2A | N, NL | 16 | 2 | | | ZHAL16C1A | | 16 | 2 | _ | | ZHAL10L8A | | 10 | 8 | | | ZHAL12L6A | | 12 | 6 | | | ZHAL14L4A | | 14 | 4 | | | ZHAL16L2A | | 16 | 2 | - | | ZHAL16L8A | | 16 | 8 | _ | | ZHAL16R8A | N, NL | 16 | | 8 | | ZHAL16R6A | | 16 | 2 | 6 | | ZHAL16R4A | | 16 | 4 | 4 | | ZHAL16P8A | | 16 | 8 | | | ZHAL16RP8A | N, NL | 16 | _ | 8 | | ZHAL16RP6A | | 16 | 2 | 6 | | ZHAL16RP4A | | 16 | 4 . | 4 | ## Zero Power CMOS Hard Array Logic ZHAL<sup>TM</sup> 20A Series # Zero Power CMOS Hard Array Logic ZHALTM 20A Series ## **Absolute Maximum Ratings** | Supply voltage, V <sub>CC</sub><br>C input voltage, V <sub>I</sub> | | | -0.5V to V +0.5 | |---------------------------------------------------------------------------|-----|------|--------------------------------| | OC output voltage, V <sub>O</sub> | | <br> | -0.5V to V <sub>CC</sub> + 0.5 | | OC output voitage, VoOC output source/sink current per output pin, Io | | <br> | ± 35m | | OC V <sub>CC</sub> or ground current, I <sub>CC</sub> or I <sub>GND</sub> | | <br> | ± 100m | | nput diode current, luc: | | | 하이지 않아 하셨다는 그 바람이 | | V <sub>I</sub> < 0 | | <br> | –20m | | V <sub>I</sub> > V <sub>CC</sub> | | <br> | + 20m | | Output diode current, lov: | 3.0 | | 그렇게 하기 되는 화되었다 | | V <sub>O</sub> < 0 | | | | | V <sub>0</sub> > V <sub>cc</sub> | | <br> | + 20m | | Storage temperature | | <br> | 65°C to 150° | ## **Operating Conditions** | | | | IN | DUSTR | AL | СО | MMERC | IAL | | |-----------------|--------------------------------------------|---------------------------------------------------|-----|-------|-----|------|-------|------|------| | SYMBOL | PARAN | METER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | t <sub>w</sub> | Width of clock | | 15 | 10 | | 15 | 10 | | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 16R4A, 16R6A, 16R8A,<br>16RP4A, 16RP6A,<br>16RP8A | 20 | 13 | | 20 | 13 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | t <sub>A</sub> | Operating free-air tempera | ture | -40 | 25 | 85 | 0 | 25 | 75 | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARA | METER | TEST | CONDITIONS | MIN | TYP | MAX | UNIT | |--------------------|-----------------|------------------------|------------------------------|---------------------------------------------|-------------------|-------|----------------------------|----------| | V <sub>IL</sub> 1 | Low-level inpu | it voltage | | | 0 | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level inpu | ut voltage | | | 2 | | V <sub>CC</sub> | ٧ | | l <sub>iL</sub> | Low-level inpu | it current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | 34.33 | -1 | μΑ | | | High-level | Pin 8 <sup>2</sup> | | | | 1 | 10 | μΑ | | I <sub>II</sub> | input current | All other pins | V <sub>CC</sub> = MAX | V <sub>i</sub> = GND | | | 1 | μΑ | | V | | | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.1 | 0.4 | v | | V <sub>OL</sub> | Low-level outp | out voitage | V <sub>CC</sub> = 5V | l <sub>OL</sub> = 1μA | | | 0.05 | V. | | V | | | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -6mA | 3.76 <sup>3</sup> | 4.1 | Paralli (1)<br>Pijes grije | v | | V <sub>OH</sub> | High-level out | put voitage | V <sub>CC</sub> = 5V | l <sub>OH</sub> = -1μA | 4.95 | | | <b>Y</b> | | I <sub>OZL</sub> 4 | O# | | | V <sub>O</sub> = GND | | 0 | -10 | μΑ | | I <sub>OZH</sub> 4 | Off-state outp | ut current | V <sub>CC</sub> = MAX | $V_{\rm O} = V_{\rm CC}$ | | 0 | 10 | μΑ | | l <sub>cc</sub> | Standby suppl | y current <sup>5</sup> | $I_0 = 0 \text{mA}, V_1 = 0$ | AND or V <sub>CC</sub> | | 0 | 100 | μΑ | | 100 | Operating sup | ply current | f = 1MHz, I <sub>O</sub> = 0 | mA, V <sub>I</sub> = GND or V <sub>CC</sub> | | 2 | 56 | mA | #### Zero Power CMOS Hard Array Logic ZHALTM 20A Series ## Switching Characteristics Over Operating Conditions | ovaroo: | <b>D.</b> | .ctc | TEST | IN | DUSTR | AL | СО | MMERC | IAL | | |---------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------|------------|-------|-----|----------------------|-------|-----|------| | SYMBOL | PARAM | AEIER | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>PD</sub> | Input or feedbac<br>10H8A, 12H6A,<br>16C1A, 10L8A,<br>16L2A, 16L8A,<br>16P8A, 16RP6A | 14H4A, 16H2A,<br>12L6A, 14L4A,<br>16R6A, 16R4A, | | | 15 | 25 | | 15 | 25 | ns | | t <sub>CLK</sub> | Clock to output<br>16R4A, 16R6A,<br>16RP4A, 16RP6 | 16R8A, | $R_L = 1K\Omega$<br>$C_L = 50pF$ | San San ya | 10 | 15 | egrek fyr<br>Târek i | 10 | 15 | ns | | t <sub>PZX</sub> | Input to output enable | 16L8A, 16R4A,<br>16R6A, 16P8A, | [석호 : 42] : .<br>[1] : | | 12 | 25 | An Lewis | 12 | 25 | ns | | t <sub>PXZ</sub> <sup>7</sup> | Input to output disable | 16RP4A,<br>16RP6A | | | 14 | 25 | | 14 | 25 | ns | | t <sub>PZX</sub> <sup>7</sup><br>t <sub>PZX</sub> | Pin 11 to<br>output<br>disable/enable | 16R4A, 16R6A,<br>16R8A,<br>16RP4A, | | | 12 | 15 | | 12 | 15 | ns | | f <sub>MAX</sub> | Maximum frequency | 16RP6A,<br>16RP8A | | 28.5 | 40 | | 28.5 | 40 | | MHz | Notes: Apply to electrical and switching characteristics. - 2. Pin 8 (PRELOAD pin). Applies to all devices whether registered or non-registered. - 3. JEDEC standard no. 7 for high-speed CMOS devices. - 4. Applies to pins 12 to 19. - 5. Disable output pins = V<sub>CC</sub> or GND. 6. Add 3mA per additional 1.0MHz of operation over 1MHz. - 7. C<sub>L</sub> = 5pF. <sup>1.</sup> These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment. #### Switching Test Load Notes: 1. CL includes probe and jig capacitance. - 2. When measuring $t_{\text{PLZ}}$ and $t_{\text{PZL}}$ , S1 is tied to $V_{\text{CC}}$ . When measuring $t_{PHZ}$ and $t_{PZH}$ , S1 is tied to ground. $t_{PZX}$ is measured with $C_L$ = 50pF. $t_{PXZ}$ is measured with $C_L$ = 5pF. When measuring propagation delay times of 3-state outputs, S1 is open, i.e., not connected to $V_{\mbox{\footnotesize CC}}$ or ground. - 3. Waveform 1 is for an output with internal conditions such that the output is Low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is High except when disabled by the output control. #### Output Register PRELOAD<sup>†</sup> The PRELOAD function allows the register to be loaded from data placed on the output pins. This feature aids functional testing of state sequencer designs by allowing direct setting of output states for improved test coverage. The procedure for PRELOAD is as follows: - 1. Raise V<sub>CC</sub> to 4.5V. - 2. Disable output registers by setting pin 11 to VIH. Set pin 1 - 3. Apply $V_{\rm IL}/V_{\rm IH}$ to all registered output pins. - Pulse pin 8 to V<sub>p</sub> (12V), then back to 0V. - 5. Remove $V_{IL}/V_{IH}$ from all registered output pins. - 6. Lower pin 11 to $V_{\rm IL}$ to enable the output registers. - 7. Verify for V<sub>OL</sub>/V<sub>OH</sub> at all registered output pins. † Note: Only applies to parts with output registers. Typical $t_{sup} = 50$ ns = 100ns t<sub>wp</sub> = 50ns = 30µA (Pin 8) #### **Enable/Disable Delay** ## Schematic of Inputs and Outputs ## 4 #### Features/Benefits - Demonstrates all features of ZHAL20A product - 4-bit up/down counter with reset - 3-bit shifter - 25-ns maximum propagation delay - Zero standby power #### **Description** The ZHAL20A Evaluation Pattern is provided as an example of the features and characteristics of the ZHAL20A Series products. This design consists of two functionally independent patterns: a 4-bit up/down counter and a 3-bit shifter. The 4-bit counter can count up or count down and has reset capability. These features are controlled by two control signals: UP and CNTRSET (Count Reset). When UP is high, the counter counts up. When UP is low, the counter counts down. CNTRSET overrides the count function and resets the counter to all ones, synchronous with the clock. The 3-bit shifter shifts data bits by 0, 1 or 2 positions. The three bits of the shifter are enabled when EN (enable) is high, and are disabled (high-Z) when EN is low. The PALASM®2 software file and simulation results are shown on the next page. Below are the function tables that summarize the functions of the counter and the shifter. #### Counter Function Table | ŌĒ | UP | CNTRSET | CLK | Q3-Q0 | OPERATION | |----|----|---------|-----|-----------|-----------| | Н | Х | Х | Х | Z | High-Z | | L | Н | L | 1 | Q plus 1 | Increment | | L | L | L | 1 | Q minus 1 | Decrement | | L | Х | н | 1 | High | Reset | H=HIGH voltage level L=LOW voltage level X=Don't care Z=High impedance (off) state †= LOW-to-HIGH clock transition ## Logic Symbol #### Shifter Function Table | EN | l1 | 10 | Y2 | Y1 | YO | OPERATION | |----|----|----|----|----|----|--------------| | L | X | х | Z | Z | Z | High-Z | | Н | L | L | D2 | D1 | DO | No operation | | Н | L | Н | DO | D2 | D1 | Shift by one | | н | Н | L | D1 | D0 | D2 | Shift by two | ## PALASM Design Specification ``` PDS CONVERSION FILE PATTERN EXAMPLE REVISION 1.00 AUTHOR JOHN DOE COMPANY MONOLITHIC MEMORIES, INC DATE 9/23/85 CHIP zzz PAL16RP4 CLK IO I1 DO D1 D2 EN UP CNTRSET GND /OE Y2 NC Q1 Q2 Q3 Q0 Y1 Y0 VCC EQUATIONS Y0 = /I1*/I0*/D0 + /I1* I0*/D1 + I1*/I0*/D2 Y0.TRST = EN Y1 = /I1*/I0*/D1 + /I1* I0*/D2 + I1*/I0*/D0 Y1.TRST = EN Y2 = /|1+/|0+/|2| + /|1+|10+/|0| + |1+/|0+/|0| Y2.TRST = EN Q0 :=/Q0 + CNTRSET Q1 :=/Q1* Q0* UP + Q1* Q0*/UP + Q1*/Q0* UP +/Q1*/Q0*/UP + CNTRSET -- CRIRSET +/Q2*/Q1*/Q0*/UP + Q2*/Q1* UP + Q2* Q1*/Q0 +/Q2* Q1* Q0* UP + Q2* Q0*/UP ``` #### Simulation Results + Q3\* Q0\*/UP +/Q3\*\Q2\*\Q1\*\Q0\*\UP +/Q3\*\Q2\*\Q1\*\Q0\*\UP + Q3\*\Q2\*\Q1 + Q3\*\Q2\*\Q1 + Q3\*\Q2\*\Q1 + Q3\*\Q1\*\Q0 + Q3\*\Q1\*\Q0 Q3 := CNTRSET + 03\* PALASM SIMULATION HISTORY LISTING 00\*/UP ``` CLK XXTITITITH HAITITITI TITITITIT TITITITIT XXTITITITI THERIHHHH HHHHHHHHH HHHHHHHHH TO XXLLLLLLIT ITHHHHHHHH HHHHHHHHH HHHHHHHHH Dl EN UP CNTRSET /0E Y2 Q1 Q2 Q3 Q0 Y1 Y0 ``` #### Simulation File ``` SIMULATION TRACE_ON CLK IO I1 DO D1 D2 EN UP CNTRSET /OE Y2 Q1 Q2 Q3 Q0 Y1 Y0 SETF /CLK /OE /EN SETF OE EN /I1 /IO /D2 /D1 /DO Y2 Y1 YO CNTRSET CLOCKF CLK CHECK Q3 Q2 Q1 Q0 SETF /I1 /I0 /D2 /D1 /D0 Y2 Y1 Y0 /CNTRSET UP CLOCKF CLK CHECK /Q3 /Q2 /Q1 /Q0 SETF /I1 IO D2 /D1 D0 /Y2 /Y1 Y0 CLOCKF CLK CHECK /Q3 /Q2 /Q1 Q0 SETF I1 /I0 /D2 D1 /D0 /Y2 Y1 Y0 CLOCKF CLK CHECK /Q3 /Q2 Q1 /Q0 SETF OF /CNTRSET UP CHECK /Q3 /Q2 Q1 Q0 SETF OF /CNTRSET UP CHECK /Q3 Q2 /Q1 /Q0 SETF OF /CNTRSET UP CLOCKF CLK CHECK /Q3 Q2 /Q1 Q0 SETF OE /CNTRSET UP CHECK /Q3 Q2 Q1 /Q0 SETF OF /CNTRSET UP CHECK /Q3 Q2 Q1 Q0 SETF OE /CNTRSET UP CLOCKF CLK CHECK Q3 /Q2 /Q1 /Q0 SETF OE /CNTRSET UP CLOCKF CLK CHECK Q3 /Q2 /Q1 Q0 SETF OE /CNTRSET UP CHECK Q3 /Q2 Q1 /Q0 CHECK 03 /02 01 00 SETF OF /CNTRSET UP CHECK Q3 Q2 /Q1 /Q0 SETF OE /CNTRSET UP CLOCKF CLK CHECK Q3 Q2 /Q1 Q0 SETF OE /CNTRSET UP CHECK Q3 Q2 Q1 /Q0 ``` TRACE\_OFF #### Features/Benefits - Cost-effective mask-programmable complement to PAL64R32 user-programmable device - CMOS technology provides zero standby power - High speed with 55ns maximum propagation delay - High density with 32 highly-flexible macrocells and global connectivity - Product term sharing, selectable output polarity, and register bypass for high logic efficiency - Individual clocks for 4 banks of 8 registers - Register preload for easier test generation - HC/HCT level compatible for use in CMOS/TTL systems #### Description The ZHAL64R32 circuit is a high-density logic device with thirty-two flexible macrocells. Each macrocell consists of a registered sum of products with feedback, forming a one-bit state machine. The PAL/ZHAL64R32 device can implement over 1500 equivalent logic gates. The MegaHAL<sup>TM</sup> circuit features product term sharing between output pairs. This allows sixteen product terms to be shared mutually exclusively between outputs. Selectable polarity allows the output to be either active low or active high, depending on the sense of the equation. Registers can be bypassed in banks of eight, leaving combinatorial outputs. Each register bank has its own clock, preset, preload, and enable controls for independent operation. The register pre- load pin allows test vectors to be loaded directly into the registers for control of present state conditions for testing. #### **Design Procedures** The zero-power ZHAL64R32 device is a CMOS, mask-programmable version of the bipolar PAL64R32 circuit. Prototyping can be done with the user-programmable PAL® circuit before committing to a dedicated mask. Thus the Mega-PALTM/MegaHAL products combine the instant prototyping of the PAL circuit with the cost-effective, zero power ZHALTM circuit. To initiate a design with the ZHAL64R32 device, the PAL64R32 circuit is used to program and debug the design with PALASM®2 software. The resulting "PAL Device Design Specification" is submitted to Monolithic Memories, and the ZHAL circuit option is produced. A ZHAL32R16 option is also available. For details contact a Monolithic Memories representative. ## **Ordering Information** ## Pin Configuration — PLCC | | | | СО | MMERC | IAL | IN | DUSTRI | AL | | |-------------------|------------------------------|------------------------|------|-------|------|-----|--------|-----|------| | SYMBOL | P.<br>P. Walang and A. Santa | ARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | ٧ | | | Width of clock | Low | 20 | 10 | | 20 | 10 | | | | ₩. | Width of Clock | High | 20 | 10 | | 20 | 10 | | ns | | t <sub>su</sub> 1 | Setup time from inpu | t or feedback to clock | 40 | 24 | | 45 | 24 | | ns | | t <sub>h</sub> | Hold time | | 0 | -10 | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air ten | nperature | 0 | 25 | 75 | -40 | 25 | 85 | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TEST | CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|-------------------------------------|-------------------------|------------------------------------|-------------------|----------|-----------------|------| | V <sub>IL</sub> 2 | Low-level input voltage | | | 0 | 3 | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level input voltage | | | 2 | 7 a | V <sub>CC</sub> | ٧ | | I <sub>IL</sub> 5 | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | | -1 | μΑ | | I <sub>IH</sub> 5 | High-level input current | V <sub>CC</sub> = MAX | $V_I = V_{CC}$ | | | 1. | μΑ | | | | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 4mA | | 0.1 | 0.4 | v | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = 5V | $I_{OL} = 1\mu A$ | | | 0.05 | V | | ., | | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -4mA | 3.76 <sup>3</sup> | 4.1 | | v | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = 5V | $I_{OH} = -1\mu A$ | 4.95 | | | \ | | I <sub>OZL</sub> <sup>5</sup> | ~ | V = MAV | V <sub>O</sub> = GND | | 0 | -10 | | | I <sub>OZH</sub> <sup>5</sup> | Off-state output current | V <sub>CC</sub> = MAX | $V_O = V_{CC}$ | | 0 | 10 | μΑ | | | Standby supply current <sup>4</sup> | $I_O = 0$ mA, $V_I = 0$ | ND or V <sub>CC</sub> <sup>4</sup> | | 0 | 100 | | | l <sub>cc</sub> | Operating supply current | $I_O = 0$ mA, $V_I = 0$ | ND or V <sub>CC</sub> | See gra | ph on pa | ge 4-20 | | ## Switching Characteristics Over Operating Conditions | OVMDOL | | | TEST | co | MMERC | IAL | IN | DUSTRI | AL | UNIT | |--------------------|------------------------------------------------------------------|---------------|-----------------------|-----|-------|-----|-----|--------|-----|------| | SYMBOL | PARAMETE | | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | . 1 | Input or feedback to | Active<br>low | | | 34 | 55 | | 34 | 58 | | | t <sub>PD</sub> 1 | output | Active high | | | 34 | 55 | | 34 | 58 | ns | | t <sub>CLK</sub> | Clock to output or fee | edback | $R_L = 1K\Omega$ | | 14 | 22 | | 14 | 25 | ns | | t <sub>PZX</sub> | Output enable | | C <sub>L</sub> = 50pF | | 19 | 30 | | 19 | 30 | ns | | t <sub>PZX</sub> | Output disable | | | | 18 | 30 | | 18 | 30 | ns | | t <sub>PRH</sub> | Preset to output | | | | 23 | 35 | | 23 | 40 | ns | | f <sub>MAX</sub> 1 | Maximum frequency,<br>f = 1/(t <sub>SU</sub> +t <sub>CLK</sub> ) | | | 16 | 25 | | 14 | 25 | | MHz | Notes: 1. Maximum 32 inputs per product term. <sup>2.</sup> V<sub>IL</sub> and V<sub>IH</sub> are absolute voltages with respect to the ground on the device and includes all overshoots due to system and/ or tester noise. Do not attempt to test these values without suitable equipment. Per JEDEC standard no. 7 for high-speed CMOS devices. Disable output pins = V<sub>CC</sub> or GND. <sup>5.</sup> I/O pin leakage is the worst case of $I_{OZX}$ or $I_{IX},$ i.e., $I_{OZH}$ and $I_{IL}.$ ## **Absolute Maximum Ratings** | Supply voltage, V <sub>CC</sub><br>DC input voltage, V <sub>I</sub> | | | 0.5V to 7.0 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------|------------------------------| | DC input voltage, V <sub>1</sub> | | | 0.5V to V <sub>CC</sub> +0.5 | | OC output voltage, V <sub>O</sub><br>OC output source/sink current per output p<br>OC V <sub>CC</sub> or ground current, I <sub>CC</sub> or I <sub>GND</sub> | | | 0.5V to V <sub>CC</sub> +0.5 | | C output source/sink current per output | oin, I <sub>O</sub> | | ± 35m | | OC V <sub>CC</sub> or ground current, I <sub>CC</sub> or I <sub>GND</sub> | | | ± 100m | | nput diode current, I <sub>IK</sub> : V <sub>I</sub> < 0 | | | 가 하시 가입하는 기원. | | V <sub>1</sub> < 0 | | | –20m | | $V_1 > V_{CC}$ | | | + 20m | | $V_{\rm l}^{\rm l} > V_{\rm CC}$ | | 사람이 있다는 이번 사람이다. | | | V <sub>O</sub> < 0 | | ., | –20m | | V <sub>O</sub> > V <sub>CC</sub> | | | + 20m | | V <sub>O</sub> > V <sub>CC</sub> trorage temperature | | | 65°C to +150° | | nput rise and fall times | | | 0 to 500r | ## **Switching Test Load** ## **Enable/Disable Delay** ## **Switching Waveforms** ## Schematic of Inputs and Outputs Notes: 1. CL includes probe and jig capacitance. - 2. When measuring $t_{PLZ}$ and $t_{PZL}$ , S1 is tied to $V_{CC}$ . When measuring $t_{PHZ}$ and $t_{PZH}$ , S1 is tied to ground. When measuring propagation delay times of 3-state outputs, S1 is open, i.e., not connected to $V_{CC}$ or ground. - 3. Waveform 1 is for an output with internal conditions such that the output is Low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is High except when disabled by the output control. ## ZHAL64R32 Testability Features Testing Conditions | OVMOOL | | CO | MMERC | IAL | IN | DUSTRI | AL | | |-------------------|----------------------|-----|-------|------|-----|--------|-----|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>wp</sub> | Preload pulse width | 35 | | | 45 | | | ns | | t <sub>sup</sub> | Preload setup time | 50 | | | 60 | | | ns | | t <sub>hp</sub> | Preload hold time | 5 | | | 10 | | | ns | | t <sub>PRW</sub> | Preset pulse width | 25 | | 1 44 | 30 | | | ns | | t <sub>PRR*</sub> | Preset recovery time | 45 | | | 50 | | | ns | <sup>\*</sup> Includes setup time for preset data feedback, Maximum 32 inputs per product term. #### **Preload Feature** Preload pins are provided to enable the testability of each state in state-machine design. Typically for a state machine there are many unreachable states for the registers. These states, and the logic which controls them, are untestable without a way to "set-in" the desired starting state of the registers. In addition, long test sequences are sometimes needed to test a state machine simply to reach those starting states which are legal. Since complete logic verification is needed to ensure the proper exit from "illegal" or unused states, a way to enter these states must be provided. The ability to preload each bank of registers independently to any state is provided in this device. To use the preload feature, several steps must be followed. First, a high level on an assertive-low output enable pin disables the outputs for that bank of registers. Next, the data to be loaded is presented at the output pins. This data is then loaded into the register by placing a low level on the PRELOAD pin. PRELOAD is asynchronous with respect to the clock. #### **Preset Feature** Register banks of eight may be PRESET to all highs on the outputs by setting the PRESET pin (PS) to a low level. Note from the Logic Diagram that when the state of an output is high, the state of the register is low due to the inverting three-state buffer. 117-00170m <sup>3</sup>reload data must be held constant while the PRELOAD pin is low. ## I<sub>CC</sub> Characteristics vs. Frequency #### **Commercial Operating Conditions** TA = 0°C TA = 75°C #### **Industrial Operating Conditions** \_\_\_\_ = MAXIMUM VALUE \_\_\_ = V<sub>CC</sub> = 5V WITH 32 INPUTS MAX PER PRODUCT TERM ## 4 ## AC Characteristics vs. Loading #### **Commercial Operating Conditions** TA = 75°C ...... TA = 75°C OP0007014 ## **Industrial Operating Conditions** TA = 85°C пероперы TA = 85°C OP000901 #### How To Use The PAL/ZHAL64R32 The following description and example demonstrate the functionality of the PAL/ZHAL64R32, using PALASM 2 software. Conventions for writing equations conform with the PAL Design Specification format. Features to be programmed into the PAL device are completely specified by the equations and automatically configured by PAL device assemblers. #### **Register Bypass** Outputs within a bank must either be all registered or all combinatorial. Whether or not a bank of registers is bypassed depends on how the outputs are defined in the equations. A colon followed by an equal sign [:=] specifies a registered output with feedback which is updated after the low-to-high transition of the clock. An equal sign [ = ] defines a combinatorial output which bypasses the register. Registers are bypassed in banks of eight. Bypassing a bank of registers eliminates the feedback lines for those outputs. ### **Output Polarity** Output polarity is defined by comparison of the pin list and the equations. If the logic sense of a specific output in the pin list is different from the logic sense of that output as defined by its equation, the output is inverted or active low polarity. If the logic sense of a specific output in the pin list is the same as the logic sense of that output as defined by its equation, the output is active high polarity. ### **Product Term Sharing** The basic configuration is sixteen product terms shared between two output cells. For a typical output pair, each product term can be used by either output; but, since product term sharing is exclusive, a product term can be used by only one output, not both. If equations call for both outputs to use the same product term, two product terms are generated, one for each output. This should be taken into account when writing equations. PAL device assemblers configure product terms automatically. This example on the following page uses the 84-pin package. Four output equations are shown to demonstrate functionality. Pin names are arbitrary. TITLE ZHAL64R32 DESIGN EXAMPLE USING PALASM 2 PATTERN EXAMPLE.PDS REVISION PALASM 2 VERSION NAME AUTHOR COMPANY MONOLITHIC MEMORIES, INC. DATE 1986 #### CHIP FUNCTIONALITY EXAMPLE PAL64R32 Il 12 I3 I4 I5 I6 I7 I8 /PL1/PS1 GND CLK1 /OE1 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15 Q16 /OE2 CLK2 VCC /PS2 /PL2 I9 I10 I11 I12 I13 I14 I15 I16 I17 I18 I19 I20 I21 I22 I23 I24 /PL3 /PS3 GND CLK3 /OE3 Q17 Q18 Q19 Q20 Q21 Q22 Q23 Q24 Q25 Q26 Q27 Q28 Q29 Q30 Q31 Q32 /OE4 CLK4 VCC /PS4 /PL4 I25 I26 I27 I28 I29 I30 I31 I32 #### **FOUATTONS** ;ACTIVE LOW COMBINATORIAL /01 = I1\*I2\*I3;OUTPUT. SINCE THE + Ill\*I27\*/I32\*Q9 + I4\*/I9\*Q10 ; REGISTERS ARE BYPASSED + I1\*I2\*I7\*/Q27\*Q15\*/Q32 ;FOR THIS BANK, THE + I8\*/Q13\*/Q32 ;OUTPUTS CANNOT FEED ; BACK INTO THE ARRAY. = I1\*I2\*I3 ;ACTIVE HIGH 02 ; COMBINATORIAL OUTPUT. + I27\*/Q12 + I15\*/I32\*/Q9 ;Q2 USES THE REMAINING +/I1\*I2\*/I3\*I4\*Q27 ;11 PRODUCT TERMS + 010\*011 ;AFTER /Q1 USED 5. ;NOTE THAT THE FIRST +/Q32 ;PRODUCT TERM IS ;CREATED TWICE. + I4\*I9\*I11\*Q12\*/Q27 + Q9\*Q27\*/Q15 + I6\*17\*/18\*/19\*/110\*/112 + I6\*Q12\*Q15 + Ill\*/Q15 ;ACTIVE LOW REGISTERED /Q9 := I2\*/I4\*Q15 +/11\*14\*19\*115\*132 ;OUTPUT. SOME OF THE + Q32\*/Q15 ;OUTPUT SIGNALS ARE FED ;BACK INTO THE ARRAY, ;SINCE THE REGISTER IS +/Q9\*I3 + I8\*/Q13\*/Q32 + I5\*/I6\*I11\*/Q15 ;USED. + I12\*I13\*I27 ;ACTIVE HIGH REGISTERED Q10 := I3\*/I8 + I9\*Q15\*/Q32 ; OUTPUT. + I7\*I8\*/I9\*/Q11\*/Q27\*/Q32 COMBINATORIAL **ACTIVE HIGH** REGISTERED/ **ACTIVE LOW** PI Q n ō CLK 3 REGISTERED/ **ACTIVE HIGH** PI Q ō CLK COMBINATORIAL / **ACTIVE LOW** TB02010M ## Zero Power CMOS Hard Array Logic ZHAL<sup>TM</sup> 24A Series #### Features/Benefits - Zero standby power - Low power operation - High-speed CMOS technology - HC and HCT compatible - 24-pin SKINNYDIP® and 28-pin PLCC packages save space - Low power alternative for most 24-pin PAL® devices, including 20L8/20R8/20R6/20R4 #### Description This family of Zero Power Hard Array Logic (ZHAL) devices utilizes a unique architecture that is designed for a high degree of flexibility in implementing most patterns of the listed 24-pin PAL/HAL® devices. Prototyping should be done using standard PAL devices before converting to ZHAL circuits for production. ZHAL devices are fabricated by Monolithic Memories with custom metallization masks defined by a user-supplied HAL Design Specification. The ZHAL devices are ideal in low-power applications that require high-speed operation. These attributes are achieved through the use of Monolithic Memories' advanced high-speed CMOS process. Now system designers have the option of using a ZHAL device that matches fast PAL device speeds, but with the added feature of zero standby power. These features are needed in power-critical areas such as portable digital equipment or lap-top computers. The procedures for designing with Monolithic Memories' ZHAL devices are shown in the flow chart on the next page. The ZHAL option in the PALASM®2 CAD package will confirm whether a design specification will fit within the ZHAL architecture. For more information on the ZHAL software, refer to the PALASM 2 User Manual. For evaluation of the ZHAL24A circuit, sample patterns are available. See the description in this document for details. ### **Ordering Information** | | | ARRAY | OUTF | UTS | |-------------|---------|--------|------|-----| | PART NUMBER | PACKAGE | INPUTS | СОМВ | REG | | ZHAL12L10A | NS, NL | 12 | 10 | | | ZHAL14L8A | NS, NL | 14 | 8 | - | | ZHAL16L6A | NS, NL | 16 | 6 | - | | ZHAL18L4A | NS, NL | 18 | 4 | · | | ZHAL20L2A | NS, NL | 20 | 2 | - | | ZHAL20C1A | NS, NL | 20 | 2 | _ | | ZHAL20L8A | NS, NL | 20 | 8 | _ | | ZHAL20R8A | NS, NL | 20 | _ | 8 | | ZHAL20R6A | NS, NL | 20 | 2 | 6 | | ZHAL20R4A | NS, NL | 20 | 4 | 4 | | ZHAL20L10A | NS, NL | 20 | 10 | - | | ZHAL20X10A | NS, NL | 20 | _ | 10 | | ZHAL20X8A | NS, NL | 20 | 2 | 8 | | ZHAL20X4A | NS, NL | 20 | 6 | 4 | | ZHAL20S10A | NS, NL | 20 | 10 | | | ZHAL20RS10A | NS, NL | 20 | _ | 10 | | ZHAL20RS8A | NS, NL | 20 | 2 | 8 | | ZHAL20RS4A | NS, NL | 20 | 6 | 4 | #### **ZHAL 24A Device Generation Flow** #### **ZHAL24A DEVICE GENERATION FLOW** ZHAL12L10A 4 3 2 1 28 27 26 5 6 24 7 INPUT 23 **ACTIVE** AND 22 8 LOW OR OUTPUT 9 LOGIC 21 CELLS **ARRAY** 10 20 19 GND 12 13 14 15 16 17 18 CD01910M | | /MBOL PARAMETER | | DUSTRI | AL | СО | MMERC | IAL | | |-----------------|--------------------------------|-----|--------|-----|------|-------|------|------| | SYMBOL | PAHAMEIEH | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | TA | Operating free-air temperature | -40 | 25 | 85 | 0 | 25 | 75 | °C | ### **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARAMETER | TES1 | CONDITIONS | MIN | TYP | MAX | UNIT | |--------------------|-----------------------------------------|------------------------------|---------------------------------------------|-------------------|-----|-----------------|------| | V <sub>IL</sub> 1 | Low-level input voltage | | | 0 | | 0.8 | ٧ | | V <sub>IH</sub> 1 | High-level input voltage | | | 2 | | V <sub>CC</sub> | ٧ | | 1 <sub>IL</sub> | Low-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | | -1 | μΑ | | l <sub>iH</sub> | High-level input current | V <sub>CC</sub> = MAX | $V_{I} = V_{CC}$ | | | 1 | μΑ | | V | | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.1 | 0.4 | v | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = 5V | $I_{OL} = 1\mu A$ | | | 0.05 | , v | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -6mA | 3.76 <sup>2</sup> | 4.1 | | v | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = 5V | $I_{OH} = -1\mu A$ | 4.95 | | | , v | | I <sub>OZL</sub> 3 | <b>~</b> | V E NAV | V <sub>O</sub> = GND | | 0 | -10 | μΑ | | I <sub>OZH</sub> 3 | Off-state output current | V <sub>CC</sub> = MAX | $V_O = V_{CC}$ | | 0 | 10 | μΑ | | | Standby supply current <sup>4</sup> | $I_O = 0$ mA, $V_I = 0$ | AND or V <sub>CC</sub> | | 0 | 100 | μΑ | | lcc | Operating supply current | f = MHz, I <sub>O</sub> = 0n | nA, V <sub>I</sub> = GND or V <sub>CC</sub> | | 2 | 5 <sup>5</sup> | mA | ## Switching Characteristics Over Operating Conditions | SYMBOL PARAMETER | | TEST<br>CONDITIONS | INDUSTRIAL | | | со | UNIT | | | |------------------|-----------------|----------------------------------|------------|-----|-----------------|-----|------|-----------------|------| | SYMBOL | PANAMEIER | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | t <sub>PD</sub> | Input to output | $R_L = 1K\Omega$<br>$C_L = 50pF$ | | 13 | 25 <sup>6</sup> | | 13 | 25 <sup>6</sup> | ns | Notes: 1. These are absolute voltages with respect to the the ground pin on the device and includes all overshoots due to system and/ or tester noise. Do not attempt to test these values without suitable equipment. - 2. JEDEC standard no. 7 for high-speed CMOS devices. - 3. Applies to pins 14-23 for DIP (pins 17, 18, 20-27 for PLCC). - 4. Disable output pins = V<sub>CC</sub> or GND. 5. Add 3mA per additional 1.0MHz of operation over 1MHz. - 6. For outputs with more than 12 inputs in a product term, $t_{PD}$ = 30ns. | 0/4/001 | PARAMETER | | | DUSTR | IAL | СО | | | | |-----------------|--------------------------------------------|---------------------------|-----------------|-------|-----|-----------------|-----|------|------| | SYMBOL | PANAMETER | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | t <sub>w</sub> | Width of clock | | 15 | 4 | 1.5 | 15 | 4 | 1 | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 20R8A,<br>20R6A,<br>20R4A | 20 <sup>1</sup> | 11 | | 20 <sup>1</sup> | 11 | | ns | | t <sub>h</sub> | Hold time | 20117 | 0 | -10 | | 0 | -10 | | ns | | TA | Operating free-air temperature | | -40 | 25 | 85 | 0 | 25 | 75 | °C | #### **Electrical Characteristics** Over Operating Conditions | SYMBOL | PARA | METER | TEST ( | CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------|-----------------|------------------------|-------------------------------|--------------------------------------------|---------|---------|-----------------|----------| | V <sub>IL</sub> <sup>2</sup> | Low-level inpu | t voltage | | | 0 | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level inpu | ut voltage | | | 2 | 10.0700 | V <sub>CC</sub> | ٧ | | I <sub>IL</sub> | Low-level inpu | t current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | | -1 | μΑ | | 1 | High-level | Pin 10 <sup>3</sup> | V - MAY | V _ V | | 8 | 30 | μΑ | | I <sub>IH</sub> | input current | All other pins | V <sub>CC</sub> = MAX | $V_{I} = V_{CC}$ | | - | 1 | μΑ | | V | I our loved out | uit vieltees | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.1 | 0.4 | V | | V <sub>OL</sub> | Low-level outp | out voitage | V <sub>CC</sub> = 5V | $I_{OL} = 1\mu A$ | | 1.4. | 0.05 | <b> </b> | | V | High-level out | nut valtaga | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -6mA | 3.764 | 4.1 | | V | | V <sub>OH</sub> | nigh-level out | put voltage | V <sub>CC</sub> = 5V | $I_{OH} = -1\mu A$ | 4.95 | | | <b>'</b> | | I <sub>OZL</sub> 5 | Off state suits | ut aussant | V - MAY | V <sub>O</sub> = GND | 11.0 | 0 | -10 | μΑ | | I <sub>OZH</sub> 5 | Off-state outp | ut current | V <sub>CC</sub> = MAX | $V_{O} = V_{CC}$ | Jagan 1 | 0 | 10 | μΑ | | Icc | Standby suppl | y current <sup>6</sup> | $I_O = 0 \text{mA}, V_I = GN$ | ND or V <sub>CC</sub> | | 0 | 100 | μΑ | | ·CC | Operating sup | ply current | f = 1MHz, I <sub>O</sub> = 0m | A, V <sub>I</sub> = GND or V <sub>CC</sub> | | 2 | 57 | mA | ## Switching Characteristics Over Operating Conditions | SYMBOL | DADAS | PARAMETER | | IN | DUSTR | AL | СО | UNIT | | | |-------------------------------|-----------------------------------|------------------|-----------------------------------|------|-------|-----------------|---------------------|------|-----------------|------| | SIMBUL | PARAM | IEIEN | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | t <sub>PD</sub> | Input or feedbac<br>20L8A, 20R6A, | | | | 13 | 25 <sup>1</sup> | | 13 | 25 <sup>1</sup> | ns | | t <sub>CLK</sub> | Clock to output<br>20R8A, 20R6A, | | | | 8 | 15 | e. Pyr 19<br>19 mai | 8 | 15 | ns | | t <sub>PZX</sub> | Input to output enable | 20L8A,<br>20R6A, | $R_1 = 1K\Omega$ | | 12 | 25 | | 12 | 25 | ns | | t <sub>PXZ</sub> 8 | Input to output disable | 20R4A | $R_{L} = 1K\Omega$ $C_{L} = 50pF$ | | 12 | 25 | | 12 | 25 | ns | | t <sub>PXZ</sub> <sup>8</sup> | Pin 13 (DIP) to<br>ouutput | 20R8A, | | | 10 | 20 | | 10 | 20 | ns | | t <sub>PZX</sub> | disable/enable | 20R6A, | | | 100 | | | | | | | f <sub>MAX</sub> | Maximum frequency | 20R4A | | 28.5 | 40 | | 28.5 | 40 | | MHz | Notes: 1. For outputs with more than 12 inputs in a product term, t<sub>SU</sub> = 25ns and t<sub>PD</sub> = 30ns. 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. 3. Pin 10 (PRELOAD pin), pin 13PLCC (PRELOAD pin), Applies to registered devices only. 4. JEDEC standard no. 7 for high-speed CMOS devices. 5. Applies to pins 14-23 for DIP (pins 17, 18, 20-27 for PLCC). 6. Disable output pins = V<sub>CC</sub> or GND. 7. Add 3mA per additional 1.0MHz of operation over 1MHz. 8. C<sub>L</sub> = 5pF. | 0.44501 | | PARAMETER | | DUSTR | AL | СО | IAL | LIMIT | | |-----------------|--------------------------------------------|----------------------------|-----------------|-------|-----|-----------------|-----|-------|------| | SYMBOL | PANAMETEN | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply Voltage | | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | t <sub>w</sub> | Width of clock | | 15 | 5 | | 15 | 5 | | ns | | t <sub>su</sub> | Setup time from input or feedback to clock | 20X10A,<br>20X8A,<br>20X4A | 25 <sup>1</sup> | 15 | | 25 <sup>1</sup> | 15 | | ns | | t <sub>h</sub> | Hold time | 20,47 | 0 | -10 | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air temperature | | -40 | 25 | 85 | 0 | 25 | 75 | °C | #### Electrical Characteristics Over Operating Conditions | SYMBOL | PARA | METER | TEST C | CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------|-----------------|------------------------|--------------------------------|--------------------------------------------|-------|-----|-----------------|---------------------------------------| | V <sub>IL</sub> <sup>2</sup> | Low-level inpu | t voltage | | | 0 | | 0.8 | V | | V <sub>IH</sub> <sup>2</sup> | High-level inpu | ut voltage | | | 2 | | V <sub>CC</sub> | ٧ | | I <sub>IL</sub> | Low-level inpu | t current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | | -1 | μΑ | | | High-level | Pin 10 <sup>3</sup> | V - MAY | V = V | | 8 | 30 | μΑ | | l <sub>IH</sub> | input current | All other pins | V <sub>CC</sub> = MAX | $V_{I} = V_{CC}$ | | | 7 1 | μΑ | | V | Low lovel oute | uit valtaaa | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.1 | 0.4 | V | | V <sub>OL</sub> | Low-level outp | out voitage | V <sub>CC</sub> = 5V | $I_{OL} = 1\mu A$ | | | 0.05 | \ \ | | V | High-level out | aut voltage | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -6mA | 3.764 | 4.1 | | v | | V <sub>OH</sub> | High-level out | out voltage | V <sub>CC</sub> = 5V | $I_{OH} = -1\mu A$ | 4.95 | | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | I <sub>OZL</sub> 5 | Off-state outpu | ut ourront | V - MAY | V <sub>O</sub> = GND | | 0 | -10 | μΑ | | I <sub>OZH</sub> 5 | On-state outpo | ut current | $V_{CC} = MAX$ | $V_O = V_{CC}$ | | 0 | 10 | μΑ | | I <sub>CC</sub> | Standby suppl | y current <sup>6</sup> | $I_O = 0 \text{mA}, V_I = G N$ | D or V <sub>CC</sub> | 25 | 0 | 100 | μА | | 'CC | Operating sup | ply current | f = 1MHz, I <sub>O</sub> = 0m/ | A, V <sub>I</sub> = GND or V <sub>CC</sub> | | 2 | 57 | mA | ## Switching Characteristics Over Operating Conditions | SYMBOL | DADAS | PARAMETER | | IN | DUSTRI | AL | СО | IAL | UNIT | | | | | |--------------------|------------------------------------|-------------------|-----------------------------------|------|--------|-------------------|------|-----|-----------------|------|----|----|-----| | STMBUL | FANAN | | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | | | | t <sub>PD</sub> | Input or feedbac<br>20L10A, 20X8A, | | | | 13 | 25 <sup>1</sup> | | 13 | 25 <sup>1</sup> | ns | | | | | t <sub>CLK</sub> | Clock to output<br>20X10A, 20X8A, | | | | 10 | 15 | | 10 | 15 | ns | | | | | t <sub>PZX</sub> | Input to output enable | 20L10A, | R <sub>1</sub> = 1KΩ | | 12 | 25 | | 12 | 25 | ns | | | | | t <sub>PXZ</sub> 8 | Input to output disable | 20X8A,<br>20X4A | $R_{L} = 1K\Omega$ $C_{L} = 50pF$ | | 12 | 25 | | 12 | 25 | ns | | | | | t <sub>PXZ</sub> 8 | Pin 13 (DIP) to output disable/ | | | | 15 | 20 | | 15 | 20 | ns | | | | | t <sub>PZX</sub> | enable | 20X10A,<br>20X8A, | | | | 20X10A,<br>20X8A. | | 13 | 20 | | 13 | 20 | 115 | | f <sub>MAX</sub> | Maximum<br>frequency | 20X4A | | 22.2 | 32 | | 22.2 | 32 | | MHz | | | | Notes: 1. For outputs with more than 12 inputs in a product term, t<sub>SU</sub> = 30ns and t<sub>PD</sub> = 30ns. 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. 3. Pin 10 (PRELOAD pin), pin 13PLCC (PRELOAD pin). Applies to registered devices only. 4. JEDEC standard no. 7 for high-speed CMOS devices. 5. Applies to pins 14-23 for DIP (pins 17, 18, 20-27 for PLCC). 6. Disable output pins = V<sub>CC</sub> or GND. 7. Add 3mA per additional 1.0MHz of operation over 1MHz. 8. C<sub>L</sub> = 5pF. ## ZHAL24A Series 20S10A, 20RS10A, 20RS8A, 20RS4A ### **Operating Conditions** | OVERDOL | SYMBOL PARAMETER | | INDUSTRIAL | | | co | | | | |-----------------|--------------------------------|----------|-----------------|-----|---------|-----------------|-----|------|------| | SYMBOL | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage | | | 5 | 5.5 | 4.75 | 5 | 5.25 | ٧ | | t <sub>w</sub> | Width of clock | 20RS10A, | 15 | 4 | is, inc | 15 | 4 | | ns | | t <sub>su</sub> | Setup time for input clock | 20RS8A, | 20 <sup>1</sup> | 11 | | 20 <sup>1</sup> | 11 | | | | t <sub>h</sub> | Hold time | 20S4A | 0 | -10 | | 0 | -10 | | ns | | T <sub>A</sub> | Operating free-air temperature | | -40 | 25 | 85 | 0 | 25 | 75 | °C | ### Electrical Characteristics Over Operating Conditions | SYMBOL | PARA | METER | TEST | CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------|-----------------|-------------------------|-------------------------------|---------------------------------------------|-------|-----|-----------------|----------| | V <sub>IL</sub> <sup>2</sup> | Low-level inpu | ıt voltage | | | 0 | | 0.8 | ٧ | | V <sub>IH</sub> <sup>2</sup> | High-level inpu | ut voltage | | | 2 | | V <sub>cc</sub> | ٧ | | I <sub>IL</sub> | Low-level input | it current | V <sub>CC</sub> = MAX | V <sub>I</sub> = GND | | | -1 | μΑ | | | High-level | Pin 10 <sup>3</sup> | V - MAN | V. | | 8 | 30 | μΑ | | <sup>1</sup> ін | input current | All other pins | V <sub>CC</sub> = MAX | V <sub>I</sub> ≡ V <sub>CC</sub> | | | 1 | μΑ | | , | 1 1 1 | | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 8mA | | 0.1 | 0.4 | v | | V <sub>OL</sub> | Low-level outp | out voitage | V <sub>CC</sub> = 5V | I <sub>OL</sub> = 1μA | 4.3 | | 0.05 | <b>"</b> | | | Libe level and | | V <sub>CC</sub> = MIN | I <sub>OH</sub> = -6mA | 3.764 | 4.1 | | v | | V <sub>OH</sub> | High-level out | put voitage | V <sub>CC</sub> = 5V | $I_{OH} = -1\mu A$ | 4.95 | | | \ \ \ | | I <sub>OZL</sub> 5 | 0# -1-1- | | V - MAV | V <sub>O</sub> = GND | | 0 | -10 | μΑ | | I <sub>OZH</sub> 5 | Off-state outp | ut current | V <sub>CC</sub> = MAX | $V_O = V_{CC}$ | | 0 | 10 | μΑ | | I <sub>CC</sub> | Standby suppl | ly current <sup>6</sup> | $I_O = 0 \text{mA}, V_I = G$ | ND or V <sub>CC</sub> | | 0 | 100 | μΑ | | 'CC | Operating sup | ply current | f = 1MHz, I <sub>O</sub> = 0r | mA, V <sub>I</sub> = GND or V <sub>CC</sub> | | 2 | 5 <sup>7</sup> | mA | ## Switching Characteristics Over Operating Conditions | SYMBOL | DADAS | PARAMETER | | IN | DUSTR | AL | co | IAL | UNIT | | |--------------------|------------------------------------|---------------------|-----------------------------------|------|-------|-----------------|------|-----|-----------------|------| | SYMBUL | PARAN | AE I EN | (See Test Load) | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | t <sub>PD</sub> | Input or feedbace<br>20S10A, 20RS8 | | | | 13 | 25 <sup>1</sup> | | 13 | 25 <sup>1</sup> | ns | | t <sub>CLK</sub> | Clock to output<br>20RS10A, 20RS | | | | 8 | 15 | | 8 | 15 | ns | | t <sub>PZX</sub> | Input to output enable | 20S10A, | $R_{i} = 1K\Omega$ | | 12 | 25 | | 12 | 25 | ns | | t <sub>PXZ</sub> 8 | Input to output disable | 20RS8A,<br>20RS4A | $R_{L} = 1K\Omega$ $C_{L} = 50pF$ | | 12 | 25 | | 12 | 25 | ns | | t <sub>PXZ</sub> 8 | Pin 13 (DIP) to output disable/ | | | | 10 | 20 | | 10 | 20 | ns | | t <sub>PZX</sub> | enable | 20RS10A,<br>20RS8A, | | | 10 | 20 | | 10 | 20 | 113 | | f <sub>MAX</sub> | Maximum frequency | 20RS4A | | 28.5 | 40 | | 28.5 | 40 | | MHz | Notes: 1. For outputs with more than 12 inputs in a product term, t<sub>SU</sub> = 25ns and t<sub>PD</sub> = 30ns. 2. These are absolute voltages with respect to the ground pin on the device and include all overshoots due to system and/or tester noise. 2. Do not attempt to test these values without suitable equipment. 3. Pin 10 (PRELOAD pin), pin 13PLCC (PRELOAD pin). Applies to registered devices only. 4. JEDEC standard no. 7 for high-speed CMOS devices. 5. Applies to pins 14-23 for DIP (pins 17, 18, 20-27 for PLCC). 6. Disable output pins = V<sub>CC</sub> or GND. 7. Add 3mA per additional 1.0MHz of operation over 1MHz. 8. C<sub>L</sub> = 5pF. #### **Absolute Maximum Ratings** | Supply voltage, V <sub>CC</sub> | | <br> | <br>0.5V to 7 | |---------------------------------------------------------------------------------------------------|-------------------|------|----------------------------------| | DC input voltage, Vi | | <br> | <br>0.5V to V <sub>CC</sub> +0.5 | | DC output voltage, Vo | | <br> | <br>0.5V to V <sub>CC</sub> +0.5 | | DC output source/sink current per output pi | n, I <sub>O</sub> | <br> | <br>± 35m | | OC V <sub>CC</sub> or ground current, I <sub>CC</sub> or I <sub>CND</sub> | | <br> | <br>± 100m | | V. < 0 | | | -20m | | $V_1 > V_{CC}$ | | | +20m | | V <sub>I</sub> > V <sub>CC</sub><br>dutput diode current, I <sub>OK</sub> :<br>V <sub>O</sub> < 0 | | | 20m | | V <sub>O</sub> > V <sub>CC</sub> | | <br> | <br>+20m | | Storage temperature | | <br> | <br>65°C to + 150°C | #### **Switching Test Load** ### Schematic of Inputs and Outputs ## Output Register PRELOAD† The PRELOAD function allows the register to be loaded from data placed on the output pins. This feature aids functional testing of state sequencer designs by allowing direct setting of output states for improved test coverage. The procedure for PRELOAD using DIP pin numbers, is as follows: - Raise V<sub>CC</sub> to 4.5V. - 2. Disable output registers by setting pin 13 to VIH. Set pin 1 to 0V. - 3. Apply $V_{IL}/V_{IH}$ to all registered outputs. - Pulse pin 10 to V<sub>p</sub> (12V), then back to 0V. - Remove V<sub>IL</sub>/V<sub>IH</sub> from all registered outputs. - 6. Lower pin 13 to $V_{\rm IL}$ to enable the output registers. 7. Verify for $\rm V_{OL}/\rm V_{OH}$ at all registered outputs. † Note: Only applies to parts with output registers. Typical $t_{sup} = 50 \text{ns}$ t<sub>wp</sub> = 100ns = 50ns $= 30 \mu A \text{ (Pin 10)}$ ## **Enable/Disable Delay** - CL includes probe and jig capacitance. Notes: 1. - When measuring $t_{PLZ}$ and $t_{PZL}$ , S1 is tied to $V_{CC}$ . When measuring $t_{PHZ}$ and $t_{PZH}$ , S1 is tied to ground. $t_{PZX}$ is measured with $C_L$ = 50pF. $t_{PXZ}$ is measured with $C_L$ = 5pF. When measuring propagation delay times of three-state outputs, S1 is open, i.e., not connected to $V_{\mbox{\footnotesize CC}}$ or ground. - 3. Waveform 1 is for an output with internal conditions such that the output is LOW except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is HIGH except when disabled by the output control. #### Features/Benefits - Demonstration pattern for ZHAL24A Series (ZHAL20X8A) - 8-bit counter - Three-state output - Expandable in 8-bit increments - Equivalent to 74ACT461 #### Description The ZHAL24A Evaluation #4 pattern is provided as an example of the features and characteristics of the ZHAL24A Series products. The design consists of an 8-bit synchronous counter with parallel load, clear, and hold capability. Two function select inputs (I0, I1) provide one of four operations which occur synchronously on the rising edge of the clock (CK). The LOAD operation loads the inputs (D7-D0) into the output register (Q7-Q0). The CLEAR operation resets the output register to all LOWs. The HOLD operation holds the previous value regardless of clock transitions. The INCREMENT operation adds one to the output register when the carry-in input is TRUE( $\overline{Cl}$ = LOW), otherwise the operation is a HOLD. The carry-out ( $\overline{CO}$ ) is TRUE ( $\overline{CO}$ = LOW) when the output register (Q7-Q0) is all HIGHs, otherwise FALSE ( $\overline{CO}$ = HIGH). The data output pins are enabled when $\overline{\text{OE}}$ is LOW, and disabled (HI-Z) when $\overline{\text{OE}}$ is HIGH. Two or more 8-bit counters may be cascaded to provide larger counters. The operation codes were chosen such that when I1 is HIGH, I0 may be used to select between LOAD and INCREMENT as in a program counter (JUMP/INCREMENT). #### **Function Table** | ŌĒ | СК | 11 | 10 | CI | D7-D0 | Q7-Q0 | OPERATION | |----|----|----|----|----|-------|----------|-----------| | Н | * | | * | * | | Z | HI-Z* | | L | 1 | L | L | Х | X | L | CLEAR | | L | 1 | L | Н | X | Х | Q | HOLD | | L | 1 | н | L | X | D | D | LOAD | | L | 1 | Н | Н | н | Х | Q | HOLD | | L | 1 | Н | Н | L | X | Q plus 1 | INCREMENT | \*When $\overline{\text{OE}}$ is HIGH, the three-state outputs are disabled to the high-impedance states; however, sequential operation of the counter is not affected. - H = HIGH voltage level - L = LOW voltage level - X = Don't care - Z = High impedance (off) state - t = LOW-to-HIGH clock transition ## **Logic Symbol** LS00100 ## Logic Diagram ``` Title ZHAL24A Evaluation 4 (74ACT461) Pattern P7023 Revision B Author Birkner/Kazmi/Blasco Company Monolithic Memories, Inc. Date 1986 CHIP ZHAL24A Evaluation 4 PAL20X8 IO DO D1 D2 D3 D4 D5 D6 D7 I1 GND /OE /CO Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 /CI VCC EQUATIONS /Q0 := /I1*/I0 ;CLEAR LSB + I0*/Q0 ; COUNT/HOLD :+: I1*/I0*/D0 ;LOAD DO (LSB) + I1* I0* CI ; COUNT /Q1 := /I1*/I0 ; CLEAR I0*/Q1 ; COUNT/HOLD :+: I1*/I0*/D1 ;LOAD D1 I1* I0* CI*Q0 ; COUNT /Q2 := /I1*/I0 ;CLEAR + I0*/Q2 ; COUNT/HOLD I1*/I0*/D2 :+: :LOAD D2 I1* I0* CI*Q0*Q1 ; COUNT /Q3 := /I1*/I0 ; CLEAR I0*/03 ; COUNT/HOLD I1*/I0*/D3 :+: ;LOAD D3 I1* I0* CI*Q0*Q1*Q2 ; COUNT /Q4 := /I1*/I0 ;CLEAR + I0*/Q4 ; COUNT/HOLD I1*/I0*/D4 :+: ;LOAD D4 I1* I0* CI*Q0*Q1*Q2*Q3 ; COUNT /Q5 := /I1*/I0 ; CLEAR I0*/05 ; COUNT/HOLD :+: I1*/I0*/D5 ;LOAD D5 I1* I0* CI*Q0*Q1*Q2*Q3*Q4 ; COUNT /Q6 := /I1*/I0 ;CLEAR + I0*/Q6 ; COUNT/HOLD I1*/I0*/D6 ;LOAD D6 :+: I1* I0* CI*Q0*Q1*Q2*Q3*Q4*Q5 : COUNT /Q7 := /Il*/IO ; CLEAR MSB I0*/Q7 : COUNT/HOLD + I1*/I0*/D7 ;LOAD D7 (MSB) :+: I1* I0* CI*Q0*Q1*Q2*Q3*Q4*Q5*Q6 ; COUNT IF (VCC) CO = CI*Q0*Q1*Q2*Q3*Q4*Q5*Q6*Q7 ; CARRY OUT ``` **PAL® Device Introduction** PAL®/HAL® Device Specifications # Logic Cell Array™ #### Introduction The Logic Cell Array (LCA)<sup>TM</sup> is a CMOS integrated circuit with a flexible, uncommitted architecture and VLSI-level density. The LCA is manufactured on Monolithic Memories' 1.6 micron CMOS process. The device architecture as is shown in Figure 1, similar to that of a gate array, with an interior matrix of programmable logic blocks, a surrounding ring of I/O interface blocks and programmable interconnect used to define the overall device structure. Unlike gate arrays, Logic Cell Array functionality is defined by the user simply by loading the internal writable storage cells with the configuration data. An additional benefit, reprogrammability in system, allows in-circuit-emulation to be used for design verification. The M2064 family of Logic Cell Arrays has been developed to allow Monolithic Memories to offer a device and technology that offer both the density benefits of gate arrays and the programmability benefits of user-configurable devices. These parts have been designed for maximum flexibility in system applications and are easy to use. Using the XACT<sup>TM</sup> software development system, the designer can define and interconnect logic blocks to build larger-scale, multi-level logic functions. These are then connected to external circuitry. Interconnections throughout the Array are defined automatically by the development system, unless otherwise specified by the designer. Because the Logic Cell Array's logic functions and interconnections are established with memory cells, the array is never physically altered; instead it is simply reprogrammed. #### **XACT Evaluation Kit (LCA-MEK01)** Monolithic Memories offers evaluation software and documentation that will allow a designer to determine if his or her logic design fits and assess its performance as a Logic Cell Array. All that is needed is an IBM PC-XT, AT, or compatible, a three-button Mouse System or compatible mouse. ## XACT Development System (LCA-MDS21) The XACT Development System is the "power behind the machine." It will allow a designer to sit down with a concept and walk away with a completely tested, completely finished part. The reason is that XACT functions as both a CAE and CAM system. The CAE part of the system allows the designer to simply draw out the design using a sophisticated graphics-based design editor. The CAM part then converts the drawing to code, similar to a PALASM-generated JEDEC file, that allows programming with conventional programming hardware of an EPSOM containing the configuration data for system phototyping. The XACT Development System currently has 113 macros and, in addition, allows the user to define his or her own macro. To insure that internal timing constraints are satisfied, a Timing Analyzer is included to calculate propagation delays along any path within the Array. As the design is being entered, the Automatic Design Checker insures that no design rules are violated, and when the design is completed, a final design rule check is performed. #### The XACT Development System Contents: - Editor - Macro Library - Design Checker - Timing Analyzer (LCA-MDS24) Configuration File Generator ## Configuration File Formatter In-Circuit-Emulator The In-Circuit-Emulator is a software/hardware package that enables a designer to connect his or her target system to the work-station where a design has just been completed. The emulator package allows: - User control and monitoring of device function - Interactive or file-driven setup and configuration - Daisy-chain configuration capabilities for up to seven LCAs in a chain - Simultaneous in-circuit emulation of up to four devices - Single step capability for device clocks - Readback display of device internal register states - Dynamic reconfiguration capability. The In-Circuit-Emulator comes with a single "pod". Up to three additional pods (LCA-MDS25) may be ordered for each emulator. ## P-SILOS Simulation Package (LCA-MDS22) After a design is completed, the next step is to simulate. Monolithic Memories offers an integrated simulation package manufactured by Simucad, called P-SILOS. | PART NUMBER | DESCRIPTION | | | |-------------|-----------------------------|--|--| | LCA-MEK01 | LCA Evaluation Kit | | | | LCA-MDS21 | LCA Development system | | | | LCA-MDS22 | LCA Simulator-P-SILOS | | | | LCA-MDS24 | LCA In-Circuit-Emulator | | | | LCA-MDS25 | LCA In-Circuit-Emulator Pod | | | | LCA-MTB01 | LCA Demonstration Board | | | Table 1 The introduction of the Logic Cell Array will allow customers to reduce inventories of discrete components, reduce the time to market and development cost for new products, save money in manufacturing and spare parts inventory management, reduce test costs and improve system reliability. Monolithic MMI Memories #### **Configurable Logic Block** The core of the Logic Cell Array is an 8 x 8 matrix of Configurable Logic Blocks. Each CLB provides four logic inputs, a clock input, a combinatorial logic section, two logic outputs, and a programmable storage element. The inputs drive a combinatorial logic section that can perform any logic function from a simple gate to a three-out-of-four majority decoder. The combinatorial portion accepts and generates both positive- and negative-true logic, eliminating the need for inverters or the routing of complementary signals. The storage element can serve as a flip-flop (D-type) and can be programmed to have clock enable, synchronous set and reset, and various gated inputs. In addition, since all these options can be specified independently for each logic block, designers can mix asynchronous and synchronous logic in any combination. #### Interconnect The Array's extraordinary flexibility is also the result of a twolayer metal network of lines that run horizontally and vertically between the logic and I/O blocks, and a variety of userdefinable interconnection elements. Definable interconnection points connect the inputs and outputs of logic and I/O blocks to nearby metal lines. Crosspoint switches and interchanges are clustered at the intersection of every row and column of logic blocks. They link horizontal and vertical paths and allow signals to be switched from one path to another. Finally, "long lines" run the length and breadth of the chip, bypassing interchanges but tying into logic blocks and other lines and distributing clocks and other critical signals with a minimum of propagation delay. Interchanges and interconnection point assignments, as well as all routing are handled automatically by the XACT Development System Software. In addition, special graphics-based design tools are included to facilitate any necessary designer interaction. ## Configurable I/O Block External signals enter and leave the chip through general-purpose, user-definable I/O blocks positioned around the periphery of the array. Each block can be programmed independently to be an input, output or bidirectional pin with a tristate control on the output. When configured as an input, the designer can select TTL or CMOS thresholds. In addition, each I/O bloc contains an input register option whose clock line is common to all the other I/O blocks along the same edge of the die. I/O blocks can also handle more than input and output functions. For example, the Input registers of unused I/O blocks can be used for read/write storage registers or as stages of a shift register. Figure 1 ## Logic Cell Array™ M2064 #### Features/Benefits - CMOS programmable Logic Cell Array (LCA<sup>TM</sup>) for replacement of standard logic - · Completely reconfigurable by the user in the final system - High performance - 20MHz flip-flop toggle rate (-20 speed grade) - 33MHz flip-flop toggle rate (-33 speed grade) - 50MHz flip-flop toggle rate (-50 speed grade) - User-configurable logic functions, interconnect and I/O for maximum flexibility - 64 user-Configurable Logic Blocks (CLBs) providing usable gate equivalency of up to 1500 gates - 58 individually-configurable I/O pins allowing any mix of inputs, outputs or bidirectional signals (68-pin package) - User-selectable TTL or HCMOS input threshold levels - Multiple configuration modes for greatest flexibility and ease of use - Verification feature allows user to check configuration data - User-selectable security feature prevents read-back of configuration data - Read-back of internal register states for system debug - On-chip clock oscillator and clock buffer circuits provide flexible internal and external clocking functions - Master reset of all internal register elements in addition to user-configurable Reset and/or Set control of individual CLB storage elements #### **General Description** The M2064 is the first member of a family of configurable Logic Cell Arrays (LCAs) available from Monolithic Memories. These general purpose CMOS integrated circuit devices allow the user to rapidly implement complex digital logic functions directly without the requirement for masking or other vendor performed programming steps. Unique configuration circuitry allows complete reconfiguration within a user's final system to allow system changes 'on-the-fly.' User configuration is controlled by internal storage elements. These are loaded with data bits which control definition of logic functions, configuration of I/O blocks, routing of internal signals, and other options. Configuration data can be loaded in one of several methods to minimize impact on overall system design. CMOS technology optimized for system level performance provides LS-TTL compatible speeds with power consumption less than 10% of equivalent TTL systems. The use of innovative I/O buffers providing either TTL or CMOS input switching levels insures lowest possible power consumption in totally CMOS systems without any compromise in performance. #### **Ordering Information** | PART NUMBER | DESCRIPTION | | | |-------------|----------------------------|--|--| | LCA-MDS21 | XACT Development System | | | | LCA-MDS22 | P-SILOS Simulation Package | | | | LCA-MDS24 | LCA In-Circuit Emulator | | | | LCA-MDS25 | In-Circuit Emulator Pod | | | | LCA-MEK01 | XACT Evaluation Kit | | | Portions of this Data Sheet reproduced with the permission of XILINX Inc. #### Pin Description #### 1/0 User-configurable Input/Output pins. #### ~PWRDN Input forces device into low power mode; operation is suspended. #### MO-~RT Dual function input. During initial power up, the state of M0 and M1 determines the configuration mode. After configuration, a rising edge on ~RT initiates a configuration read operation. #### M1-~RD Dual function input/output. During initial power up, the state of M1 and M0 determines the configuration mode. After configuration is complete, ~RD outputs configuration data during a configuration read back operation synchronously with the toggling of the CCLK input. #### ~RESET Input. A low level on this input after configuration causes all register elements internal to the LCA to be forced to 0. If asserted prior to the start of configuration, causes the LCA to remain in the initialization state (configuration is not started). If asserted during configuration the LCA returns to the initialization state. #### DONE-~PG Dual function output/input. During configuration the LCA pulls DONE low and releases it when configuration is complete (output is open drain). After configuration is complete, a falling edge on ~PG initiates an LCA programming cycle (if enabled in the current configuration). This pin has an internal userenabled pull-up resistor. #### XTAL1-I/O Dual function input and I/O. This pin may be configured by the user to be a normal I/O pin equivalent to any of the general purpose I/O pins. Alternatively, this pin and XTAL2 my be used to connect a crystal for use with the internal crystal oscillator configuration. #### XTAL2-I/O Dual function output and I/O. This pin may be configured by the user to be a normal I/O pin equivalent to any of the general purpose I/O pins. Alternatively, this pin and XTAL1 may be used to connect a crystal for use with the internal crystal oscillator configuration. #### CCLK Configuration mode dependent input/output. CCLK is the master configuration clock used to configure the LCA. In slave mode it is an input; in all other modes it is an output designed to provide the input clocking of additional slave mode daisy chain connected LCA devices. During a configuration read back operation, CCLK serves as the clock input used to read the internal configuration data. #### DOUT-I/O Dual function output and I/O. General purpose user-configurable I/O pin during normal operation. During configuration, the serial data stream supplied from the first LCA to LCAs down the serial daisy chain is output on DOUT. re a gapter, sur est récent del bors, le la comité la cité de la comité de la comité de la comité de la comité NOVE IN PROPERTY OF #### ~RCLK-I/O Dual function output and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, a low level output on ~RCLK indicates that the external memory device is being accessed. #### D0-DIN-I/O Multi-function input and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, this pin is bit 0 of the 8-bit parallel input data bus (D0). During slave mode or peripheral mode configuration, this pin is the serial input data pin (DIN). #### D1-~WS-I/O Multi-function input and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, this pin is bit 1 of the 8-bit parallel input data bus (D1). During peripheral mode configuration, a low level on ~WS indicates that a write operation is being performed by the controlling processor. See note. #### D2-CS-I/O Multi-function input and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, this pin is bit 2 of the 8-bit parallel input data bus (D2). During peripheral mode configuration, a high level on CS indicates that a write operation is being performed by the controlling processor. See note. #### D3-~CE0-I/O Multi-function input and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, this pin is bit 3 of the 8-bit parallel input data bus (D3). During peripheral mode configuration, a low level on ~CEO indicates that a write operation is being performed by the controlling processor. See note. #### D4-~CE1-I/O Multi-function input and I/O. General purpose user-configurable I/O pin during normal operation. During master mode configuration, this pin is bit 4 of the 8-bit parallel input data bus (D4). During peripheral mode configuration, a low level on ~CE1 indicates that a write operation is being performed by the controlling processor. See note. #### D5-I/O to D7-I/O Input and I/O. General purpose user-configurable I/O pins during normal operation. During master mode configuration, these pins are bits 5 through 7 of the 8-bit parallel input data bus (D5-D7). #### A0-I/O to A15-I/O Output and I/O. General purpose user-configurable I/O pins during normal operation. During master mode configuration these pins are address output pins (A0-A15) used to address the external storage element used for configuration data. Note: to perform a peripheral mode write, the following logical combination is necessary: ~WS·CS·CE0·CE1. #### **Functional Description** The M2064 is a high-performance CMOS Logic Cell Array providing superior system performance with greatest user flexibility. Complete user-configurability provides an optimized solution to logic implementation problems. The M2064 utilizes a unique Configurable Logic Block (CLB) structure as the basic functional building block of the device. Each CLB is a combination of a programmable logic function and a storage element. The CLB has the capability of performing any function of its inputs with the option of the output of the storage element included in the input field. User-defined logic is implemented in a matrix of sixty-four CLBs which are interconnected with user-configurable interconnect resources. Fifty-eight independently configurable I/O Blocks; each of which can be a direct or latched input, a direct or open drain output, or a bidirectional I/O buffer; provide the interface to external circuits. Input voltage levels are user definable and may be either standard TTL or CMOS for all I/O Blocks, depending on the user's configuration choice. User-definable path selector or multiplexers are utilized to select configuration options for the CLBs and I/O Blocks. These selectors are set in the desired state by the configuration data loaded into the device upon power up. ## Logic User logic is implemented in one or more CLBs which are general purpose 4-input, 2-output elements. Figure 1 shows a block diagram of a single CLB. Each element is composed of a 4-input combinational logic module with two outputs, a general purpose storage element, and routing selection logic. The module can generate any combinational logic function of the four inputs, or it can generate any two independent functions of any three of the four inputs. If a function of four inputs is selected, that same function will be available on both of the outputs of the combinational module. The inputs to the combinational module are three of the four inputs to the CLB (A, B and C) and either the D input to the CLB, or the Q output of the storage element. Figure 1. Block Diagram of a Single CLB The general purpose storage element has a data input, a clock input, a set direct input, a reset direct input and an output, Q. The storage characteristic may be defined as either a transparent latch or as an edge-triggered flip-flop. The data input is connected to one of the outputs of the combinational logic module. The set direct and reset direct inputs may be individually enabled or disabled. The reset direct input, if enabled, may come from either the D input to the CLB, or from the G output of the combinational logic module. Set direct control, if enabled, can come from either the A input to the CLB or from the F output of the combinational logic module. Clock for the storage element may be individually enabled or disabled and can be driven by the clock input, K, to the CLB, the C input to the CLB, or the G output of the combinational logic module. Final outputs, X and Y, from the CLB can be selected to be either of the two outputs, F and G, of the combinational logic module, or the Q output from the storage element. ## I/O Elements The M2064 contains fifty-eight user-configurable I/O blocks for connection to external circuits. Each block is a general purpose device containing a three-state output buffer, an input buffer, and an input flip-flop as shown in Figure 2. The input buffer always reflects the status of the I/O pin or the contents of the input flip-flop. If the flip-flop is selected, data present on the I/O pin will be clocked to the input buffer by the I/O block clock signal. All I/O blocks on a particular edge of the device share a common I/O clock signal. The output buffer may be enabled, disabled, or under the control of the three-state connection. Figure 2. Block Diagram of an I/O Element #### Interconnect There are nine rows and nine columns of metal interconnect resources with one row or column located between each row or column of CLBs or I/O blocks. Each row or column of interconnect resources contains local use lines, long lines and programmable interconnect points between I/O blocks, CLBs and interconnect resources. Local lines run either vertically from one row of resources to the adjacent row or horizontally from one column to the adjacent column. Long lines run the full height or width of the device. At the intersection of every row and column of interconnect resources are user configurable interconnect elements which allow multiple combinations of connections between local lines in adjacent rows and columns. In addition, selected intersections of local and long lines can be connected by user programmable interconnect points. Inputs and outputs from each CLB or I/O block have programmable connections to the interconnect resources in the adjacent rows and columns. These connections allow CLBs or I/O block connections to be made for proper signal routing to or from the I/O blocks or CLBs. In addition to the programmable connections to adjacent interconnect resources, there are direct connection paths which do not utilize the general interconnect resources. These paths allow selected connection between some I/O blocks and CLBs and between adjacent CLBs. For example, the outputs of a CLB in the interior of the matrix of CLBs may be connected to adjacent CLBs without using any interconnect resources. Figure 3. Overview Functional Layout of the M2064 # **Clock Generation and Buffering** The M2064 contains two special purpose clock buffers for generating and driving clock signals to multiple CLBs or I/O blocks with negligible skew. The Global Clock Buffer, is dedicated to driving a matrix of long lines which have configurable connections to the K input of each CLB register. This clock buffer may be driven from an internally generated register source, or configured with a connection directly to an I/O block for driving it with an external clock signal. The output from the Global Clock Buffer may be configured to directly drive an I/O block for driving clock signals off the device. The alternate clock buffer can be configured either as a simple buffer or as a buffer for the crystal oscillator. In the crystal oscillator mode, an externally connected crystal and optional passive components form a clock generator for use on the chip or for driving other external circuits (see Figure 4). When configured in the buffer mode, the alternate clock buffer can have either one or both of its input and output configured to directly drive, or be driven by, an I/O block. The output of the alternate clock buffer can drive long lines in any column of CLBs as well as local interconnect. Suggested component values: R1 1 – 4M $\Omega$ R2 0 – 1K $\Omega$ (may be required for low frequency, phase shift and/or compensate level for crystal Q) C1, C2 5 - 20pF Y1 1 - 10MHz AT cut Figure 4. Crystal Oscillator Each CLB has a special clock input (K) which can be selected as the clock input of the storage element. Clock inputs to user selected CLBs can be configured to be driven from either the Global Clock Buffer, the oscillator/buffer or from other local interconnect. Clocks to the I/O blocks can be configured from either of the clock buffers or the local interconnect. ## **Programming** Configuration of the device may be performed in any one of three modes. The desired configuration mode is set by the state of the mode pins M0 and M1 at power up (see Table 1). All configuration data relating to CLB function definition interconnect resource utilization, and I/O block programming must be loaded into the device prior to use. In the peripheral and slave modes the data is supplied in a serial stream in conjunction with the configuration clock signal, CCLK. In master mode, the device automatically loads data from an external memory device by supplying addresses and reading bytes of data. In all modes the data patterns required to create a specific configuration are the same. | MODE SELECT PINS | MO | M1 | |------------------|----|-----| | Master LOW mode | 0 | 0 * | | Master HIGH mode | 0 | 1 | | Peripheral mode | 1 | 0 | | Slave mode | 1 | 1. | Note: During configuration, Pin 27 on the 68-pin package or Pin 7 on the 48-pin package must be held HIGH. Table 1. Modes Data patterns for a specific user-configuration are created with the Monolithic Memories XACT LCA Development System and can be output to a standard EPROM programmer or saved on disk for inclusion with other software. Users who are using the Monolithic Memories XACT debugging system can directly access the configuration data and load the device directly during a debug session. Because of the complexity of the data patterns and difficulty in generating them without a thorough knowledge of the device, users are discouraged from attempting to generate data patterns on their own. Data pattern files for M2064 devices contain 1536 bytes. #### **Special Features** The M2064 contains several special features which enhance its capacity for use in a wide variety of applications. Among these are the following: #### **Data Security** The M2064 configuration data contains special controls bits which enable or disable configuration data security control. If enabled, the security control will prevent the read-back of configuration data after the initial configuration. There are two possible modes of operation under security control. One mode allows a single read-back after configuration to allow verification of the data. In the second mode, all access to the configuration data is prevented. #### Reprogrammability Configuration data changes are controlled by reprogramming control bits in the configuration data supplied to the device. If reprogramming is enabled, the user may supply new configuration data at any time by asserting the correct control sequence on the DONE-~PG and M0 and M1 mode control pins. Alternatively, the user may elect to prevent reconfiguration of the device. When operating in this mode, the only method to remove the configuration is to remove all power from the device. #### Inactive Power-down In a system which is to remain in its current configuration through power loss, the M2064 may be forced into a low power inactive state by using the ~PWRDN pin. When held low, the LCA will retain all configuration data but will not operate. All clocks will be stopped and all outputs put into a high-impedance state. Power is reduced to a very low level, allowing a simple external battery arrangement to supply the required configuration data saving power (see electrical characteristics). #### Configuration Data Read-back A mechanism is provided in the M2064 to provide verification of stored configuration data. The configuration read-back is initiated by toggling the $\sim$ RT pin and clocking the CCLK pin. Each clock applied to CCLK will read out a configuration data bit on the $\sim$ RD pin. When all configuration data has been read out, the AD pin will return to its inactive state. The configuration data may be read at any time with no effect on the operation of the device. Once a configuration read-back has been initiated, all data must be read out of the device to insure that subsequent read-back operations will begin at the start of the configuration data. #### **Master Reset** After device configuration, the ~RESET pin becomes a master reset for all CLB and IOB storage elements in the device. Asserting this control signal will asynchronously reset all of the internal storage registers regardless of the operating condition of the circuit. ## **Development System** The Monolithic Memories Design System is an integrated package of design tools for developing configuration data for LCAs. All aspects of configuration are specified through interactive graphics software. Facilities to verify functionality and timing of the designed configuration insure that designs operate as desired. XACT is a graphic design system used to specify LCA designs. It contains several standard and several optional software and hardware packages. The basic package runs on an IBM PC/XT or AT compatible computer with 640K memory, a color monitor and a mouse. The tools accessible from the executive, including the optional packages, are: - LCA Editor and Macros - Timing Analyzer - Simulator (P-Silos, optional) - Configuration-File Generator - Configuration-File Formatter - XACTOR 2 In-circuit-emulator (optional). XACTOR 2 consists of a software program plus a hardware attachment that allows control of up to four LCAs. The program contains commands for: - Loading configuration data - · Activating the Master Reset input - Reconfiguring - Single stepping the device clock - Reading back configuration data and state of all 122 internal registers on any clock cycle. - Real time system debug. An evaluation kit is available which includes: - Complete documentation of the Development System - A sample LCA design - XACT software package. Contact your local Monolithic Memories Representative or Distributor for more information. # Logic Cell Array M2064 # Absolute Maximum Ratings\* | | | | | 0.5V | |-------------------------------|---------------|------|-------|-----------------------------| | Power down V <sub>CC</sub> | | | | | | nput voltage | | | | 0.5V to V <sub>CC</sub> | | oltage applied to three-state | e output | <br> | ••••• | <br>0.5V to V <sub>CC</sub> | | Storage temperature range | | | | 65°C to + | | ead temperature (soldering, | , 10 seconds) | <br> | | <br> | Note: Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those listed under "Recommended Operating Conditions" is not implied. Exposure to "Absolute Maximum Ratings" conditions for extended periods of time may affect device reliability. ## **Operating Conditions** | F | | | | | | |------------------|---------------------------------------------------------|------|--------|------|------| | SYMBOL | PARAMETER | MIN | TYP | MAX | UNIT | | V <sub>CC</sub> | Supply voltage relative to GND | 4.75 | | 5.25 | - V | | V <sub>IHT</sub> | High level input voltage — TTL configuration | 2.0 | | | ٧ | | V <sub>IHC</sub> | High level input voltage — CMOS configuration | 0.7 | | | ٧ | | V <sub>ILT</sub> | Low level input voltage — TTL configuration | 0 | P. L. | 0.8 | ٧ | | V <sub>ILC</sub> | Low level input voltage — CMOS configuration | 0 | C2 1/4 | 0.2 | ٧ | | l <sub>IT</sub> | Input leakage current — TTL configuration | | | ± 1 | μΑ | | lic | Input leakage current — CMOS configuration | | | ± 1 | μΑ, | | loz | Three-state output off current (V <sub>CC</sub> = 5.5V) | | | ± 10 | μΑ | | t <sub>OP</sub> | Operating free-air temperature | 0 | 100 | 70 | °C | # Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMET | TER | TEST CONDITION | MIN | TYP | MAX | UNIT | |-----------------------------------------------------|-------------------|------------|--------------------------------------------------|-------|-----------|------|------| | V <sub>OH</sub> | High level output | voltage | V <sub>CC</sub> = 4.75V I <sub>OH</sub> = -4.0mA | 3.86 | | | ٧ | | V <sub>OL</sub> | Low level output | voltage | V <sub>CC</sub> = 4.75V I <sub>OL</sub> = 4.0mA | | A, esse h | 0.32 | ٧ | | Quiescent operating power supply current TTL inputs | | | V <sub>CC</sub> =5.0V | | n jak | 5 | mA | | | | | V <sub>CC</sub> =5.0V | | | 10 | mA | | I <sub>CCPD</sub> | Power down supp | ly current | V <sub>CC</sub> =2.0V | Consu | It factor | / | ٧ | Note: All switching characteristics are at worst case conditions. ### **Power on Timing** The M2064 contains on-chip reset timing logic for power-up operation. To insure proper master mode system operation, VCC must rise from 2.0V to minimum specification level in 10ms or less. For other modes, initiation of configuration must be delayed for 60ms after VCC reaches the minimum specified level. # Logic Cell Array™ M2064 # Switching Characteristics — CLB | | | M | 2064 - | 50 | М | 2064 - | 33 | M | LINUT | | | |------------------|-------------------------------------------------|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------|-----|-----|--------------|-----|-----| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNI | | t <sub>ILO</sub> | Input through logic to X or Y | | | 15 | | | 20 | | | 35 | ns | | t <sub>ITO</sub> | Input through logic and latch to X or Y | | | 20 | | | 25 | | 21 A 2 | 45 | ns | | t <sub>CKO</sub> | Storage element clock from K to output | *** | | 15 | | | 20 | À | | 35 | ns | | t <sub>cco</sub> | Storage element clock from C to output | | | 19 | | | 25 | | | 45 | ns | | t <sub>CIO</sub> | Logic to storage element clock to output | | | 27 | 21 ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( | | 37 | | | 65 | ns | | t <sub>QLO</sub> | Storage element Q to logic to output | | | 8 | | | 13 | | | 30 | ns | | t <sub>ICK</sub> | Input setup to K clock to storage element | 8 | | | 12 | | | 22 | | | ns | | t <sub>CKI</sub> | Input hold to K clock to storage element | 0 | | | 0 | | | 0 | | | ns | | t <sub>ICC</sub> | Input setup to C clock to storage element | 9 | | | 12 | | | 18 | | | ns | | t <sub>cci</sub> | Input hold to C clock to storage element | 0 | | | 6 | | | 10 | | | ns | | t <sub>ICI</sub> | Input setup to input clock to storage element | 4 | | | 6 | | | 10 | | | ns | | t <sub>CII</sub> | Input hold to input clock to storage element | 5 | | | 9 | | | 15 | | | ns | | t <sub>RIO</sub> | Input to storage element<br>Reset/Set to output | | | 22 | | | 25 | | | 45 | ns | | t <sub>RLO</sub> | Logic to storage element<br>Reset/Set to output | | | 28 | | | 37 | | | 65 | ns | | t <sub>RPW</sub> | Reset/Set pulse width | 9 | | T. A.V | 12 | 3 4 | | 20 | A STATE LAND | | ns | | t <sub>RS</sub> | Storage element control separation | 9 | | | 17 | | | 30 | | | ns | | t <sub>CH</sub> | Storage element clock high time | 9 | | | 12 | | | 20 | | | ns | | t <sub>CL</sub> | Storage element clock low time | 9 | | in the second se | 12 | | | 20 | | | ns | | f <sub>CLK</sub> | Storage element clock frequency | | | 50 | | | 33 | | | 20 | MHz | | t <sub>MRQ</sub> | Master reset to storage element Q to output | | | 25 | | | 35 | | | 60 | ns | # **Cross Reference Guide** | VIIINV | MONOLITHIC | Vo | c | - <u>-</u> 1915. | |------------|------------|-------|-------|------------------| | XILINX | MEMORIES | MIN | MAX | F <sub>MAX</sub> | | XC-2064-1 | | 4.5V | 5.5V | 20MHz | | | M2064-20 | 4.75V | 5.25V | 20MHz | | XC-2064-2 | | 4.5V | 5.5V | 33MHz | | XC-2064-33 | M2064-33 | 4.75V | 5.25V | 33MHz | | XC-2064-50 | M2064-50 | 4.75V | 5.25V | 50MHz | <sup>\*</sup>For commercial product only. # Switching Characteristics — CLB Notes: 1. Input refers to CLB inputs A, B, C or D 1. Input refers to CLB iliputs A, B, C or Z 2. Output refers to CLB output X or 3. Clock refers to the CLB storage element clock 4. FF (Filp-Flop or L (Latch) refers to the CLB storage element 5. Set and Reset refer to CLB storage element controls # Switching Characteristics — IOB | | | M | 2064 - | 50 | M | 2064 - | 33 | M | 2064 - | 20 | | |------------------|------------------------------------------------|-------------|--------|------|-----|--------|-----------|-----|--------|-----|------| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | ТҮР | MAX | UNIT | | t <sub>PID</sub> | Pad to input direct | | | 8 | | | 12 | | | 20 | ns | | t <sub>PL</sub> | Pad input setup to I/O clock | 8 | | 3.55 | 12 | | | 20 | r Vi | | ns | | t <sub>LP</sub> | Pad input hold to I/O clock | 0 | | | 0 | | | 0 | | | ns | | fL | Frequency, I/O clock | | | 50 | | | 33 | | | 20 | MHz | | t <sub>LW</sub> | Pulse width input latch clock | 9 | | | 12 | | A Company | 20 | | | ns | | t <sub>Ll</sub> | Input latch clock to input | | | 15 | | 40 | 20 | | | 30 | ns | | t <sub>OP</sub> | Output to pad output (three-<br>state enabled) | e pojetine. | | 12 | | | 15 | | | 25 | ns | | t <sub>THZ</sub> | Three-state inactive to high impedance | | | 20 | | | 25 | | | 35 | ns | | t <sub>TON</sub> | Three-state active to output on | | | 20 | | | 25 | | | 40 | ns | | t <sub>RI</sub> | Master Reset to latched input reset | | | 25 | | | 30 | | | 50 | ns | Notes: 1. Output (O) refers to the output connection on the IOB - 2. Input (I) refers to the input connection on the IOB - 3. Three-state (T) refers to the three-state control on the IOB - 4. Pad or Pin (P) refers to the device pin connected to the IOB 5. Latch (L) refers to the input Flip-Flop clock connection # Switching Characteristics — Programming — Slave Mode | | | м | 2064 - | 50 | M2064 - 33 | | | М | | | | |------------------|----------------------------------------|-----|--------|------|------------|-----|------|-----|-----|-------|------| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>CCH</sub> | CCLK high time | 300 | 100 | | 3000 | | | 500 | | | ns | | t <sub>CCL</sub> | CCLK low time | 200 | | | 200 | | | 300 | | | ns | | t <sub>CCL</sub> | CCLK low time | | | 5000 | 10.14 | | 5000 | | | 10000 | ns | | t <sub>DCC</sub> | DIN data setup to CCLK rising edge | 25 | | | 25 | | | 50 | | | ns | | t <sub>CCD</sub> | DIN data hold from CCLK rising edge | 40 | | | 40 | | | 75 | | | ns | | t <sub>cco</sub> | DOUT data delay from CCLK falling edge | | | 65 | | | 65 | | | 100 | ns | | f <sub>CC</sub> | CCLK maximum frequency | | | 2 | | | 2 | | | 1 | MHz | # Switching Characteristics — Programming — Peripheral Mode | ITEM | DECODIDATION | M2064 - 50 | | | M2064 - 33 | | | M | | | | |------------------|------------------------------------|------------|-----|------|------------|-----|------|-----|-----|-------|------| | IIEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>CA</sub> | Control input active period | 200 | | | 200 | | | 300 | | | ns | | t <sub>CA</sub> | Control input active period | | | 5000 | | | 5000 | | | 10000 | ns | | t <sub>Cl</sub> | Control input inactive period | 150 | | | 150 | | | 250 | | | ns | | t <sub>CCC</sub> | CCLK delay from control input edge | | | 75 | | | 75 | | | 100 | ns | | t <sub>DC</sub> | DIN setup to control transition | 35 | | | 35 | | | 50 | | | ns | | t <sub>CD</sub> | DIN hold from control transition | 5 | | | 5 | | | 10 | | | ns | Notes: 1. Peripheral mode timing determined from last control signal (~CEO,~WS, CS) to transition to active or inactive state. 2. CCLK timing minima and maxima same as for slave mode. 3. CCLK and DOUT timing same as for slave mode. # Switching Characteristics — Programming — Master Mode | er lærte | DECODIDETION | М | 2064 - | 50 | M2064 - 33 | | | М | UNIT | | | |------------------|----------------------------------------|------|--------|-----|------------|-----|-----|------|-----------------|-----|------| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNII | | t <sub>ARC</sub> | Address invalid prior to<br>~RCLK edge | | | 0 | | | 0 | | | 0 | ns | | t <sub>RCA</sub> | Address valid from ~RCLK edge | | | 200 | | | 200 | | | 300 | ns | | t <sub>DRC</sub> | Data bus setup to ~RCLK edge | 60 | | | 60 | | | 100 | | | ns | | t <sub>RCD</sub> | Data bus hold from ~RCLK edge | 0 | | | 0 | | | 0 | | | ns | | t <sub>RCH</sub> | ~RCLK high | 600 | | | 600 | | | 600 | i<br>Sagizeg ja | | ns | | t <sub>RCL</sub> | ~RCLK low | 4000 | | | 4000 | | | 4000 | | | ns | Note: Timing for DOUT and CCLK out is same as for slave mode. # Switching Characteristics — Program Readback | | DECODIDEION | M2064 - 50 | | | M2064 - 33 | | | М | | | | |-------------------|------------------------------------------|------------|-----|-----|------------|-----|-----|-------|-----|-----|------| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>RTH</sub> | Read trigger (RT) high time | 150 | | | 150 | | | 250 | | | ns | | t <sub>RTCC</sub> | Delay from RT assertion to first CCLK | 60 | | | 60 | | | 100 | | | ns | | t <sub>CCRD</sub> | Delay from CCLK edge to<br>RD data valid | | | 60 | | | 60 | 19 C. | | 100 | ns | | t <sub>DRT</sub> | Wait period from DONE to RT assertion | 75 | | | 175 | | | 300 | | | ns | Notes: 1. Timing for CCLK is same as for slave programming mode. <sup>2.</sup> DONE/~PG output/input must be high (device programmed) prior to assertion of ~PG. # Switching Characteristics — General | | | M | 2064 - | 50 | М | 2064 - | 33 | М | шыт | | | |------------------|-----------------------------------------------|------|--------|------|------|----------|-------|------|----------|------|------| | ITEM | DESCRIPTION | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>VMR</sub> | Master Reset delay from valid V <sub>CC</sub> | 150 | | | 150 | | | 250 | esta de | | ns | | t <sub>MRW</sub> | Master Reset pulse width | 150 | | | 150 | i iya | 100 | 250 | | | ns | | t <sub>MR</sub> | Mode control setup to Master<br>Reset | 60 | | | 60 | | | 100 | | | ns | | t <sub>RM</sub> | Mode control hold from<br>Master Reset | 7 | | | 7 | | | 10 | | | ns | | t <sub>PGW</sub> | Program control pulse width | 6000 | | 2.3 | 6000 | | | 6000 | | | ns | | t <sub>PGI</sub> | Program control to I/O initialized | | | 7000 | | Aujur. | 7000 | | | 7000 | ns | | t <sub>CLH</sub> | Clock buffer input high time | 9 | | | 12 | si es de | 40,00 | 20 | u (dient | | ns | | t <sub>CLL</sub> | Clock buffer input low time | 9 | | | 12 | | | 20 | | | ns | | f <sub>CL</sub> | Clock buffer input frequency | | | 50 | | | 33 | | | 20 | MHz | #### **Test Conditions:** Outputs loaded with rated DC current and 50-pF capacitance to GND #### **Design Aids** XACT<sup>TM</sup> provides complete design automation for users to specify and implement designs utilizing Monolithic Memories' LCA products. Configuration of CLBs, internal routing, I/O block definitions and global routing are all handled in an integrated, easy-to-use system. Placement and routing of logic and I/O blocks is accomplished using interactive graphics. Final programming bit patterns are automatically produced for debugging, transfer to other systems, or downloading to standard EPROM programmers. Debugging with the XACTOR 2<sup>TM</sup> emulation system allows full device emulation and operation analysis in the target system. The user inputs data via a graphics-oriented physical editing environment. User functions are translated into CLB logic specifications and interconnections automatically. Standard logic libraries and other macro capabilities can be utilized for rapid design entry. Physical placement and hard connections are performed with the graphics placement and connection capabilities. Final device layout and routing are visible and can be modified without disturbing the logical arrangement. Logical connectivity and physical layout rules checking are performed automatically. Full timing analysis and functional simulation of user configurations allows device performance and functional checking without external test hardware. In addition, point-to-point path timing calculation capability is provided to simplify general timing analysis and critical path determination. The debugging system provides full emulation in the user's target system. User configurations may be transferred directly from the design phase into the target system and tested through the emulation system. Additional capabilities include a tool for automatic hard copy generation of the user's logic design and physical implementation and a tool for transferring programming bit patterns to EPROM programming systems. # **Recommended Sockets** The following 68-pin PLCC sockets have been evaluated by Monolithic Memories and have been found to exhibit acceptable connectivity, device retention and device extraction characteristics: | VENDOR | DESCRIPTION | PART<br>NUMBER | | | | |------------------|----------------------------|------------------------|--|--|--| | AMP | PCB solder tail, tin plate | 821574-1 | | | | | AMP | Surface mount, tin plate | 821542-1 | | | | | Burndy | PCB solder tail, tin plate | QILE68P-410T | | | | | Midland-<br>Ross | PCB solder tail, tin plate | 709-2000-068-<br>4-1-1 | | | | The following 68-pin PLCC sockets are also available: | VENDOR | DESCRIPTION | PART<br>NUMBER | |---------|----------------------------|----------------| | Methode | PCB solder tail, tin plate | 213-068-001 | | Methode | Surface mount, tin plate | 213-068-002 | Notes: - The standard device extraction tools supplied with the XACT development system will work with all of the above sockets. - 2. All of the above PCB solders tail sockets have the same hold pattern and pinout. **Representatives and Distributors** # PALASM® 2 Software # Introducing PALASM®2 Software PALASM 2 software is a package that turns PAL device Design Specification (PDS) files into input files for PAL device programmers. PDS is a format for specifying a PAL circuit and for creating inputs to a logic circuit. Using a text editor, you create a PDS file that describes a PAL circuit. PALASM 2 software accepts the file as input and performs a number of functions under your control including: - Assembling PAL Design Specifications. - Generating PAL device fuse patterns in JEDEC format. - Reporting errors in syntax and assembly. - Allowing concise mnemonic names for long, frequently used logic expressions through string substitution. #### Functional differences from PALASM 1 PALASM 2 software is quite different from PALASM 1 in implementation. It is composed of several interacting programs coupled by disk files. (Floppy based files slow interaction. We recommend RAM or hard disks for production use.) The principal benefit of the reorganization is the freedom from fixed limits within the design file. The syntax of PALASM 2 software is significantly different from that of PALASM 1. PALASM 2 software allows description of asynchronous devices like the 20RA10 and devices of much higher complexity such as MegaPAL devices. The current version of PALASM 2 software omits several features provided within PALASM 1. They are: - Fault coverage prediction for test vectors. - Automatic generation of documentation. - Device signal/pinout display. - Support of the security fuse. - Printing of logic equations for each product term in a fuse Some of these omissions represent a change in philosophy; others will be provided in later versions of the program. ## Required Equipment T is section describes computers and PAL device programmers supported by PALASM 2 software and provides information about necessary and optional PALASM 2 software. #### Computers PALASM 2 software operates with no user modification on the following CPUs, provided certain minimum system requirements are satisfied. It is usually provided as an executable program, ready to run on any of these systems: Minicomputers: VAXTM under VMSTM Microcomputers: IBM-PCTM, -XTTM, -ATTM under MS-DOSTM (256K RAM) All systems must have a serial port (RS-232) for communication with the PAL device programmer. We also recommend that floppy disk based systems be equipped with two disk drives. Figure 1. Typical Computer Configuration #### NOTE Please refer to a PALASM 2 software order form for the correct part number of the version of PALASM 2 software designed for your CPU. Monolithic M Memories Figure 2. PALASM Software Flow ty or the second #### **PDSCNVT** PDSCNVT allows you to interactively convert PAL device design specifications from the PALASM 1 format to PALASM 2 software. Input is a PALASM 1 formatted specification file, and output is the equivalent design in PALASM 2 software syntax. ### PALASM 2 PALASM 2 is the first program you will use in the PALASM 2 software suite. It reads and validates your input — a PAL device design specification — for correct design syntax. If an error is detected, the program attempts to indicate where in the input description the error has occurred. Recovery is attempted after each error in order to catch as many errors as possible on a single run. Only if no error is detected is an intermediate specification file generated. This file contains the input specification in a hierarchically structured form to enable easy processing by follow-on programs. Further, it is guaranteed to be syntactically correct. This program recognizes input descriptions for all current PAL devices. #### **XPLOT** XPLOT validates the architectural design of an input PAL device description and produces fuse maps and JEDEC data for a specified PAL device. Input is a set of Boolean equations that has been preprocessed by the PALASM 2 program. XPLOT checks the equations for consistency among themselves and with the specified PAL device. When an error is detected, XPLOT attempts immediate recovery. In this way, XPLOT spots as many errors as possible on each run. Only if no errors are detected will the output fuse maps and JEDEC data be generated. The architectural information for each PAL device is read in from a file containing a profile description for the specific PAL device. #### NOTE XPLOT will check only valid Monolithic Memories PAL devices. #### SIM SIM checks the functionality of a PAL device design. You will run this program after XPLOT. If the design is architecturally correct, however, you can run SIM directly after PALASM 2. SIM reads a special simulation syntax that has been preprocessed by PALASM 2. It will simulate the operation of the PAL device you specify, calculating the output values based on input signals through the Boolean equations and any feedback. Output is a history file that traces the values of every pin through a simulation sequence. A trace file, which is a subset of the history file, traces only the pins you specify in the simulation syntax. If XPLOT has been run and a JEDEC fuse address file has been created, then SIM will add test vectors to the JEDEC file that duplicate the simulation sequence when the device is tested on a programmer. All JEDEC checksums are recalculated. #### NOTE SIM will test only valid Monolithic Memories PAL devices. #### ZHAL ZHAL makes sure that a PAL device description will fit into the ZHAL device architecture. ZHAL reads the description that has been preprocessed by the PALASM 2 software program, and a YES or NO answer is output. If the design fits, you must send the PAL device Design Specification to Monolithic Memories for mask processing. Before a description is rejected, the program will attempt to minimize the input equations to make use of some sharing features in the ZHAL architecture. ZHAL will also indicate what the error is before a no fit answer is output. #### NOTE ZHAL currently accepts designs only for valid Monolithic Memories PAL devices. ## **MENU** MENU is an interactive program designed to simplify user interface to PALASM 2 software. MENU's multiple choice selection process offers you a number of options at each stage. Once you have made a selection, your choice is automatically executed. MENU makes the modular design of the PALASM 2 software system invisible to you. All you need to know is what you want to do, not how-to. For example, if you select simulation, the programs PALASM 2, XPLOT and SIM automatically run in sequence, and your need to understand the functions of the individual programs is greatly reduced. ## PC<sub>2</sub> PC2 enables communication between PLD programmers and IBM<sup>TM</sup> PC machines (-PC, -XT, -AT, etc.). It is a menu-driven multiple-choice program that guides you through various options for programming and checking PLD devices. ## VTRACE VTRACE reads the trace output of the PALASM 2 software simulator. The text-formatted data of the trace file is converted into graphic form. VTRACE output looks very much like timing diagrams of the simulation results. #### **Software Customization** For software development and user customization of PALASM 2 software, you will need a Pascal compiler/linker and a second disk drive. These are necessary to create the executable version of the program. Monolithic Memories recommends the Professional Pascal compiler (Microtek Inc.) which was used to develop and test the programs on the IBM-PC. PALASM 2 software is written in nearly ISO Standard Pascal to ease porting to many computer systems. #### CAUTION Porting PALASM 2 software to other computer systems will require you to install and modify the original source code. Allow at least two to four weeks of software engineering time to complete this task. Monolithic Memories makes no guarantee of the portability of PALASM 2 software, and does not provide support for such efforts or other user modification. # **PAL Device Applications** # **Table of Contents** | PAL20L10; 10-Bit Open Collector Burner | | |-------------------------------------------------------------------------------------|------| | PAL20L10; 10-Bit Open Collector Inverting Buffer | | | PAL20X10; 10-Bit Addressable Register | 7-7 | | PAL20L10; MC6800 Microprocessor Interface | | | PAL14L4; Quad 3:1 Multiplexer | 7-13 | | PAL20X8; 4-Bit Counter With Register | 7-14 | | PAL20X10; 9-Bit Down Counter | 7-16 | | PAL20X10; Refresh Clock Generator | 7-18 | | PAL16R8; Octal Addressable Register | 7-21 | | PAL16R8; Octal Addressable Register With Demux/Enables | 7-24 | | PAL16R8; Octal Addressable Register With Demux/Clear | 7-28 | | PAL16C1; Rounding-Control Logic | | | PAL16R6; 4-Bit Counter With Terminal Count Lock | 7-32 | | PAL18L4; Memory-Mapped I/O | | | PAL16R4; 74S508 Memory Map Interface #1 | 7-36 | | PAL16R4; 74S508 Memory Map Interface #2 | 7-38 | | PAL20R4; 16 Input Registered Priority Encoder #1 | 7-39 | | PAL16C1; 16 Input Priority Encoder Interrupt Flag #2 | 7-41 | | PAL20R4; 15 Input Registered Priority Encoder | 7-42 | | PAL16R4; 8 Input Registered Priority Encoder | 7-44 | | PAL16R4, 8 Input Registered Priority Encoder PAL16R8; Dual Stepper Motor Controller | 7-47 | | PAL20L10; Clean Octal Latch | 7-49 | | PAL16R4; Shaft Encoder #1 | 7-51 | | PAL16R8; Shaft Encoder #2 | | | PAL20X10; Shaft Encoder #3 | | | PAL6L16; Four-to-Sixteen Decoder PAL8L14; PC I/O Mapper | 7-60 | | PAL8L14; PC I/O Mapper | 7-61 | | PAL16C1; Octal Comparator | 7-62 | | PAL16R8; Three-to-Eight Demultiplexer | 7-63 | | PAL16RP8; Basic Flip-Flops PAL20X10; 9-Bit Register | 7-64 | | PAL20X10; 9-Bit Register | 7-65 | | PAL20X10; 10-Bit Register | 7-66 | | PAL64R32; 16-Bit Barrel Shifter | 7-67 | | PAL32R16; 16-Bit Addressable Register | 7-69 | | PAL16RP8; Traffic Signal Controller | 7-71 | | PAL16RP6; Memory Handshake Logic | 7-73 | | PAL16RP4; 4-Bit Counter | 7-76 | | PAL20X8; 8-Bit Counter | | | PAL20X10; 9-Bit Counter | | | PAL20RS10; 10-Bit Counter | 7-79 | | PAL20RA10, PAL16C1; 5-Bit Up Counter | 7-80 | | PAL20RA10; 7-Bit I/O Port | 7-83 | | PAL20RA10; Serial Data Link Controller | 7-85 | | PAL20RA10, PAL20L10; Interrupt Controller | 7-88 | ``` Title 10-BIT OPEN COLLECTOR BUFFER Pattern P7070 Revision A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 10/21/81 CHIP 10-BIT OPEN COLLECTOR BUFFER PAL20L10 /OC1 DO D1 D2 D3 D4 D5 D6 D7 D8 D9 GND /OC2 Y9 Y8 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 VCC EQUATIONS IF(OC1*/D0) /Y0 = VCC ;YO= DO (TRUE) IF(OC1*/D1) /Y1 = VCC ;Y1= D1 (TRUE) IF(OC1*/D2) /Y2 = VCC ;Y2= D2 (TRUE) IF(OC1*/D3) /Y3 = VCC ;Y3= D3 (TRUE) IF(OC1*/D4) /Y4 = VCC ;Y4= D4 (TRUE) IF(OC2*/D5) /Y5 = VCC ;Y5= D5 (TRUE) IF(OC2*/D6) /Y6 = VCC ;Y6= D6 (TRUE) IF(OC2*/D7) /Y7 = VCC ;Y7= D7 (TRUE) IF(OC2*/D8) /Y8 = VCC ;Y8= D8 (TRUE) IF(OC2*/D9) /Y9 = VCC ; Y9= D9 (TRUE) ; FUNCTION TABLE FOR PALASM 1 ;/OC2 /OC1 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 ; Y9 Y8 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 INPUT DATA OUTPUT DATA :/OC DDDDDDDDDD YYYYYYYYY ``` | ;2 1 | 9876543210 | 9876543210 | COMMENTS | |------|------------|------------|---------------------------------| | ;L L | LLLLLLLLL | LLLLLLLLL | TEST L's (TRUE D) | | ;LL | нинининни | ZZZZZZZZZZ | TEST H's (TRUE D) | | ;LL | HLHLHLHLHL | ZLZLZLZLZL | TEST EVEN CHECKERBOARD (TRUE D) | | ;L L | LHLHLHLHLH | LZLZLZLZ | TEST ODD CHECKERBOARD (TRUE D) | | ;H L | XXXXXLLLLL | ZZZZZLLLLL | TEST HI-Z FOR /OC2=H | | ;LH | LLLLLXXXXX | LLLLLZZZZZ | TEST HI-Z FOR /OC1=H | | ; | | | | # 10-Bit Open Collector Buffer ## ; DESCRIPTION ; THE 10-BIT OPEN COLLECTOR BUFFER WILL OUTPUT THE INPUT DATA (D). THE ;OUTPUTS (Y) WILL BE EITHER L OR HI-Z. ;CERTAIN OUTPUTS WILL BE HIGH-Z (Y=Z) IF EITHER OUTPUT CONTROL LINE ;IS HIGH (/OC=H) REGARDLESS OF OTHER INPUTS. NOTE THAT OC2 CONTROLS ;OUTPUTS Y9-Y5 AND OC1 CONTROLS OUTPUTS Y4-Y0. OC2 AND OC1 CONTROL ;INDEPENDENTLY. #### ; OPERATIONS TABLE: | ; | /OC2 | /OC1 | D9-D0 | Y9-Y5 | Y4-Y0 | OPERATION | |---|------|------|-------|-------|--------------|-------------------------| | ; | н | x | x | z | x | HI-Z FOR UPPER 5 BITS | | ; | X | H | X | X | $\mathbf{z}$ | HI-Z FOR LOWER 5 BITS | | ; | L | L | D | D | D | OUTPUT TRUE (L or HI-Z) | | • | | | | | | | ``` Title 10-BIT OPEN COLLECTOR INVERTING BUFFER Pattern P7071 Revision A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 10/21/81 CHIP 10-BIT OPEN COLLECTOR INVERTING BUFFER PAL20L10 /OC1 DO D1 D2 D3 D4 D5 D6 D7 D8 D9 GND /OC2 Y9 Y8 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 VCC EQUATIONS IF(OCl*D0) / Y0 = VCC ;Y0= /D0 (COMP) IF(OC1*D1) /Y1 = VCC ;Yl=/Dl (COMP) IF(OC1*D2) /Y2 = VCC ;Y2 = D2 (COMP) ;Y3 = /D3 (COMP) IF(OC1*D3)/Y3 = VCC IF(OC1* D4) /Y4 = VCC ;Y4 = /D4 (COMP) IF(OC2*D5) /Y5 = VCC ;Y5=/D5 (COMP) IF(OC2*D6) /Y6 = VCC ;Y6 = /D6 (COMP) IF(OC2*D7) /Y7 = VCC ;Y7 = D7 (COMP) IF(OC2*D8) /Y8 = VCC ;Y8= /D8 (COMP) IF(OC2*D9) /Y9 = VCC ;Y9= /D9 (COMP) ; FUNCTION TABLE FOR PALASM 1 ;/OC2 /OC1 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 Y9 Y8 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 INPUT DATA OUTPUT DATA;/OC DDDDDDDDDD YYYYYYYYY 9876543210 ;2 1 9876543210 COMMENTS ;---- ;LL LLLLLLLLL ZZZZZZZZZZ TEST L's (COMP D) TEST H's (COMP D) нннннннн ;LL LLLLLLLLL ;LL HLHLHLHL LZLZLZLZLZ TEST EVEN CHECKERBOARD (COMP D) LHLHLHLHLH ;LL ZLZLZLZLZL TEST ODD CHECKERBOARD (COMP D) TEST HI-Z FOR /OC2=H ;H L хххххннннн ZZZZZLLLLL TEST HI-Z FOR /OC1=H ;LH HHHHHXXXXX LLLLLZZZZZ ``` ## 10-Bit Open Collector Inverting Buffer #### ; DESCRIPTION ;THE 10-BIT INVERTING OPEN COLLECTOR BUFFER WILL OUTPUT THE ;COMPLEMENT OF THE INPUT DATA (D). THE OUTPUTS (Y) WILL BE ;EITHER L OR HI-Z. ;CERTAIN OUTPUTS WILL BE HIGH-Z (Y=Z) IF EITHER OUTPUT CONTROL ;LINE IS HIGH; (/OC=H) REGARDLESS OF OTHER INPUTS. NOTE THAT ;OC2 CONTROLS OUTPUTS Y9-Y5 AND OC1 CONTROLS OUTPUTS Y4-Y0. ;OC2 AND OC1 CONTROL INDEPENDENTLY. ## ;OPERATIONS TABLE: | ; | /OC2 | /OC1 D9-D0 Y9-Y5 Y4-Y0 | ·. | OPERATION | | |---|--------|------------------------------------------------------|----|------------------------------------------------|-------| | ; | H<br>X | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | HI-Z FOR UPPER 5 BITS<br>HI-Z FOR LOWER 5 BITS | | | 3 | L<br> | L D /D /D | | OUTPUT COMP (L or HI-Z | )<br> | ``` Title 10-BIT ADDRESSABLE REGISTER Pattern P7072 (PMSI407) Revision A DANESH TAVANA Author Company MMI SUNNYVALE, CALIFORNIA Date 04/05/82 CHIP 10-BIT_ADDRESSABLE REGISTER PAL20X10 CLK /CLR /PR A B C D E1 E2 /E3 DIN GND Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 EQUATIONS /Q0 := CLR ;CLEAR (LSB) + + /PR*/Q0 :+: /PR*/CLR* E1* E2* E3*/D*/C*/B*/A*/Q0* DIN ;HOLD (/Q0) ;LOAD ( DIN:+:/Q0) IF /Q0=H /PR*/CLR* E1* E2* E3*/D*/C*/B*/A* Q0*/DIN ;LOAD (/DIN:+:/QO) IF /QO=L /Q1 := ; CLEAR /PR*/Q1 ;HOLD (/Q1) :+: /PR*/CLR* E1* E2* E3*/D*/C*/B* A*/Q1* DIN ;LOAD ( DIN:+:/Q1) IF /Q1=H /PR*/CLR* E1* E2* E3*/D*/C*/B* A* Q1*/DIN ;LOAD (/DIN:+:/Q1) IF /Q1=L /Q2 := CLR ;CLEAR + /PR*/Q2 ;HOLD (/Q2) ;LOAD ( DIN:+:/Q2) IF /Q2=H :+: /PR*/CLR* E1* E2* E3*/D*/C* B*/A*/Q2* DIN + /PR*/CLR* E1* E2* E3*/D*/C* B*/A* Q2*/DIN ;LOAD (/DIN:+:/Q2) IF /Q2=L /Q3 := CLR ; CLEAR + /PR*/Q3 ;HOLD (/Q3) :+: /PR*/CLR* E1* E2* E3*/D*/C* B* A*/Q3* DIN ;LOAD ( DIN:+:/Q3) IF /Q3=H + /PR*/CLR* E1* E2* E3*/D*/C* B* A* Q3*/DIN ;LOAD (/DIN:+:/Q3) IF /Q3=L /Q4 := CLR ;CLEAR /PR*/Q4 ;HOLD (/Q4) :+: /PR*/CLR* E1* E2* E3*/D* C*/B*/A*/Q4* DIN ;LOAD ( DIN:+:/Q4) IF /Q4=H /PR*/CLR* E1* E2* E3*/D* C*/B*/A* O4*/DIN ;LOAD (/DIN:+:/Q4) IF /Q4=L /Q5 := CLR ;CLEAR + /PR*/Q5 ;HOLD (/Q5) :+: /PR*/CLR* E1* E2* E3*/D* C*/B* A*/Q5* DIN ;LOAD ( DIN:+:/Q5) IF /Q5=H + /PR*/CLR* E1* E2* E3*/D* C*/B* A* Q5*/DIN ;LOAD (/DIN:+:/Q5) IF /Q5=L /Q6 := CLR ; CLEAR + /PR*/Q6 :+: /PR*/CLR* E1* E2* E3*/D* C* B*/A*/Q6* DIN ;HOLD (/Q6) ;LOAD ( DIN:+:/Q6) IF /Q6=H + /PR*/CLR* E1* E2* E3*/D* C* B*/A* Q6*/DIN ;LOAD (/DIN:+:/Q6) IF /Q6=L /Q7 := CLR ; CLEAR /PR*/Q7 ;LOAD ( DIN:+:/Q7) IF /Q7=H :+: /PR*/CLR* E1* E2* E3*/D* C* B* A*/Q7* DIN ;LOAD (/DIN:+:/Q7) IF /Q7=L + /PR*/CLR* E1* E2* E3*/D* C* B* A* Q7*/DIN /Q8 := CLR ;CLEAR + /PR*/08 ;HOLD (/Q8) :+: /PR*/CLR* E1* E2* E3* D*/C*/B*/A*/Q8* DIN ;LOAD ( DIN:+:/Q8) IF /Q8=H /PR*/CLR* E1* E2* E3* D*/C*/B*/A* Q8*/DIN ;LOAD (/DIN:+:/Q8) IF /Q8=L ``` ``` /Q9 := CLR ;CLEAR (MSB) ;HOLD (/Q9) /PR*/Q9 :+: /PR*/CLR* E1* E2* E3* D*/C*/B* A*/Q9* DIN ;LOAD ( DIN:+:/Q9) IF /Q9=H /PR*/CLR* E1* E2* E3* D*/C*/B* A* Q9*/DIN ;LOAD (/DIN:+:/Q9) IF /Q9=L ; FUNCTION TABLE FOR PALASM 1 ;/OC CLK /CLR /PR /E3 E2 E1 D C B A DIN Q9 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 ----OUTPUTS---- ; CONTROL ----FUNCTIONS---- --- INPUTS-- 00000000000 ;/OC CLK /CLR /PR /E3 E2 E1 D C B A DIN 9 8 7 6 5 4 3 2 1 0 COMMENTS ; L C L X х X LLLLLLLLLL /CLR OVRRD /PR X X X X X ; L С Н L Х \mathbf{X} = \mathbf{X} HHHHHHHHH /PR OVRRD ENABLE X X X X X ; L С H H LLLL HHHHHHHL LOAD QO WITH DIN H H L L LLLH C H Η L H H L HHHHHHLL LOAD O1 WITH DIN ; L L C Н H L Н Η LLHL L HHHHHHLLL LOAD O2 WITH DIN ГГНН H L С Н Н L Н HHHHHLLLL LOAD Q3 WITH DIN С HHHHLLLLL LOAD Q4 WITH DIN L Н H L H H LHLL L н н C LHLH LOAD Q5 WITH DIN L L L HHHHLLLLLL Н Η ; L С н н LHHL L LOAD Q6 WITH DIN Н Н L HHHLLLLLLL C H H LHHH L ; L Н H L HHLLLLLLLL LOAD Q7 WITH DIN C LOAD OS WITH DIN ; L H Н L н н HLLL L HLLLLLLLLL С ; L H н L н н HLLH L LLLLLLLLLL LOAD Q9 WITH DIN c ; L Н Н L HLLH H HLLLLLLLLL LOAD Q9 WITH DIN н н С HHLLLLLLLL Н L H L L L H LOAD Q8 WITH DIN ; L Н н н HHHLLLLLLL LOAD Q7 WITH DIN ; L С Н H L н н LHHH H С Н Н L H H LHHL H HHHHLLLLLL LOAD Q6 WITH DIN ; L LHLH ; L C Н Н L H H H HHHHLLLLL LOAD Q5 WITH DIN r r r r L C H L H HHHHHLLLL LOAD Q4 WITH DIN ; H H Н L С H н L H H н HHHHHHLLL LOAD Q3 WITH DIN H LOAD Q2 WITH DIN L C L LLHL HHHHHHLL Η H H Н L С H Η LLLH H ннннннннь LOAD Q1 WITH DIN Н H L C н н LLLLH LOAD QO WITH DIN L H H H H H H H H H Η н L ; L C Н Н L L L X X X X X нннннннн HOLD STATE C H H LLLLL HHHHHHHL LOAD QO WITH DIN ; L Н H L x x x x x ; L С H Н LLH HHHHHHHL HOLD STATE С H H LLHL L HHHHHHLHL LOAD Q2 WITH DIN ; L H H L C H L H L x x x x x HHHHHHLHL HOLD STATE ; L Η C ; L H H н н LHLL L HHHHLHLHL LOAD Q4 WITH DIN н C H L L X X X X X HHHHHLHLHL HOLD STATE ; L Н C HHHLHLHL LOAD Q6 WITH DIN ; L H H L н н LHHLL C H L X X X X X HHHLHLHL HOLD STATE Н Н H ; L L LOAD Q8 WITH DIN H HLHLHLHL ; L C H н L Н HLLL ``` С H H X ; L ; H н н н X X X X X X X X X X X HLHLHLHL 2 2 2 2 2 2 2 2 2 2 2 HOLD STATE TEST HI-Z #### ; DESCRIPTION ;THE 10-BIT ADDRESSABLE REGISTER IS A SYNCHRONOUS GENERAL PURPOSE ADDRESSABLE ;REGISTER WITH CLEAR, PRESET, AND ENABLE. THE OUTPUT REGISTER (Q) IS SELECTED ;BY THE INPUT ADDRESS PINS (A,B,C,D). THE DATA (DIN) IS LOADED INTO THE ;SELECTED OUTPUT REGISTER ON THE RISING EDGE OF THE CLOCK (CLK) IF THE CHIP IS ;ENABLED (E1=HIGH,E2=HIGH,/E3=LOW). ALL OTHER OUTPUTS HOLD THEIR PREVIOUS ;STATES DURING THE LOAD OPERATION. ANY OTHER COMBINATION OF THE ENABLE PINS ;(E1,E2,/E3) WILL DISABLE THE REGISTER AND ALL OUTPUTS WILL HOLD THEIR PREVIOUS ;STATES. CLEAR (/CLR) AND PRESET (/PR) ARE ACTIVE LOW PINS WHICH SET THE ;REGISTERS TO ALL HIGH OR LOW RESPECTIVELY. ;CLEAR OVERRIDES PRESET AND ENABLE, PRESET OVERRIDES ENABLE. ;THESE FUNCTIONS ARE EXERCISED IN THE FUNCTION TABLE AND SUMMARIZED IN THE ;OPERATIONS TABLE: | 1 | /oc | CLK | /CLR | /PR | /E3 | E2 | El | D | С | В | Α | DIN | Q9-Q0 | OPERATION | |---|-----|-----|------|-----|-----|----|----|---|---|---|---|-------|-------|------------------------------| | | н | х | x | х | x | x | | x | x | x | x | <br>х | z | HI-Z | | 1 | L | С | L | L | X | X | X | X | X | Х | X | Х | L | CLEAR | | | L | С | H | L | Х | X | X | X | Х | X | X | Х | H | PRESET | | | L | С | H | H | L | L | L | X | X | X | X | X | Q | HOLD PREVIOUS STATES | | | L | С | H | H | L | L | H | X | X | Х | X | X | Q | HOLD PREVIOUS STATES | | | L | С | H | H | L | H | L | X | X | X | X | X | Q | HOLD PREVIOUS STATES | | | L | С | H | H | L | H | H | D | C | В | Α | DIN | DIN | LOAD DIN TO ADDRESSED OUTPUT | | | L | С | H | H | Н | L | L | X | X | Х | Х | X | Q | HOLD PREVIOUS STATES | | | ; L | С | H | H | H | L | H | х | Х | X | Х | Х | Q | HOLD PREVIOUS STATES | | | ; L | С | H | Н | H | н | L | Х | X | Х | х | X | Q | HOLD PREVIOUS STATES | | | ; L | С | H | н | н | н | Н | х | X | X | X | х | õ | HOLD PREVIOUS STATES | | Ι | ) | С | В | Α | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | |---|---|---|---|---|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | ] | , | L | L | L | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | DIN | | 1 | , | L | L | H | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | DIN | Q0 | | 1 | ٠ | L | H | L | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | DIN | Q1 | Q0 | | 1 | | L | H | H | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | DIN | Q2 | Q1 | QO | | 1 | | H | L | L | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | DIN | Q3 | Q2 | Q1 | Q0 | | 1 | , | H | L | H | DIN | Q9 | Q8 | Q7 | Q6 | DIN | Q4 | Q3 | Q2 | Q1 | Q0 | | 1 | , | H | H | L | DIN | Q9 | Q8 | Q7 | DIN | Q5 | Q4 | Q3 | Q2 | Q1 | QO | | 1 | , | H | Н | H | DIN | Q9 | Q8 | DIN | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | QO | | I | I | L | L | L | DIN | Q9 | DIN | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | QO | | I | I | L | L | H | DIN | DIN | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | | I | I | L | H | L | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | | I | I | L | H | H | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | | 1 | I | H | X | X | DIN | Q9 | Q8 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | Monolithic IIII Memories ``` Title MC6800 MICROPROCESSOR INTERFACE ``` Pattern P7073 Revision A Author COLI/SACKETT Company MMI SUNNYVALE, CALIFORNIA Date 09/14/82 ## CHIP MC6800 MICROPROCESSOR INTERFACE PAL20L10 A15 A14 A13 A12 A11 NC /S /R PH2 VMA /AR GND ENIN EN /IO /RAM4 /RAM3 /RAM2 /RAM1 /PROM2 /PROM1 /RSET VUA VCC #### **EQUATIONS** | IF(VCC) | PROM1 | = | A15* | A14* | A13* | A12 | * * | VMA* | PH2*/RSET | ;PROM1, | F000-FFFF | |---------|-------|-----|-----------|--------|------------|--------|-------|-------|-------------|------------|------------| | IF(VCC) | PROM2 | _ | A15* | A14* | A13*/ | /A12 | * | VMA* | PH2*/RSET | ;PROM2, | E000-EFFF | | IF(VCC) | RAM1 | = | /A15* | /A14*/ | 'A13*/ | /A12*, | /All* | VMA* | PH2*/RSET | ;RAM1, | 0000-07FF | | IF(VCC) | RAM2 | = | /A15* | /A14*/ | A13*/ | /A12* | All* | VMA* | PH2*/RSET | ;RAM2, | 0800-0FFF | | IF(VCC) | RAM3 | • = | /A15* | /A14*/ | A13* | A12*, | /All* | VMA* | PH2*/RSET | ;RAM3, | 1000-17FF | | IF(VCC) | RAM4 | = | /A15* | /A14*/ | 'A13* | A12* | All* | VMA* | PH2*/RSET | ;RAM4, | 1800-1FFF | | IF(VCC) | IO | = | A15* | A14*/ | A13* | A12* | A11* | VMA* | PH2*/RSET | ;1/0, | D800-DFFF | | IF(VCC) | /EN | = | /PROM | 1*/PR0 | M2*/I | RAM1* | /RAM2 | */RAM | 3*/RAM4*/IC | * VMA*/RSE | r ;EN=/VUA | | IF(VCC) | /VUA | | ENIN | | ;1 | ASSER' | TIVE | HIGH | VUA SIGNAL | (INVERT EN | FEEDBACK) | | IF(VCC) | RSET | + | s<br>/R * | | ;SI<br>;RI | | nanm | | | | | #### ; FUNCTION TABLE FOR PALASM 1 + /AR\* RSET ;A15 A14 A13 A12 A11 /S /R /AR /RSET PH2 VMA /PROM1 /PROM2 /RAM1 /RAM2 /RAM3 ;/RAM4 /IO EN ENIN VUA ; AUTO RESET | ;ADDR1 | s- | ·R | | /RE | | | PR | MO | | -RI | /M- | | | ENA | BLE | | | |---------|----|----|-----|-----|-----|-----|----|----|---|-----|-----|---|-----|-----|-----|-----|-----------------| | ;54321 | /s | /R | /AR | SET | PH2 | VMA | 1 | 2 | 1 | 2 | 3 | 4 | 1/0 | OUT | IN | VUA | COMMENT | | ; | | | | | | | | | | | | | | | | | | | ;HHHHX | L | Н | L | L | L | H | H | Н | H | Н | Н | H | H | H | H | L | RESET (/S=L) | | ; HHHHX | H | L | H | L | L | H | H | H | H | H | H | H | H | H | H | L | AUTO-RESET | | ; HHHHX | H | L | L | H | L | H | H | H | H | H | H | H | H | L | L | H | NO SELECT PH2=L | | ;HHHHX | H | L | L | H | H | L | H | H | H | Н | H | Н | H | H | H | L | NO SELECT VMA=L | | ; HHHHX | H | L | L | H | H | H | L | H | H | H | Η | H | H | H | H | L | SELECT PROM1 | | ; HHHLX | H | L | L | H | Ħ | H | H | L | H | H | H | H | H | н | H | L | SELECT PROM2 | | ; LLLLL | H | L | L | H | H | H | H | Н | L | H | H | H | H | H | H | L | SELECT RAM1 | | ; LLLLH | H | L | L | H | H | H | H | H | H | L | H | H | H | H | H | L | SELECT RAM2 | | ; LLLHL | H | L | L | H | H | H | H | Η | H | H | L | Н | H | H | H | L | SELECT RAM3 | | ;LLLHH | H | L | L | H | H | H | H | H | H | H | H | L | H | H | H | L | SELECT RAM4 | | ; HHLHH | Н | L | L | H | H | H | H | H | H | H | H | H | L | H | H | L | SELECT 1/O PORT | | ; | | | | | | | | | | | | | | | | | | #### ; DESCRIPTION ;THIS PAL20L10 INTERFACES BETWEEN THE MOTOROLA MC6800 MICROPROCESSOR AND ITS ;SYSTEM COMPONENTS ON A SINGLE BOARD COMPUTER. THE FUNCTIONS IT PERFORMS, ;PREVIOUSLY DONE WITH RANDOM LOGIC ARE: ADDRESS DECODING, MEMORY AND I/O ;SELECT, RESET SIGNAL GENERATION, AND CONTROL OF THE BUFFER WHICH INTERFACES ;THE DATA BUS TO OTHER BOARDS IN THE SYSTEM. # ; FUNCTION TABLE FOR PALASM 1 ;B A 1C0 1C1 1C2 2C0 2C1 2C2 3C0 3C1 3C2 4C0 4C1 4C2 1Y 2Y 3Y 4Y | ; | SE | L | | INP | UTS | | ( | ודטכ | PUTS | 3 | COMMENTS | |----|----|-------|-----|-----|-----|-----|----|------|------|-----|--------------| | ; | | | 1C | 2C | 3 C | 4C | | | | | | | ; | В. | A<br> | 012 | 012 | 012 | 012 | lY | 2 Y | 34 | 4 Y | | | ; | L | | LHH | ннн | ннн | ннн | L | Н | Н | H | 1C0=0 | | ; | | L | HHH | LHH | HHH | HHH | H | L | H | H | 2C0=0 | | ; | | L | HHH | HHH | LHH | HHH | H | H | L | H | 3C0=0 | | ; | | L | ннн | HHH | HHH | LHH | H | H | H | L | 4C0=0 | | ; | | L | HLL | LLL | LLL | LLL | H | L | L | L | 1C0=1 | | ; | | L | LLL | HLL | LLL | LLL | L | H | L | L | 2C0=1 | | ٠; | L | L | LLL | LLL | HLL | LLL | L | L | H | L | 3C0=1 | | ; | L | L | LLL | LLL | LLL | HLL | L | L | L | Н | 4C0=1 | | ; | L | L | HHH | HHH | HHH | HHH | H | Н | H | Н | TOGGLE LINES | | ; | L | H | HLH | HHH | ннн | HHH | L | H | H | Н | 1C1=0 | | ; | L | H | HHH | HLH | ннн | HHH | H | L | H | Н | 2C1=0 | | ; | L | H | HHH | HHH | HLH | HHH | Н | Н | L | H | 3C1=0 | | ; | L | H | HHH | HHH | HHH | HLH | H | Н | H | L | 4C1=0 | | ; | L | H | LHL | LLL | LLL | LLL | Н | L | L | L | 1C1=1 | | ; | L | H | LLL | LHL | LLL | LLL | L | н | L | L | 2C1=1 | | ; | L | H | LLL | LLL | LHL | LLL | L | L | H | L | 3C1=1 | | ; | L | Н | LLL | LLL | LLL | LHL | L | L | L | H | 4C1=1 | | ; | L | H | HHH | HHH | HHH | ннн | H | H | H | H | TOGGLE LINES | | ; | Н | L | HHL | ннн | ннн | ннн | L | Н | Н | Н | 1C2=0 | | ; | Н | L | HHH | HHL | HHH | ннн | H | L | Н | H | 2C2=0 | | ; | H | L | HHH | ннн | HHL | ннн | H | H | L | H | 3C2=0 | | ; | Н | L | HHH | HHH | HHH | HHL | Н | Н | H | L | 4C2=0 | | ; | H | L | LLH | LLL | LLL | LLL | н | L | L | ī | 1C2=1 | | ; | H | L | LLL | LLH | LLL | LLL | L | H | L | L | 2C2=1 | | ; | Н | L | LLL | LLL | LLH | LLL | L | L | H | Ĺ | 3C2=1 | | ; | | L | LLL | LLL | LLL | LLH | L | L | L | H | 4C2=1 | | ; | | L | ннн | ннн | ннн | ннн | H | H | н | н | TOGGLE LINES | | • | | H | LLL | LLL | LLL | LLL | н | H | н | Н | SELECT = 4 | | • | | H | ннн | ннн | ннн | ннн | H | H | H | H | TOGGLE LINES | | ; | | | | | | | | | | | | #### ; DESCRIPTION ;THIS IS AN EXAMPLE OF A QUAD 3-TO-1 MULTIPLEXER USING A PAL1814. SELECT; LINES A,B ARE ENCODED IN BINARY, WITH A REPRESENTING THE LSB. THE OUTPUTS; (Y) ARE ALL HIGH IF THE SELECT LINES ARE BOTH HIGH (B, A=H). #### OPERATIONS TABLE: | ;<br>;<br>; | INPUT<br>SELECT<br>B A | OUTPUTS | |-------------|--------------------------|---------------------| | | L L<br>L H<br>H L<br>H H | C0<br>C1<br>C2<br>H | Title QUAD 3:1 MULTIPLEXER Pattern P7074 Revision A Author V VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 01/05/82 CHIP QUAD 3:1 MULTIPLEXER PAL14L4 1C0 1C1 1C2 2C0 2C1 2C2 3C0 3C1 3C2 GND 4C0 4C1 4C2 4Y 3Y 2Y 1Y B A VCC # EQUATIONS | /lY | = | /B*/A | * | /1C0 | ;SELECT | INPUT | 100 | |-----|---|-------|---|------|---------|-------|-----| | | | /B* A | | | ;SELECT | INPUT | 101 | | | | B*/A | | | ;SELECT | INPUT | 1C2 | | /2Y | _ | /B*/A | * | /2C0 | ;SELECT | INPUT | 2C0 | | | + | /B* A | * | /2C1 | ;SELECT | INPUT | 2C1 | | | | B*/A | | | ;SELECT | INPUT | 2C2 | | /3¥ | _ | /B*/A | * | /3C0 | ;SELECT | INPUT | 3C0 | | | | /B* A | | | ;SELECT | INPUT | 3C1 | | | | B*/A | | | ;SELECT | INPUT | 3C2 | | /4Y | _ | /B*/A | * | /4C0 | ;SELECT | INPUT | 4C0 | | | | /B* A | | | ;SELECT | INPUT | 4C1 | | | | R*/A | | | :SELECT | TNPUT | 4C2 | ``` Title 4-BIT COUNTER WITH REGISTER Pattern P7075 Revision A Author MIKE VOLPIGNO Company MONOLITHIC MEMORIES INC NEWTON, MASSACHUSETTS Date 11/20/81 CHIP 4-BIT COUNTER WITH REGISTER PAL20X8 CLK DO D1 D2 D3 /RCLR /RLD SEL /CCLR /CLD EP GND /OC RCO C3 C2 C1 C0 R3 R2 R1 R0 ET VCC EQUATIONS /C0 := CCLR ;CLEAR COUNTER + /CLD*/CCLR* EP* ET : COUNT :+: /CLD*/CCLR*/C0 ; COUNT CLD*/CCLR*/RO ;LOAD COUNTER FROM REGISTER /Cl := CCLR ;CLEAR COUNTER + /CLD*/CCLR* EP* ET* CO ; COUNT :+: /CLD*/CCLR*/Cl ; COUNT CLD*/CCLR*/R1 ;LOAD COUNTER FROM REGISTER /C2 := CCLR CLEAR COUNTER + /CLD*/CCLR* EP* ET* CO* C1 ; COUNT :+: /CLD*/CCLR*/C2 ; COUNT CLD*/CCLR*/R2 ;LOAD COUNTEF FROM REGISTER /C3 := CCLR ;CLEAR COUNTER + /CLD*/CCLR* EP* ET* CO* C1* C2 ; COUNT :+: /CLD*/CCLR*/C3 ; COUNT CLD*/CCLR*/R3 ;LOAD COUNTER FROM REGISTER /R0 := RCLR ;CLEAR REGISTER + /RCLR* RLD*/SEL*/D0 ;LOAD REGISTER FROM DATA :+: /RCLR* RLD* SEL*/C0 ;LOAD REGISTER FROM COUNTER + /RCLR*/RLD*/RO ;HOLD /Rl := RCLR CLEAR REGISTER + /RCLR* RLD*/SEL*/D1 ;LOAD REGISTER FROM DATA :+: /RCLR* RLD* SEL*/Cl ;LOAD REGISTER FROM COUNTER + /RCLR*/RLD*/R1 :HOLD /R2 := RCLR ;CLEAR REGISTER + /RCLR* RLD*/SEL*/D2 :+: /RCLR* RLD* SEL*/C2 ;LOAD REGISTER FROM DATA ;LOAD REGISTER FROM COUNTER + /RCLR*/RLD*/R2 ;HOLD /R3 := RCLR ;CLEAR REGISTER + /RCLR* RLD*/SEL*/D3 ;LOAD REGISTER FROM DATA :+: /RCLR* RLD* SEL*/C3 ;LOAD REGISTER FROM COUNTER + /RCLR*/RLD*/R3 ;HOLD IF(VCC) /RCO = ET* CO* C1* C2* C3 TERMINAL COUNT ``` ``` CLK /RCLR /RLD SEL /CCLR /CLD EP ET D3 D2 D1 D0 ;R3 R2 R1 R0 C3 C2 C1 C0 /RCO R / CCRSCC LLLELLEED--DR--RC--CC KRDLRDPT3 03 03 00 COMMENTS ; C L X X X X X X XXXX LLLL XXXX X CLEAR REGISTER LOAD REGISTER HI FROM DATA LOAD COUNTER FROM REGISTER ENABLE RCO AND HOLD COUNT COUNT AND ROLLOVER ; C H L L X X X X HHHH HHHH XXXX X ; C H H X H L X X XXXX HHHH HHHH X C H H X H H L H XXXX HHHH HHHH H ; C H H X H H H H XXXX HHHH LLLL L INCREMENT COUNTER ; C H H X H H H H XXXX HHHH LLLH L ** ; C H H X H H H H XXXX HHHH LLHL L ** ; C H H X H H H H XXXX HHHH LLHH L ** ; C H H X H H H H XXXX HHHH LHLL L ; C H H X H H H H XXXX HHHH LHLH L ; C H H X H H H H XXXX HHHH LHHL L ; C H H X H H H H XXXX HHHH LHHH L ; C H H X H H H H XXXX HHHH HLLL L ; C H H X H H H H XXXX HHHH HLLH L ; C H H X H H H H XXXX HHHH HLHL L ; C H H X H H H H XXXX HHHH HLHH L ; C H H X H H H H XXXX HHHH HHLL L ; C H H X H H H H XXXX HHHH HHLH L ; C H H X H H H H XXXX HHHH HHHL L LOAD REGISTER FROM COUNTER HOLD REGISTER, CLEAR COUNTER ; C H L H H H H L XXXX HHHL HHHL L ; C H H X L X X X XXXX HHHL LLLL L ``` #### ; DESCRIPTION ; FUNCTION TABLE FOR PALASM 1 ;THIS PAL DESIGN SPECIFICATION DESCRIBES A 4-BIT SYNCHRONOUS COUNTER WITH ;4-BIT REGISTER. DATA CAN BE LOADED TO THE COUNTER FROM THE REGISTER. IT ;CAN ALSO BE SYNCHRONOUSLY CLEARED. THE REGISTER CAN BE LOADED FROM EITHER ;THE COUNTER OR THE DATA INPUTS UNDER CONTROL OF THE SEL INPUT. THE REGISTER ;CAN ALSO BE SYNCHRONOUSLY CLEARED. THE COUNTER AND REGISTER HAVE A COMMON ;CLOCK FOR SYNCHRONOUS OPERATION. ``` Title 9-BIT DOWN COUNTER Pattern P7076 Revision A Author BIRKNER/COLI/LEE Company MMI SUNNYVALE, CALIFORNIA Date 01/12/83 CHIP 9-BIT DOWN COUNTER PAL20X10 CLK DO D1 D2 D3 D4 D5 D6 D7 D8 /LD GND /OC /BO Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC EQUATIONS /Q0 := /LD*/Q0 ;HOLD Q0 LD*/D0 + ;LOAD DO (LSB) :+: /LD ; COUNT DOWN /Q1 := /LD*/Q1 ;HOLD Q1 + LD*/D1 ;LOAD D1 :+: /LD*/Q0 ; COUNT DOWN /Q2 := /LD*/Q2 ;HOLD Q2 LD*/D2 ;LOAD D2 :+: /LD*/Q0*/Q1 ; COUNT DOWN /Q3 := /LD*/Q3 ;HOLD Q3 + LD*/D3 ;LOAD D3 :+: /LD*/Q0*/Q1*/Q2 COUNT DOWN /Q4 := /LD*/Q4 ;HOLD Q4 LD*/D4 + ;LOAD D4 :+: /LD*/Q0*/Q1*/Q2*/Q3 COUNT DOWN /Q5 := /LD*/Q5 ;HOLD Q5 ;LOAD D5 LD*/D5 :+: /LD*/Q0*/Q1*/Q2*/Q3*/Q4 COUNT DOWN /Q6 := /LD*/Q6 ;HOLD Q6 ;LOAD D6 LD*/D6 :+: /LD*/Q0*/Q1*/Q2*/Q3*/Q4*/Q5 COUNT DOWN /Q7 := /LD*/Q7 ;HOLD Q7 LD*/D7 ;LOAD D7 :+: /LD*/Q0*/Q1*/Q2*/Q3*/Q4*/Q5*/Q6 ; COUNT DOWN /Q8 := /LD*/Q8 ;HOLD Q8 ; LOAD D8 (MSB) LD*/D8 :+: /LD*/Q0*/Q1*/Q2*/Q3*/Q4*/Q5*/Q6*/Q7 ; COUNT DOWN BO := LD* Q0*/Q1*/Q2*/Q3*/Q4*/Q5*/Q6*/Q7*/Q8 ; CARRY OUT (ANTICIPATE COUNT) ; CARRY OUT (ANTICIPATE LOAD) LD*/D0*/D1*/D2*/D3*/D4*/D5*/D6*/D7*/D8 ``` ;CLK /OC /LD D8 D7 D6 D5 D4 D3 D2 D1 D0 /B0 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | ;;; | | ONTRO<br>/OC | _ | DATA IN<br>DDDDDDDDD<br>876543210 | /B0 | DATA OUT<br>QQQQQQQQQ<br>876543210 | COMMENT | |-----|---|--------------|---|-----------------------------------|-----|------------------------------------|--------------------| | ; | С | L | L | LLLLLLLL | L | LLLLLLLL | LOAD (BORROW) | | ; | C | L | H | XXXXXXXX | H | нннннннн | DECREMENT | | ; | C | L | L | LLLLLLLH | H | LLLLLLLH | LOAD | | ; | C | L | H | XXXXXXXX | L | LLLLLLLL | DECREMENT (BORROW) | | ; | С | L | L | LLLLLLHH | H | LLLLLLHH | LOAD | | ; | С | L | H | XXXXXXXX | H | LLLLLLHL | DECREMENT | | ; | С | L | L | LLLLLHHH | H | LLLLLHHH | LOAD | | ; | С | L | H | XXXXXXXX | H | LLLLLHHL | DECREMENT | | ; | С | L | L | LLLLHHHH | H | LLLLHHHH | LOAD | | ; | C | L | H | XXXXXXXX | H | LLLLLHHHL | DECREMENT | | ; | С | L | L | LLLLHHHHH | H | LLLLHHHHH | LOAD | | ; | C | L | H | XXXXXXXX | H | LLLLHHHHL | DECREMENT | | ; | C | L | L | LLLHHHHHH | H | LLLHHHHHHH | LOAD | | ; | С | L | H | XXXXXXXX | H | LLLHHHHHL | DECREMENT | | ; | С | L | L | LLHHHHHHH | H | LLHHHHHHHH | LOAD | | ; | C | L | H | XXXXXXXX | H | LLHHHHHHL | DECREMENT | | ; | C | L | L | <b>L</b> HHHHHHHH | H | LHHHHHHHH | LOAD | | ; | С | L | H | XXXXXXXX | H | LHHHHHHHL | DECREMENT | | ; | C | L | L | нннннннн | H | нниннинн | LOAD | | ; | С | L | H | XXXXXXXX | H | нниннннг | DECREMENT | | ; | С | L | L | HHHHHHLL | H | HHHHHHLL | LOAD | | ; | С | L | H | XXXXXXXX | H | HHHHHHLHH | DECREMENT | | ; | L | L | H | XXXXXXXX | H | HHHHHHLHH | HOLD | | ; | С | L | H | XXXXXXXX | н | HHHHHHLHL | DECREMENT | | ; | С | L | H | XXXXXXXX | H | HHHHHLLH | DECREMENT | | ; | С | L | H | XXXXXXXX | H | HHHHHLLL | DECREMENT | | ; | Х | н | Х | XXXXXXXX | Z | ZZZZZZZZZ | TEST HI-Z | #### ; DESCRIPTION ;THE 9-BIT SYNCHRONOUS COUNTER HAS PARALLEL LOAD, DECREMENT, AND HOLD ;CAPABILITIES. DATA (D8-D0) IS LOADED INTO THE OUTPUT REGISTER (Q8-Q0) WHEN THE ;LOAD INPUT IS TRUE (/LD=L) AND A POSITIVE EDGE PULSE IS RECEIVED ON THE CLOCK;PIN (CLK). THE COUNTER WILL DECREMENT IF A CLOCK PULSE IS RECEIVED WITH THE ;LOAD INPUT BEING FALSE (/LD=H). THE OPERATION IS A HOLD IF NO CLOCK PULSE IS ;RECEIVED REGARDLESS OF ANY OTHER INPUTS. ;THE BORROW OUT PIN (/BO) SHOWS HOW TO IMPLEMENT A BORROW OUT USING A REGISTER ;BY ANTICIPATED ONE COUNT BEFORE THE TERMINAL COUNT IF COUNTING AND THE TERMINAL ;COUNT IF LOADING. #### ; OPERATIONS TABLE: | : | /oc c | LK /LD | D8-D0 | Q8-Q0 | OPERATION | |-----|-------|--------|-------|---------|-------------| | • • | <br>Н | х х | Х | Z | HI-Z | | | L | L X | X | /Q | HOLD | | | L | C L | D | D | LOAD | | į | L | С Н | Х | Q MINUS | 1 DECREMENT | ## **Refresh Clock Generator** Title REFRESH CLOCK GENERATOR Pattern P7077 Revision A Author FRANK LEE Company MMI SUNNYVALE, CALIFORNIA Date 08/03/82 ## CHIP REFRESH CLOCK GENERATOR PAL20X10 CLK /LD F3 F2 F1 F0 M3 M2 M1 M0 /HOLD GND /OC RFCK Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 /INIT VCC ## **EQUATIONS** | INIT | :=<br>+ | /Q7*/Q6*/Q5*/Q4*/Q3*/Q2*/Q1*/Q0<br>LD | ;END OF COUNT ;LOAD | |-------|---------------------|------------------------------------------------------------------|--------------------------------------------------------------------| | /Q0 | | /INIT*/Q0<br>/INIT*/HOLD | ; DECREMENT<br>; HOLD | | /Q1 | | /INIT*/Ql<br>/INIT*/HOLD*/Q0 | ; DECREMENT<br>; HOLD | | /Q2 | | INIT<br>/INIT*/Q2<br>/INIT*/HOLD*/Q0*/Q1 | ;LOAD IN 0<br>;DECREMENT<br>;HOLD | | /Q3 | | /INIT*/Q3<br>/INIT*/HOLD*/Q0*/Q1*/Q2 | ;DECREMENT<br>;HOLD | | /Q4 | :=<br>+<br>:+: | | ;LOAD IN FO<br>;DECREMENT<br>;HOLD | | /Q5 | | INIT*/F1<br>/INIT*/Q5<br>/INIT*/HOLD*/Q0*/Q1*/Q2*/Q3*/Q4 | ;LOAD IN F1<br>;DECREMENT<br>;HOLD | | /Q6 | :=<br>+<br>:+: | INIT*/F2<br>/INIT*/Q6<br>/INIT*/HOLD*/Q0*/Q1*/Q2*/Q3*/Q4*/Q5 | ;LOAD IN F2<br>;DECREMENT<br>;HOLD | | /Q7 | :=<br>+<br>:+: | INIT*/F3<br>/INIT*/Q7<br>/INIT*/HOLD*/Q0*/Q1*/Q2*/Q3*/Q4*/Q5*/Q6 | ;LOAD IN F3<br>;DECREMENT<br>;HOLD | | /RFCK | :=<br>+<br>:+:<br>+ | | ;32 LOW STATES<br>;16 LOW STATES<br>;8 LOW STATES<br>;4 LOW STATES | # ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC /LD /HOLD F3 F2 F1 F0 M3 M2 M1 M0 /INIT Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 RFCK Ή Ī R ; C / / O N ;LOLLFFFF MMMM I QQQQQQQQ C ; K C D D 3210 3210 T 76543210 K COMMEMTS READY TO LOAD COUNTER READY TO LOAD COUNTER COUNTER LOADED, READY TO COUNT DOWN C L L X LLHH LLHH L XXXXXXXX X CLLH LLHH LLHH L LLHHHLHH X C L L H LLHH LLHH H LLHHLHH A COUNTER LOADED, READY TO COUNT DOWN C L H H LLHH LLHH H LLHHHLHH H COUNT DOWN C L H H LLHH LLHH H LLHHHLHLH H COUNT DOWN C L H H LLHH LHHL L LLHHHLLH H READY TO LOAD COUNTER, COUNT DOWN C L H H LLHL LHHL H LLHHLHH H COUNT DOWN C L H H LLLH LHHL H LLHHLHH H COUNT DOWN C L H H LLLH LHHL H LLLHHLHH L COUNT DOWN C L H H LLLH LHHL H LLLHHLHH L COUNT DOWN C L H H LLLH LHHL H LLLHHLHH L COUNT DOWN C L H H LLLH LHHL H LLLHHLHH L COUNT DOWN C L H H LLLL LHHL H LLLHHHHH L COUNT DOWN C L H H LLLL LHHL H LLLLHHHH L COUNT DOWN C L H H LLLL LHHL H LLLLHHLH L COUNT DOWN C L H H LLLL LHHL H LLLLHHLH L COUNT DOWN C L H H LLLL LHHL H LLLLHHLH L COUNT DOWN C L H H LLLL LHHL H LLLLHHLH L COUNT DOWN C L H H LLLL LHHL H LLLLHHLH H COUNT DOWN C L H H LLLL LHHL H LLLLHHLH H COUNT DOWN C L H H LLLL LHHL H LLLLHHLH H COUNT DOWN, RFCK HIGH C L H H LLLL LHHL H LLLLLHHL H COUNT DOWN, RFCK HIGH C L H H LLLL LHHL H LLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLLHLH H COUNT DOWN C L H H LLLL LHHL H LLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLHL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLLH H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLLL H COUNT DOWN C L H H LLLL LHHL H LLLLLLL H COUNT DOWN C L H H LLHH LLHH H LLHHHLHH H C L H H LLLL LHHL H LLLLLLL H COUNT DOWN C L H H LLLL LHHL L HHHHHHHH H COUNT DOWN, READY TO LOAD COUNTER C H X X XXXX XXXX Z ZZZZZZZZ Z HIGH IMPEDANCE TEST TR00640M # **Refresh Clock Generator** #### ; DESCRIPTION ;THE REFRESH CLOCK GENERATOR CAN GENERATE REFRESH CLOCK (RFCK) FOR THE DYNAMIC ;RAM CONTROLLERS. THE PERIOD OF RFCK DEPENDS ON F3-F0 WHILE THE DURATION OF ;RFCK BEING LOW DEPENDS ON M3-M0. | ; | FFFF<br>3210 | RFCK PERIOD<br>(CYCLES) | MMMM<br>3210 | RFCK LOW DURATION (CYCLES) | |----------|--------------|-------------------------|--------------|----------------------------| | ;<br>; | 0000 | 12 | 0000 | 0 | | ; | 0001 | 28 | 0001 | | | ; | 0010 | 44 | 0010 | 8 | | ; | 0011 | 60 | 0011 | 12 | | ; | 0100 | 76 | 0100 | 16 | | <b>;</b> | 0101 | 92 | 0101 | 20* | | • | 0110 | 108 | 0110 | 24 | | • | 0111 | 124 | 0111 | 28 | | | 1000 | 140 | 1000 | 32 | | • | 1001 | 156 | 1001 | 36* | | ; | 1010 | 172 | 1010 | 40* | | ; | 1011 | 188 | 1011 | 44* | | • | 1100 | 204 | 1100 | 48 | | | 1101 | 220 | 1101 | 52* | | | 1110 | 236 | 1110 | 56 | | , | 1111 | 252 | iiii | 60 | ;\*NOT ALLOWED DUE TO BAD WAVEFORMS ``` Title OCTAL ADDRESSABLE REGISTER Pattern P7078 Revision A Author DANESH TAVANA Company MMI SUNNYVALE, CALIFORNIA Date 02/02/82 CHIP OCTAL ADDRESSABLE REGISTER PAL16R8 CLK /CLR /PR A B C E1 /E2 DIN GND /OC Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC EQUATIONS = CLR + /PR* E1* E2*/DIN*/C*/B*/A + /PR* E1* E2*/Q0 * A + /PR* E1* E2*/Q0 * B - /DP* E1* E2*/Q0 * C /00 := CLR ;CLEAR (LSB) ;DATA IN ADDRESS 0 ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=L) + /PR* E1*/E2*/Q0 + /PR*/E1*/E2*/Q0 + /PR*/E1* E2*/Q0 /Q1 := CLR ;CLEAR + /PR* E1* E2*/DIN*/C*/B* A ; DATA IN ADDRESS 1 + /PR* E1* E2*/Q1 * /A + /PR* E1* E2*/Q1 * B ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES + /PR* E1* E2*/Q1 * C ;LOAD PREVIOUS STATES ;HOLD IF NOT LOADING (E1-L,/E2-H);HOLD IF NOT LOADING (E1-L,/E2-L) + /PR* E1*/E2*/Q1 + /PR*/E1*/E2*/Q1 + /PR*/E1* E2*/Q1 ;CLEAR /Q2 := CLR + /PR* E1* E2*/DIN*/C* B*/A + /PR* E1* E2*/Q2 * A + /PR* E1* E2*/Q2 * /B ;DATA IN ADDRESS 2 ;LOAD PREVIOUS STATES + /PR* E1* E2*/Q2 * /B + /PR* E1* E2*/Q2 * C ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES + /PR* E1*/E2*/Q2 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q2 ;HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1* E2*/Q2 /Q3 := CLR ; CLEAR + /PR* E1* E2*/DIN*/C* B* A + /PR* E1* E2*/Q3 * /A + /PR* E1* E2*/Q3 * /B + /PR* E1* E2*/Q3 * C ;DATA IN ADDRESS 3 ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES + /PR* E1*/E2*/Q3 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q3 ;HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1* E2*/Q3 /Q4 := CLR ; CLEAR + /PR* E1* E2*/DIN* C*/B*/A ; DATA IN ADDRESS 4 + /PR* E1* E2*/Q4 * A + /PR* E1* E2*/Q4 * B ;LOAD PREVIOUS STATES ;LOAD PREVIOUS STATES + /PR* E1* E2*/Q4 */C + /PR* E1*/E2*/Q4 + /PR*/E1*/E2*/Q4 ;LOAD PREVIOUS STATES ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1*/E2*/Q4 + /PR*/E1* E2*/Q4 ``` ``` /Q5 := CLR ;CLEAR ; CLEAR + /PR* E1* E2*/DIN* C*/B* A + /PR* E1* E2*/QS * /A + /PR* E1* E2*/Q5 * B + /PR* E1* E2*/Q5 */C + /PR* E1* E2*/Q5 */C + /PR* E1*/E2*/Q5 + /PR*/E1*/E2*/Q5 ; CLEAR ; CLEAR ; DATA IN ADDRESS 5 ; LOAD PREVIOUS STATES ; HOLD IF NOT LOADING ;HOLD IF NOT LOADING (E1=H,/E2=H);HOLD IF NOT LOADING (E1=L,/E2=H);HOLD IF NOT LOADING (E1=L,/E2=L) /Q6 := CLR ;CLEAR ;HOLD IF NOT LOADING (E1=H,/E2=H);HOLD IF NOT LOADING (E1=L,/E2=H);HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1* E2*/Q6 /07 := CLR ; CLEAR (MSB) - CLR + /PR* E1* E2*/DIN* C* B* A + /PR* E1* E2*/Q7 * /A + /PR* E1* E2*/Q7 * /B + /PR* E1* E2*/Q7 */C + /PR* E1* E2*/Q7 */C + /PR* E1*/E2*/Q7 + /PR* E1*/E2*/Q7 + /PR* E1*/E2*/Q7 + /PR*/E1*/E2*/Q7 + /PR*/E1*/E2*/Q7 + /PR*/E1*/E2*/Q7 + /PR* E1*/E2*/Q7 + /PR*/E1*/E2*/Q7 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H);HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1* E2*/Q7 ; FUNCTION TABLE FOR PALASM 1 ;/OC CLK /CLR /PR /E2 E1 C B A DIN Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 ; CONTROL FUNCTIONS INPUTS OUTPUTS ;/OC CLK /CLR /PR /E2 E1 C B A DIN Q Q Q Q Q Q Q 7 6 5 4 3 2 1 0 COMMENTS _______ ``` #### ; DESCRIPTION ;THE 8-BIT ADDRESSABLE REGISTER LOADS THE DATA (DIN) INTO THE APPROPRIATE ;ADDRESS LINE REGISTER (Q) ON THE RISING EDGE OF THE CLOCK (CLK). ;THE INPUT ADDRESSING PINS (C,B,A) CHANNEL THE DATA (DIN) INTO ITS CORRESPONDING ;OUTPUT REGISTER (Q) WHEN THE ENABLE PINS (/E2,E1) ARE (LOW,HIGH) RESPECTIVELY; ;ANY OTHER COMBINATION OF INPUTS FOR THE ENABLE PINS HOLDS THE PREVIOUS STATE OF ;THE REGISTERS (Q). ; CLEAR OVERRIDES PRESET, PRESET OVERRIDES LOAD ENABLE. ;THESE FUNCTIONS ARE EXERCISED IN THE FUNCTION TABLE AND SUMMARIZED IN THE ;OPERATIONS TABLE: | ; | /oc | CLK | /CLR | /PR | El | /E2 | СВА | DIN | Q7-Q0 | OPERATION | |---|--------|-----|------|-----|-------|-----|-----|-----|-------|-----------| | ; | Н | x | x | х | <br>х | х | x | х | z | HI-Z | | ; | 10 L 1 | С | L | X | X | X | X | X | L | CLEAR | | ; | L | С | H | L | X | X | x | X | H | PRESET | | ; | L | С | H | H | Н | L | CBA | D | D | ENABLE | | ; | L | С | | H | | H | X | X | Q | HOLD | | ; | L | С | H | H | L | H | X | X | Q | HOLD | | ; | L | С | Н | | L | L | х | Х | Q | HOLD | ``` Title OCTAL ADDRESSABLE REGISTER WITH DEMULTIPLEXER/ENABLES Pattern P7079 Revision A DANESH TAVANA Company MMI SUNNYVALE, CALIFORNIA Date 02/08/82 CHIP OCTAL ADDRESSABLE REGISTER WITH DEMULTIPLEXER/ENABLES PAL16R8 CLK MODE /PR A B C E1 /E2 DIN GND /OC Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC EOUATIONS /Q0 := /PR* E1* E2*/DIN*/C*/B*/A* MODE /Q1 := PR* E1* E2*/DIN*/C*/B* A* MODE ; LOAD /Q1 WITH /DIN (MODE=H) + /PR* E1* E2* /C*/B* A*/MODE ;LOAD /Q1 WITH HIGH (MODE=L) + /PR* E1* E2*/Q1 * /A* MODE ;/Q1 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q1 * B * MODE ;/Q1 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q1 * C * MODE ;/Q1 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q1 * C * MODE ;/Q1 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q1 ;HOLD IF NOT LOADING (E1=H,/E2=H) + /PR*/E1*/E2*/Q1 ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1* E2*/Q1 ;HOLD IF NOT LOADING (E1=L./E2=L) /Q2 := /PR* E1* E2*/DIN*/C* B*/A* MODE ;LOAD /Q2 WITH /DIN (MODE=H) + /PR* E1* E2*/Q2 * /B * MODE ;/Q2 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q2 * C * MODE ;/Q2 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q2 ;HOLD IF NOT LOADING (E1=H,/E2=H) + /PR*/E1*/E2*/Q2 ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1* E2*/Q2 ;HOLD IF NOT LOADING (E1=L,/E2=L) /Q3 := /PR* E1* E2*/DIN*/C* B* A* MODE ;LOAD /Q3 WITH /DIN (MODE=H) + /PR* E1* E2* /C* B* A*/MODE ;LOAD /Q3 WITH HIGH (MODE=L) + /PR* E1* E2* /C* B* A*/MODE + /PR* E1* E2*/Q3 * /A* MODE + /PR* E1* E2*/Q3 * /B * MODE + /PR* E1* E2*/Q3 * C * MODE ;/Q3 IS EITHER PREVIOUS STATE OR LOW ;/Q3 IS EITHER PREVIOUS STATE OR LOW ;/Q3 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q3 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q3 + /PR*/E1* E2*/Q3 ;HOLD IF NOT LOADING (E1=L,/E2=L) /Q4 := /PR* E1* E2*/DIN* C*/B*/A* MODE ;LOAD /Q4 WITH /DIN (MODE=H) + /PR* E1* E2* C*/B*/A*/MODE ;LOAD /Q4 WITH HIGH (MODE=L) + /PR* E1* E2*/Q4 * A* MODE + /PR* E1* E2*/Q4 * B * MODE + /PR* E1* E2*/Q4 */C * MODE + /PR* E1*/E2*/Q4 + /PR*/E1*/E2*/Q4 ;/Q4 IS EITHER PREVIOUS STATE OR LOW ;/Q4 IS EITHER PREVIOUS STATE OR LOW ;/Q4 IS EITHER PREVIOUS STATE OR LOW ;HOLD IF NOT LOADING (E1=H,/E2=H) + /PR*/E1* E2*/Q4 ;HOLD IF NOT LOADING (E1=L,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=L) ``` ``` /Q5 := /PR* E1* E2*/DIN* C*/B* A* MODE ;LOAD /Q5 WITH /DIN (MODE=H) + /PR* E1* E2* C*/B* A*/MODE ;LOAD /Q5 WITH HIGH (MODE=L) /A* MODE B * MODE + /PR* E1* E2*/Q5 * ;/Q5 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q5 * ;/Q5 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q5 */C * MODE ;/Q5 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q5 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q5 + /PR*/E1* E2*/Q5 ;HOLD IF NOT LOADING (E1=L,/E2=L) /Q6 := /PR* E1* E2*/DIN* C* B*/A* MODE ;LOAD /Q6 WITH /DIN (MODE=H) + /PR* E1* E2* C* B*/A*/MODE ;LOAD /Q6 WITH HIGH (MODE=L) + /PR* E1* E2*/Q6 * + /PR* E1* E2*/Q6 * /B A* MODE ;/Q6 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q6 * /B + /PR* E1* E2*/Q6 */C + /PR* E1*/P2*/C7 * MODE ;/Q6 IS EITHER PREVIOUS STATE OR LOW ;/Q6 IS EITHER PREVIOUS STATE OR LOW * MODE + /PR* E1*/E2*/Q6 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q6 ;HOLD IF NOT LOADING (E1=L,/E2=L) + /PR*/E1* E2*/Q6 /Q7 := /PR* E1* E2*/DIN* C* B* A* MODE ;LOAD /Q7 WITH /DIN (MODE=H) ;LOAD /Q7 WITH HIGH (MODE=L) + /PR* E1* E2* C* B* A*/MODE + /PR* E1* E2*/Q7 * /A* MODE ;/Q7 IS EITHER PREVIOUS STATE OR LOW + /PR* E1* E2*/Q7 * /B * MODE + /PR* E1* E2*/Q7 */C * MODE ;/Q7 IS EITHER PREVIOUS STATE OR LOW ;/Q7 IS EITHER PREVIOUS STATE OR LOW + /PR* E1*/E2*/Q7 ;HOLD IF NOT LOADING (E1=H,/E2=H) ;HOLD IF NOT LOADING (E1=L,/E2=H) + /PR*/E1*/E2*/Q7 + /PR*/E1* E2*/Q7 ;HOLD IF NOT LOADING (E1=L,/E2=L) ``` B00700M # Octal Addressable Register With Demux/Enables #### ; FUNCTION TABLE ;/OC CLK MODE /PR /E2 E1 C B A DIN Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 ; CONTROL FUNCTIONS INPUTS OUTPUTS ;/OC CLK MODE /PR /E2 E1 C B A DIN Q Q Q Q Q Q Q 7 6 5 4 3 2 1 0 COMMENTS $\mathbf{X} \cdot \mathbf{X} \cdot \mathbf{X} \cdot \mathbf{X}$ ; L C X Τ. X X ннннннн PRESET (OVERRD ENABLES) L H LLL L ; L С Η Н HHHHHHL LOAD QO WITH DIN ; L LLHL С H Η ннннньг LOAD Q1 WITH DIN L H L L ; L С Н Н L H LOAD Q2 WITH DIN HHHHLLL С L H ; L H H HHHHLLLL LOAD Q3 WITH DIN C L H HLL ; L H H L HHHLLLLL LOAD Q4 WITH DIN C L H HLH L ; L H Н HHLLLLLL LOAD Q5 WITH DIN ; L C H Н L H HHL L HLLLLLLL LOAD Q6 WITH DIN C H HHH L ; L H L H LLLLLLLL LOAD Q7 WITH DIN ; L C нин н LOAD Q7 WITH DIN Н H L H HLLLLLLL H ; L С H L H HHLH HHLLLLLL LOAD Q6 WITH DIN ; L C H H L H H L H H HHHLLLLL LOAD Q5 WITH DIN C ; L H L H H H L L H HHHLLLL LOAD Q4 WITH DIN C H H L ; L H L H H H HHHHLLL LOAD O3 WITH DIN C H L ; L H H LHL H HHHHHLL LOAD Q2 WITH DIN ; L C Н H L H LLH H ннннннь LOAD Q1 WITH DIN ; L C Н H L H LLL H HHHHHHH LOAD QO WITH DIN H LLL X ннннннь DECODE ADDRESS LINE 0 ; L C L L H X L C L Η L H LLH HHHHHLH DECODE ADDRESS LINE 1 x L C L LHL L H Н ннннньн DECODE ADDRESS LINE 2 С L L H L LHH X Η HHHHLHHH DECODE ADDRESS LINE 3 L С L H L Н HLL Х HHHLHHHH DECODE ADDRESS LINE L С L Н L H HLH Х HHLHHHHH DECODE ADDRESS LINE L C HHL Х L Н L H HLHHHHHH DECODE ADDRESS LINE нин х L C ; L H L Н LHHHHHHH DECODE ADDRESS LINE L С H X X X X; Х L L LHHHHHHH HOLD PREVIOUS STATE ; L C H L HLH L н Н LHLHHHHH LOAD O5 WITH DIN ; L C H L X X X XХ Н LHLHHHHH HOLD PREVIOUS STATE С L H H L ; L H L LHLHLHHH Н H LOAD Q3 WITH DIN C X X X X; L X. н н н LHLHLHHH HOLD PREVIOUS STATE ; L C LLHX L Н L H HHHHHLH DECODE ADDRESS LINE 1 X X X X Z Z Z Z Z Z Z Z HI-Z х х TB00710M #### ; DESCRIPTION ;THE 8-BIT ADDRESSABLE REGISTER AND DEMULTIPLEXER PERFORMS TWO FUNCTIONS ON ONE ;MSI PACKAGE. IF MODE=0 THE PART PERFORMS A 3 TO 8 DE-MULTIPLEXER FUNCTION WITH ;PRESET, LOAD, AND HOLD; IF MODE=1 IT IS AN 8-BIT ADRESSABLE REGISTER WITH ;PRESET, LOAD, AND HOLD. ; WHEN THE CONTROL PINS (/E2,E1) ARE (LOW,HIGH) THE UNIT IS ENABLED AND THE INPUT; ADDRESS PINS (C,B,A) EITHER CHANNEL THE INPUT DATA (DIN) TO ITS APPROPRIATE; OUTPUT REGISTER (Q) WITH MODE=1, OR SELECT THE ADDRESSED OUTPUT REGISTER (Q); WITH MODE=0. ANY OTHER COMBINATION FOR THE INPUT CONTROL PINS HOLDS THE; PREVIOUS STATE OF THE OUTPUTS. ; PRESET OVERRIDES ENABLE. ; THESE FUNCTIONS ARE EXERCISED IN THE FUNCTION TABLE AND SUMMARIZED IN THE ; OPERATIONS TABLE: | S. N. B. | /oc | CLK | MODE | /PR | /E2 | El | С | В | A | DIN | Q7-Q0 | OPERATION | | |-----------------------------------------|-----|-----|------|-----|-----|----|---|---|---|-----|-------|-----------|------------| | | Н | x | х | x | X | х | x | x | x | х | z | HI-Z | | | ; | L | С | X | L | X | X | X | X | Х | X | H | PRESET | | | ; | L | C | L | H | L | H | С | В | Α | X | MUX | ADDRESSED | OUTPUT=LOW | | ; | L | C | H | H | L | H | C | В | Α | D | REG | ADDRESSED | OUTPUT=D | | ; | L | C | X | H | H | L | X | X | X | X | Q | HOLD | | | ; | L | C | X | H | L | L | X | X | X | X | Q | HOLD | | | ; | L | C | X | H | H | H | X | X | X | X | Q | HOLD | | | • ` ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' | | | | | | | | | | | | | | ``` Title OCTAL ADDRESSABLE REGISTER WITH DEMULTIPLEXER/CLEAR Pattern P7080 (PMSI002) Revision A DANESH TAVANA Company MMI SUNNYVALE, CALIFORNIA Date 04/27/82 CHIP OCTAL ADDRESSABLE REGISTER WITH DEMULTIPLEXER/CLEAR PAL16R8 EQUATIONS CLK /CLR /PR A B C MODE /E DIN GND /OC Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC + /PK* E*/MODE*/C*/B*/A ;DEMULTIPLEX OUTPUT /Q0=H + /PR* E* MODE*/C*/B*/A*/DIN ;REGISTER OUTPUT /Q0=/DIN + /PR* E* MODE* A*/Q0 ;LOAD PREVIOUS STATE (/Q0) OR A LOW + /PR* E* MODE* B */Q0 ;LOAD PREVIOUS STATE (/Q0) OR A LOW + /PR* E* MODE* C */Q0 ;LOAD PREVIOUS STATE (/Q0) OR A LOW + /PR*/E */Q0 ;HOLD IF NOT LOADING (/F=H) /00 := CLR ;CLEAR (LSB) /Q1 := CLR ;CLEAR /Q2 := CLR ; CLEAR + /PR* E*/MODE*/C* B*/A + /PR* E*/MODE*/C* B*/A ; DEMULTIPLEX OUTPUT /Q2=H + /PR* E* MODE*/C* B*/A*/DIN ; REGISTER OUTPUT /Q2=/DIN + /PR* E* MODE* A*/Q2 ; LOAD PREVIOUS STATE (/Q2) OR A LOW + /PR* E* MODE* /B */Q2 ; LOAD PREVIOUS STATE (/Q2) OR A LOW + /PR* E* MODE* C */Q2 ; LOAD PREVIOUS STATE (/Q2) OR A LOW + /PR*/E */Q2 ; HOLD IF NOT LOADING (/E=H) ;DEMULTIPLEX OUTPUT /Q2=H /03 := CLR ;CLEAR + /PR* E*/MODE*/C* B* A ; DEMULTIPLEX OUTPUT /Q3=H /Q4 := CLR ;CLEAR ``` # Octal Addressable Register With Demux/Clear ``` /Q5 := CLR ;CLEAR + /PR* E*/MODE* C*/B* A ; DEMULTIPLEX OUTPUT /Q5=H + /PR* E* MODE* C*/B* A*/DIN REGISTER OUTPUT /Q5=/DIN + /PR* E* MODE* /A*/Q5 ;LOAD PREVIOUS STATE (/Q5) OR A LOW + /PR* E* MODE* */Q5 ;LOAD PREVIOUS STATE (/Q5) OR A LOW ;LOAD PREVIOUS STATE (/Q5) OR A LOW */Q5 + /PR* E* MODE*/C ;HOLD IF NOT LOADING (/E=H) + /PR*/E */Q5 /Q6 := CLR ;CLEAR + /PR* E*/MODE* C* B*/A ;REGISTER OUTPUT /Q5=/DIN ;LOAD PREVIOUS STATE ;DEMULTIPLEX OUTPUT /Q6=H + /PR* E* MODE* C* B*/A*/DIN + /PR* E* MODE* A*/Q6 ;LOAD PREVIOUS STATE (/Q6) OR A LOW + /PR* E* MODE* */Q6 ;LOAD PREVIOUS STATE (/Q6) OR A LOW + /PR* E* MODE*/C */Q6 ;LOAD PREVIOUS STATE (/Q6) OR A LOW ;HOLD IF NOT LOADING (/E=H) + /PR*/E */06 /Q7 := CLR ;CLEAR (MSB) ;CLEAR (MSB) ;DEMULTIPLEX OUTPUT /Q7=H + /PR* E*/MODE* C* B* A + /PR* E*/MODE* C* B* A + /PR* E* MODE* C* B* A*/DIN ;REGISTER OUTPUT /Q7=/DIN + /PR* E* MODE* /A*/Q7 ;LOAD PREVIOUS STATE (/Q7) ;LOAD PREVIOUS STATE (/Q7) OR A LOW ;LOAD PREVIOUS STATE (/Q7) OR A LOW ;LOAD PREVIOUS STATE (/Q7) OR A LOW + /PR* E* MODE* /B */Q7 */Q7 + /PR* E* MODE*/C HOLD IF NOT LOADING (/E=H) + /PR*/E */Q7 ; FUNCTION TABLE FOR PALASM 1 ;/OC CLK /CLR /PR /E MODE C B A DIN Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 ----OUTPUTS---- ; CONTROL ---FUNCTIONS---- -INPUTS-- 00000000 ;/OC CLK /CLR /PR /E MODE C B A DIN 7 6 5 4 3 2 1 0 COMMENTS ; L \mathbf{x} \ \mathbf{x} \ \mathbf{x} \ \mathbf{x} LLLLLLLL CLEAR (OVERRD /PR) C L T. X X X X x x x PRESET (OVERRD ENABLES) C ннннннн ; L Н L X H LLL C Н H L HHHHHHL LOAD QO WITH DIN С Η H L H LLH L HHHHHLL LOAD Q1 WITH DIN L H C LHL L HHHHLLL LOAD Q2 WITH DIN ; L H H С L H LHH L HHHHLLLL ; L H H LOAD Q3 WITH DIN L H C H L L LOAD Q4 WITH DIN HHHLLLLL ; L H H L HHLLLLLL C L H Н H HLH L LOAD Q5 WITH DIN ; L C L H HHL L HLLLLLL LOAD Q6 WITH DIN H H ; L C H H L H H H H L LLLLLLLL LOAD Q7 WITH DIN ; L С L H ннн H HLLLLLLL LOAD Q7 WITH DIN ; L H Н C L H HHL H HHLLLLLL LOAD Q6 WITH DIN ; L H H С L H HLH H HHHLLLLL LOAD O5 WITH DIN H H ; L ; L C LOAD 04 WITH DIN Н H L H HLL H HHHLLLL ; L C H H L H LHH H HHHHLLL LOAD Q3 WITH DIN ; L C H H L H LHL H HHHHHLL LOAD O2 WITH DIN C LLH ннннннь LOAD Q1 WITH DIN ; L H H L H H ; L C H H L H LLL н ннннннн LOAD OO WITH DIN С LLL x HHHHHHL DECODE ADDRESS LINE 0 ; L Н H L ; L C L L LLH DECODE ADDRESS LINE 1 H H H DECODE ADDRESS LINE 2 ; L C H L L LHL X HHHHHLHH C H H L L LHH х ннннгнн DECODE ADDRESS LINE 3 ; L DECODE ADDRESS LINE 4 C L L X HHHLHHHH ; L H H HLL DECODE ADDRESS LINE 5 C H H L L HLH X HHLHHHH ; L ; L C H H LL HHL X HLHHHHH DECODE ADDRESS LINE 6 х гнннннн DECODE ADDRESS LINE 7 C H ннн ; L H L L HOLD PREVIOUS STATE H X X LHHHHHHH ; L C Н H X X X x \times x \times x Z Z Z Z Z Z Z Z TEST HI-Z ; H X Х X X X ``` # Octal Addressable Register With Demux/Clear #### ; DESCRIPTION ;THE OCTAL ADDRESSABLE REGISTER AND DEMULTIPLEXER PERFORMS ONE OF TWO MSI ;FUNCTIONS DEPENDING ON THE STATE OF THE MODE SELECT PIN. IF MODE=HIGH THEN THE ;PART PERFORMS THE FUNCTION OF AN ADDRESSABLE REGISTER WITH 8 OUTPUTS (Q7-Q0);AND ONE DATA INPUT (DIN). THE REGISTERED OUTPUT IS SELECTED BY THREE INPUT;ADDRESS PINS (A,B,C). WITH MODE=LOW CONVERTS THIS CHIP INTO AN ACTIVE LOW;3-TO-8 DEMULTIPLEXER, WHERE THE ADDRESSED OUTPUT IS LOW AND ALL OTHER OUTPUTS;REMAIN HIGH. CLEAR (/CLR) AND PRESET (/PR) ARE ACTIVE LOW OUTPUTS WHICH SET;ALL OUTPUTS TO LOW OR HIGH RESPECTIVELY. WHEN ENABLE (/E) IS HIGH, THE CHIP IS;DISABLED AND THE OUTPUTS RETAIN THEIR PREVIOUS STATES. ; CLEAR OVERRIDES PRESET AND ENABLE, PRESET OVERRIDES ENABLE. ;THESE FUNCTIONS ARE EXERCISED IN THE FUNCTION TABLE AND SUMMARIZED IN THE ;OPERATIONS TABLE: | ; | /00 | C | CLK | / | 'CLR | /PR | /E | MODE | c | В | Α | DIN | Q7-Q0 | OPERATION | |---|-------------|---|-------------|---|-------------|-------------|--------|------------------|---|---|------------------|--------------------|----------------------|-----------------------------------------------------------------------| | • | H | | X | | X | X<br>X | | X<br>X | | X | x<br>x | X<br>X | Z<br>L | HI-Z<br>CLEAR | | 1 | L<br>L<br>L | | с<br>с<br>с | | H<br>H<br>H | L<br>H<br>H | L<br>L | X<br>L<br>H<br>X | C | В | X<br>A<br>A<br>X | X<br>X<br>DIN<br>X | H<br>MUX<br>REG<br>Q | PRESET ADDRESSED OUTPUT=LOW ADDRESSED OUTPUT=DIN HOLD PREVIOUS STATES | | C | В | A | DIN | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Ql | Q0 | |---|---|---|-----|-----|-----|-----|-----|-----|-----|-----|----| | | | | | | | | | | | | | | | | L | DIN | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | | | | L | | DIN | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | DIN | - | | | | L | DIN | Q7 | Q6' | Q5 | Q4 | Q3 | DIN | Q1 | Q0 | | L | H | H | DIN | Q7 | Q6 | Q5 | Q4 | DIN | Q2 | Q1 | Q0 | | H | L | L | DIN | Q7 | Q6 | Q5 | DIN | Q3 | Q2 | Q1 | Q0 | | H | L | H | DIN | Q7 | Q6 | DIN | Q4 | Q3 | Q2 | Ql | Q0 | | H | Н | L | DIN | Q7 | DIN | Q5 | Q4 | Q3 | Q2 | Q1 | QO | | H | H | H | DIN | DIN | 06 | 05 | Q4 | Q3 | Q2 | 01 | 00 | # **Rounding - Control Logic** ``` EQUATIONS COM = D12*D11 D11* D10 * D08 * D07 * D06 * D05 * D04 * D03 *D09 + D11 Dll D11 D11 Dll D11 D11 * D02 D11 * D01 D11 * D00 D11 ``` # ; FUNCTION TABLE Title Author Date Pattern P7081 Revision A ROUNDING-CONTROL LOGIC VINCENT COLI 03/18/82 Company MMI SUNNYVALE, CALIFORNIA CHIP ROUNDING-CONTROL LOGIC PAL16C1 D00 D01 D02 D03 D04 D05 D06 D07 D08 GND D09 D10 D11 D12 TRU COM NC NC NC VCC ``` ;D12 D11 D10 D09 D08 D07 D06 D05 D04 D03 D02 D01 D00 COM TRU; ; COM RESULTS HAVE BEEN REMOVED FROM SIMULATION RESULTS; ;D D D D D D D D D D D D ROUND-CONTROL;12 11 10 ``` ``` Title 4-BIT COUNTER WITH TERMINAL COUNT LOCK Pattern P7082 Revision A Author COLI/VOLDAN Company MMI SUNNYVALE, CALIFORNIA Date 04/05/82 CHIP 4-BIT_COUNTER WITH TERMINAL COUNT LOCK PAL16R6 CLK NC NC DO D1 D2 D3 CLEAR /LOAD GND /OC NC /EP Q3 Q2 Q1 Q0 NC NC VCC EQUATIONS /Q0 := CLEAR ;CLEAR Q0 (LSB) + LOAD*/DO ;LOAD DO ;HOLD IF NO EP + /LOAD*/Q0*/EP + /LOAD* EP* QO ; COUNT IF EP AND Q0=H /Q1 := CLEAR ;CLEAR Q1 + LOAD*/D1 ; LOAD D1 + /LOAD*/Q1*/EP ;HOLD IF NO EP + /LOAD*/Q1*/Q0 ;HOLD IF Q1,Q0=L + /LOAD* EP* Q1* Q0 ; COUNT IF EP AND Q1,Q0=H /Q2 := CLEAR ;CLEAR 02 + LOAD*/D2 ;LOAD D2 + /LOAD*/Q2*/EP ;HOLD IF NO EP + /LOAD*/Q2*/Q0 + /LOAD*/Q2*/Q1 ;HOLD IF Q2,Q0=L ;HOLD IF Q2,Q1=L + /LOAD* EP* Q2* Q1* Q0 ;COUNT IF EP AND Q2,Q1,Q0=H /Q3 := CLEAR ;CLEAR Q3 (MSB) + LOAD*/D3 ;LOAD D3 + /LOAD*/Q3*/EP ;HOLD IF NO EP + /LOAD*/Q3*/Q0 ;HOLD IF Q3,Q0=L + /LOAD*/Q3*/Q1 ;HOLD IF Q3,Q1=L + /LOAD*/Q3*/Q2 ;HOLD IF Q3,Q2=L + /LOAD* EP* Q3* Q2* Q1* Q0 ; COUNT IF EP AND Q3,Q2,Q1,Q0=H EP := CLEAR ; INITIALIZE REGISTER + /Q3 + /Q2 + /Q1 ;HOLD IF Q3,Q2,Q1=H ``` #### ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC CLEAR /LOAD /EP D3 D2 D1 D0 Q3 Q2 Q1 Q0 | | COMMENTS<br>(HEX VALUES) | QQQQ<br>3210 | DDDD<br>3210 | | | OPE | | CONI | |-----------------------|--------------------------|--------------|--------------|---|---|-----|---|------| | | CLEAR (0) | LLLL | xxxx | L | н | Н | L | С | | | COUNT (1) | LLLH | XXXX | L | H | L | L | C | | | COUNT (2) | LLHL | XXXX | L | H | L | L | C | | | COUNT (3) | LLHH | XXXX | L | H | L | L | С | | | COUNT (4) | LHLL | XXXX | L | H | L | L | C | | | COUNT (5) | LHLH | XXXX | L | H | L | L | C | | | COUNT (6) | LHHL | XXXX | L | H | L | L | С | | | COUNT (7) | LHHH | XXXX | L | H | L | L | С | | | COUNT (8) | HLLL | XXXX | L | H | L | L | С | | | COUNT (9) | HLLH | XXXX | L | H | L | L | С | | | COUNT (A) | HLHL | XXXX | L | H | L | L | C | | | COUNT (B) | HLHH | XXXX | L | H | L | L | С | | | COUNT (C) | HHLL | XXXX | L | H | L | L | C | | | COUNT (D) | HHLH | XXXX | L | H | L | L | C | | | COUNT (E) | HHHL | XXXX | L | H | L | L | C | | | COUNT (F) | нннн | XXXX | H | H | L | L | C | | COUNT | HOLD AT TERMINAL | HHHH | XXXX | H | H | L | L | C | | | LOAD (0) | LLLL | LLLL | X | L | L | L | C | | | LOAD (1) | LLLH | LLLH | X | L | L | L | C | | | LOAD (3) | LLHL | LLHL | X | L | L | L | C | | | LOAD (4) | LHLL | LHLL | х | L | L | L | ; C | | | LOAD (8) | HLLL | HLLL | Х | L | L | L | ; C | | | LOAD (C) | HHLL | HHLL | х | L | L | L | ; C | | and Allerian Comments | LOAD (E) | HHHL | HHHL | Х | L | L | L | ; с | | | LOAD (F) | нннн | нннн | х | L | L | L | ; C | | | TEST HI-Z | ZZZZ | XXXX | Z | x | X | H | X | ## ; DESCRIPTION ;THE 4-BIT COUNTER LOADS DATA, INCREMENTS, OR HOLDS ON THE RISING EDGE ;OF THE CLOCK (CLK). ;THE COUNTER WILL HOLD WHEN THE TERMINAL COUNT IS REACHED UNTIL NEW DATA; IS LOADED OR THE REGISTERS ARE CLEARED. ; THESE OPERATIONS ARE EXERCISED IN THE FUNCTION TABLE AND SUMMARIZED IN THE ; IN THE OPERATIONS TABLE: | ; | /oc | CLK | CLEAR | /LOAD | /EP | D3-D0 | Q3-Q0 | | OPERATION | |---|-----|-----|-------|-------|-----|-------|--------|---|-----------| | ; | H | х | x | X | | x | Z | | HI-Z | | • | L | С | H | x | X | L | L | | CLEAR | | • | L | С | L | L | X | A | A | | LOAD | | • | L | С | L | H | Н | x | Q | | HOLD | | | L | С | L | H | L | X | Q PLUS | 1 | INCREMENT | ``` Title MEMORY MAPPED I/O Pattern P7083 Revison A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 04/19/82 CHIP MEMORY MAPPED I/O PAL18L4 AO Al A2 A3 A4 A5 A6 A7 A8 /RD /WR GND A9 A10 A11 A12 /READ /WRITE /AUX2 /AUX1 A13 A14 A15 VCC EQUATIONS READ = /A15*/A14*/A13* A12* A11* A10* A9* A8 ; SELECT PORT1 * /A7 * A6 * A5 * A4 */A3 * A2 * A1*/A0 ; (1F76) ; READ STROBE WRITE = /A15*/A14*/A13* A12* A11* A10* A9* A8 ;SELECT PORT1 * /A7 * A6 * A5 * A4 */A3 * A2 * A1* A0 * WR ; (1F77) :WRITE STROBE AUX1 = /A15*/A14*/A13* A12* A11* A10* A9* A8 ;SELECT PORTO * /A7 * A6 * A5 * A4 * A3 */A2 */A1*/A0 (1F78) AUX2 = /A15*/A14*/A13* A12* A11* A10* A9* A8 ;SELECT PORT1 * /A7 * A6 * A5 * A4 * A3 */A2 */A1* A0 ; (1F79) ; FUNCTION TABLE FOR PALASM 1 ;A15 A14 A13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 /RD /WR ;/READ /WRITE /AUX1 /AUX2 ;-ADDRESS INPUTS- STROBES --PORT ENABLE OUTPUTS--- /RD /WR /READ /WRITE /AUX1 /AUX2 ;111111 ;5432109876543210 COMMENT ; LLLLHHHHLHHHHLLL L L Н H Н H TEST OF78 ; LLLHHHHLLHHHHLLL L H L Η Н н TEST 1E78 ; LLLHHHHHHHHHHLLL L Н TEST 1FF8 L H H Н ; LLLHHHHHLHHHLLLL L L H Н Н . H TEST 1F70 H . . . . . ;LLLHHHHHLHHHLHHL H L H Н H TEST 1F76 (NO RD STROBE) H TEST 1F76 (READ ENABLE) TEST 1F77 (NO WR STROBE) ; LLLHHHHHLHHHLHHL L Τ. Н H ;LLLHHHHHLHHHLHHH L H Н H H H H TEST 1F77 ;LLLHHHHHLHHHLHHH L H L L (WRITE ENABLE) H TEST 1F78 (AUX1 ENABLE) :LLLHHHHHLHHHHLLL L H L Н L Н TEST 1F79 (AUX2 ENABLE) ; LLLHHHHHLHHHHLLH L Н L Η L n H TEST 1F7A ; LLLHHHHHLHHHHLHL LL H H ; LLLHHHHHHHHHHLLH L H TEST 1FF9 H ; LLLHHHHLLHHHHLLH H TEST 1E79 H Н Н ; LLHHHHHHLHHHHLLH H Н TEST 3F79 H Н ; LLLLLLLLLLLLLL H Н H Н TEST ALL L'S ; ННИНИНИНИНИНИНИ L L H Н Η Н TEST ALL H'S H ;LHLHLHLHLHLHLHL L L H н Η TEST ODD CHECKERBOARD ; HLHLHLHLHLHLHLHL H H H TEST EVEN CHECKERBOARD ``` #### ; DESCRIPTION ;THIS PAL PROVIDES A SINGLE CHIP DECODER FOR USE IN MEMORY MAPPED I/O OPERATIONS ;REQUIRING FOUR ACTIVE LOW PORT ENABLES AND FULL 16-BIT DECODE WITH TWO TWO ;STROBE LINES (/RD AND /WR). EQUATION TERMS CAN BE CHANGED TO ACCOMMODATE ANY ;16-BIT ADDRESS. ;THE PAL WILL MONITOR THE SYSTEM MEMORY ADDRESS BUS (A15-A0) AND DECODE THE ;SPECIFIED MEMORY ADDRESS WORD (1F76,1F77,1F78,1F79) TO PRODUCE A PORT ENABLE ;FOR READ, WRITE, A # 74S508 Memory Map Interface #1 Title SN54/74S508 MEMORY MAP INTERFACE WITH THE INTEL 8085 (DESIGN # 1) Pattern P7085 Revision A VINCENT COLI Author Company MMI SUNNYVALE, CALIFORNIA Date 05/15/82 CHIP SN54/74S508 MEMORY MAP INTERFACE WITH THE INTEL 8085 (DESIGN #1) PAL16R4 CLK ADO AD1 AD2 AD3 AD4 AD5 AD6 AD7 GND #### EOUATIONS GO := /AD3\*/AD4\*/AD5\* AD6\*/AD7 ;MONITOR ADDRESS/DATA BUS (AD3-AD7) E1 \* E2\* E3 ; MONITOR ENABLES (FROM A8-A15) ALE ; MONITOR ADDRESS/DATA CONTROL /IO := /ADO ; REGISTER INSTRUCTION INPUT IO /Il := /AD1 ; REGISTER INSTRUCTION INPUT I1 /I2 := /AD2; REGISTER INSTRUCTION INPUT 12 #### ; FUNCTION TABLE FOR PALASM 1 ;/OE CLK ADO AD1 AD2 AD3 AD4 AD5 AD6 AD7 /E1 E2 E3 ALE IO I1 I2 /GO | ;/OE CLK 01234567 /E1 E2 E3 ALE 012 /GO (OCTAL ADDRESS | S) | |--------------------------------------------------------|--------------------| | ; L C XXXLLLLH L H H H XXX H (200 TO 207) ] | INACTIVE | | | INACTIVE (/E1=H) | | ; L C XXXLLLHL L L H XXX H (100 TO 107) 1 | INACTIVE (E2,E3=L) | | ; L C XXXLLLHL L H H L XXX H (100 TO 107) | INACTIVE (ALE=L) | | ; L C XXXLLLHL L H H H XXX L (100 TO 107) | (ACTIVE RANGE) | | ; L C LHHLLLHL L H H H LHH L (106) LOAD X | | | ; L C LHHLLLHL L H H L LHH H (106) NOP (ALI | E=L) | | ; L C LLLLLLHL L H H H LLL L (100) LOAD Y | | | ; H X XXXXXXXX X X X X ZZZ Z TEST HI-Z | | #### : DESCRIPTION ;THIS PAL PROVIDES THE DECODE LOGIC FOR INTERFACING THE MMI SN54/74S508, 8-BIT ;SEQUENTIAL MULTIPLIER/DIVIDER, WITH THE INTEL 8085 MICROPROCESSOR. THE PAL16R4 ;MONITORS THE LOWER 8 BIT ADDRESS/DATA BUS (AD0-AD7), THE ADDRESS LATCH ENABLE ;(ALE), AND THREE OF THE UPPER 8 BIT ADDRESS BUS (A8-A15) WHICH IS LABELED ;/E1,E2,M THE 8085 IN ORDER TO ;DECODE AN ACTIVE LOW CHIP-ACTIVATION SIGNAL (/GO) FOR THE 74S508. THE ;INSTRUCTION LINES AND CHIP-ACTIVATION SIGNAL ARE REGISTERED IN ORDER TO INSURE ;THAT INSTRUCTION INPUTS WILL NOT CHANGE WHEN THE CLOCK IS LOW (CLK=L). BY ;MONITORING THE MACHINE STATUS CYCLE, THE 74S508 CAN BE ADDRESS MAPPED BY THE ;8085 AS IF IT WERE AN I/O DEVICE, THUS NOT USING ANY MEMORY MAP ADDRESS SPACE. ;THE MACHINE CYCLE STATUS FROM THE 8085 IS AVAILABLE ON THE FALLING EDGE OF ALE. ;FOR THIS PARTICULAR DESIGN, THE THREE INSTRUCTION INPUTS TO THE 74S508 (10-12);ARE ASSIGNED TO THE THREE LSB BITS OF ADDRESS BUS (A8-A10), WHILE THE REMAINING;ADDRESS BITS (A11-A15) ARE DECODED BY THE PAL TO DETERMINE IF THE 74S508 IS;SELECTED. ALSO, ADDRESS 100 TO 107 IS RESERVED FOR THE 74S508. THE ADDRESS;SPACE CAN BE CHANGED BY SIMPLY EDITING THE LOGIC # 74S508 Memory Map Interface #2 Title SN54/74S508 I/O DEVICE INTERFACE WITH THE INTEL 8085 (DESIGN # 2) Pattern P7086 Revision A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA CHIP SN54/74S508\_I/O\_DEVICE\_INTERFACE\_WITH\_THE\_INTEL\_8085\_(DESIGN\_#\_2) PAL16R4 CLK A15 A14 A13 A12 A11 A10 A9 A8 GND /OE IOM ALE I2 I1 IO /GO S1 S0 VCC 05/15/82 # EQUATIONS /I2 := /Al0 Date GO := /All\*/Al2\*/Al3\* Al4\*/Al5 ; MONITOR ADDRESS BUS (All-Al5) \* IOM\*/Sl \* SO ; MONITOR MACHINE CYCLE STATUS (I/O WRITE) \* /ALE ; MONITOR ADDRESS/DATA CONTROL (FALLING EDGE) /IO := /A8 ; REGISTER INSTRUCTION INPUT IO /II := /A9 ; REGISTER INSTRUCTION INPUT II #### ; FUNCTION TABLE FOR PALASM 1 ;/OE CLK A8 A9 A10 A11 A12 A13 A14 A15 IOM S1 S0 ALE IO II I2 /GO ; REGISTER INSTRUCTION INPUT 12 | ;/OE CLK 89012345 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; L C XXXLLLH H H H L L XXX H (100 TO 107) I/O REA ; L C XXXLLLHL H H H L XXX H (100 TO 107) INTERRUPT AC ; L C XXXLLLHL L H H H XXX H (100 TO 107) INACTIVE (AL ; L C XXXLLLHL H L H L XXX L (100 TO 107) (ACTIVE RANG ; L C LHHLLLHL H L H L LHH L (106) LOAD X | | ; L C XXXLLIHL H H H H L XXX H (100 TO 107) INTERRUPT AC<br>; L C XXXLLIHL L H H H XXX H (100 TO 107) INACTIVE (AL<br>; L C XXXLLIHL H L H L XXX L (100 TO 107) (ACTIVE RANG<br>; L C LHHLLIHL H L H L LHH L (106) LOAD X | | ; L C XXXLLIHL L H H H XXX H (100 TO 107) INACTIVE (AL ; L C XXXLLIHL H L H L XXX L (100 TO 107) (ACTIVE RANG ; L C LHHLLIHL H L H L LHH L (106) LOAD X | | ; L C XXXLLLHL H L H L XXX L (100 TO 107) (ACTIVE RANG<br>; L C LHHLLLHL H L H L LHH L (106) LOAD X | | ; L C LHHLLLHL H L H L LHH L (106) LOAD X | | (100) 100 (170 11) | | | | ; L C LHHLLLHL H L H H LHH H (106) NOP (ALE=H) | | ; L C LLLLLHL H L H L LLL L (100) LOAD Y | | ; H X XXXXXXXX X X X ZZZ Z TEST HI-Z | #### ; DESCRIPTION ;THIS PAL PROVIDES THE DECODE LOGIC FOR INTERFACING THE MMI SN54/74S508, 8-BIT ;SEQUENTIAL MULTIPLIER/DIVIDER, WITH THE INTEL 8085 MICROPROCESSOR. THE PAL16R4;MONITORS THE UPPER 8 BIT ADDRESS BUS (A8-A15), THE ADDRESS LATCH ENABLE (ALE), ;AND THE THREE MACHINE CYCLE STATUS LINES (IOM,S1,S0) FRO ``` Title 16 INPUT REGISTERED PRIORITY ENCODER (CHIP No. 1) Pattern P7090 COLI/VOLPIGNO 10/13/82 Revision A Author COLI/VOLPIGNO MMI SUNNYVALE, CALIFORNIA Company Date 10/13/82 CHIP 16_INPUT_REGISTERED_PRIORITY_ENCODER (CHIP_No._1) PAL20R4 I1 I2 I3 I4 I5 I6 I7 18 · 19 /OC I10 I11 I12 Q3 Q2 Q1 Q0 I13 I14 I15 VCC EQUATIONS /Q0 := /I0* I1 + /I0*/I1*/I2* I3 + /I0*/I1*/I2*/I3*/I4* I5 + /I0*/I1*/I2*/I3*/I4*/I5*/I6* I7 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8* I9 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10* I11 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12* I13 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14* I15 /Q1 := /I0*/I1* I2 + /10*/11*/12* 13 + /10*/11*/12*/13*/14*/15* 16 + /I0*/I1*/I2*/I3*/I4*/I5*/I6* I7 + /10*/11*/12*/13*/14*/15*/16*/17*/18*/19* 110 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10* I11 + '/I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13* I14 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14* I15 /Q2 := /I0*/I1*/I2*/I3* I4 + /10*/11*/12*/13*/14* 15 + /I0*/I1*/I2*/I3*/I4*/I5* I6 + /10*/11*/12*/13*/14*/15*/16* 17 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11* I12 + /10*/11*/12*/13*/14*/15*/16*/17*/18*/19*/110*/111*/112* 113 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13* I14 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14* I15 /Q3 := /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7* I8 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8* I9 + /IO*/II*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9* I10 + /10*/11*/12*/13*/14*/15*/16*/17*/18*/19*/110* 111 + /IO*/II*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/IIO*/II1* I12 + /IO*/II*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/II0*/II1*/I12* I13 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13* I14 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14* I15 ``` ### ;FUNCTION TABLE FOR PALASM 1 ;CLK /OC 115 114 113 112 111 110 19 18 17 16 15 14 13 12 11 10 Q3 Q2 Q1 Q0 | ; CHIP<br>; CONTROL<br>; CLK /OC | SIXTEEN INPUTS<br>111111<br>5432109876543210 | OUTPUTS<br>QQQQ<br>3210 | COMMENTS | |----------------------------------|----------------------------------------------|-------------------------|---------------------------------------| | ; | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | нннн | IO INTERRUPT (HIGHEST PRIORITY INPUT) | | ; C L | XXXXXXXXXXXXXX | HHHL | Il INTERRUPT | | ; C L | XXXXXXXXXXXXXHLL | HHLH | I2 INTERRUPT | | ; C L | XXXXXXXXXXXXHLLL | HHLL | I3 INTERRUPT | | ; C L | XXXXXXXXXXHLLLL | HLHH | I4 INTERRUPT | | ; C L | XXXXXXXXXHLLLLL | HLHL | I5 INTERRUPT | | ; C L | XXXXXXXXXHLLLLLL | HLLH | I6 INTERRUPT | | ; C L | XXXXXXXXHLLLLLL | HLLL | I7 INTERRUPT | | ; C L | XXXXXXXHLLLLLLL | LHHH | I8 INTERRUPT | | ; C L | XXXXXXHLLLLLLLL | LHHL | I9 INTERRUPT | | ; C L | XXXXXHLLLLLLLLL | LHLH | IlO INTERRUPT | | ; C L | XXXXHLLLLLLLLLL | LHLL | Ill INTERRUPT | | ; C L | XXXHLLLLLLLLLLL | LLHH | I12 INTERRUPT | | ; C L | XXHLLLLLLLLLLLL | LLHL | Il3 INTERRUPT | | ; C L | XHLLLLLLLLLLLLL | LLLH | Il4 INTERRUPT | | ; C L | HLLLLLLLLLLLLL | LLLL | I15 INTERRUPT (LOWEST PRIORITY INPUT) | | ; X H | XXXXXXXXXXXXXXX | ZZZZ | TEST HI-Z | #### ; DESCRIPTION ;THE 16 INPUT REGISTERED PRIORITY ENCODER ACCEPTS SIXTEEN ACTIVE-LOW INPUTS ;(10-115) TO LOAD THE BINARY WEIGHTED CODE OF THE PRIORITY ORDER INTO THE OUTPUT ;REGISTER (Q3-Q0) ON THE RISING EDGE OF THE CLOCK (CLK). A PRIORITY IS ASSIGNED ;TO EACH INPUT SO THAT WHEN TWO INPUTS ARE SIMULTANEOUSLY ACTIVE, THE INPUT WITH ;THE HIGHEST PRIORITY IS LOADED INTO THE OUTPUT REGISTER. THEREFORE THE HIGHEST ;PRIORITY INPUT (10=H) PRODUCES HHHH IN THE OUTPUT REGISTER AND THE LOWEST ;PRIORITY INPUT (115=H) PRODUCES LLLL IN THE OUTPUT REGISTER. # ;OPERATIONS TABLE | /oc | CLK | I15 <b>-</b> I0 | Q3-Q0 | OPE | RATION | | | | |-----|-----|-----------------|-------|------------|-----------|----------|----------|--------| | Н | x | х | Z | HI-2 | | | | | | L | C | IO =H | 15 | IO | INTERRUPT | (HIGHEST | PRIORITY | INPUT) | | L | С | Il =H | 14 | Il | INTERRUPT | | | | | L | C | Il =H | 13 | I2 | INTERRUPT | | | | | L | C | Il =H | 12 | I3 | INTERRUPT | | | | | L | С | Il =H | 11 | I4 | INTERRUPT | | | | | L | С | I1 =H | 10 | <b>I</b> 5 | INTERRUPT | | | | | L | C | Il =H | 9 | I6 | INTERRUPT | | | | | L | C | Il =H | 8 | <b>I</b> 7 | INTERRUPT | | | | | L | C | I1 =H | 7 | 18 | INTERRUPT | | | | | L | C | I1 =H | 6 | 19 | INTERRUPT | | | | | L | C | Il =H | 5 | I10 | INTERRUPT | | | | | L | C | Il =H | 4 | Ill | INTERRUPT | | | | | L | С | Il =H | 3 | I12 | INTERRUPT | | | | | L | С | Il =H | 2 | I13 | INTERRUPT | | | | | L | Ċ | Il =H | 1 | I14 | INTERRUPT | | | | | L | Ċ | Il =H | 0 | I15 | INTERRUPT | (LOWEST | PRIORITY | INPUT) | ``` Title 16 INPUT PRIORITY ENCODER INTERRUPT FLAG (CHIP No. 2) ``` Pattern P7091 Revision A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 11/13/82 CHIP 16\_INPUT\_PRIORITY\_ENCODER INTERRUPT FLAG (CHIP No. 2) PAL16C1 IO I1 I2 I3 I4 I5 I6 I7 I8 GND I9 I10 I11 I12 POS INT NEG INT I13 I14 I15 VCC EQUATIONS NEG\_INT = /IO\*/II\*/I2\*/I3\*/I4\*/I5\*/I6\*/I7\*/I8\*/I9\*/II0\*/II1\*/I12\*/I13\*/I14\*/I15 ; FUNCTION TABLE FOR PALASM 1 ;I15 I14 I13 I12 I11 I10 I9 I8 I7 I6 I5 I4 I3 I2 I1 I0 NEG INT POS INT | ; SIXTEEN INPUTS<br>;111111<br>;5432109876543210 | INTEI<br>FLA<br>NEG | T - 1 | соми | 1ENTS | | | | |--------------------------------------------------|---------------------|-------|------|-----------|----------|----------|---------| | ; XXXXXXXXXXXXXXX | L | н | IO | INTERRUPT | (HIGHEST | PRIORITY | (INPUT) | | ;XXXXXXXXXXXXXXL | L | H | Il | INTERRUPT | | | | | ;XXXXXXXXXXXXHLL | L | H | I2 | INTERRUPT | | | | | ;XXXXXXXXXXXXHLLL | L | H | I3 | INTERRUPT | | | | | ;XXXXXXXXXXHLLLL | L | H | 14 | INTERRUPT | | | | | ;XXXXXXXXXXHLLLLL | L | H | 15 | INTERRUPT | | | | | ;XXXXXXXXXHLLLLL | L | H | 16 | INTERRUPT | | 64 | | | ;XXXXXXXXHLLLLLL | L | H | 17 | INTERRUPT | | | | | ;XXXXXXXHLLLLLLL | L | H | 18 | INTERRUPT | | | | | ;XXXXXXHLLLLLLLL | L | H | 19 | INTERRUPT | | | | | ;XXXXXHLLLLLLLLL | L | H | IlO | INTERRUPT | | | | | ;XXXXHLLLLLLLLLL | L | H | Ill | INTERRUPT | | | | | ;XXXHLLLLLLLLLLL | L | H | I12 | INTERRUPT | | | | | ;XXHLLLLLLLLLLL | L | H | I13 | INTERRUPT | | | | | ;XHLLLLLLLLLLLLL | L | H | I14 | INTERRUPT | | | | | ;HLLLLLLLLLLLLLL | L | H | I15 | INTERRUPT | (LOWEST | PRIORITY | INPUT) | | ;LLLLLLLLLLLLLL | H | L | NO | INTERRUPT | | | | # ; DESCRIPTION ;THE 16 INPUT PRIORITY ENCODER INTERRUPT FLAG ACCEPTS SIXTEEN ACTIVE-LOW INPUTS ; (10-115) IN ORDER TO GENERATE AN ACTIVE LOW (NEG\_INT) AND ACTIVE HIGH (POS\_INT) ;INTERRUPT FLAG. ;UP TO FOUR INTERRUPT ENABLE PINS OF ANY POLARITY CAN BE ADDED IF A PAL2OC1 IS ;SUBSTITUTED. ``` Title 15 INPUT REGISTERED PRIORITY ENCODER Pattern P7092 COLI/VOLPIGNO 10/13/82 Revision A Author COLI/VOLPIGNO MMI SUNNYVALE, CALIFORNIA Company 10/13/82 CHIP 15_INPUT_REGISTERED_PRIORITY ENCODER PAL20R4 12 13 14 15 16 17 18 I9 Ιl GND /OC IIO III FLAG Q3 Q2 Q1 Q0 II2 II3 II4 VCC EQUATIONS /Q0 := /I0* I1 + /I0*/I1*/I2* I3 + /10*/11*/12*/13*/14* 15 + /10*/11*/12*/13*/14*/15*/16* 17 + /10*/11*/12*/13*/14*/15*/16*/17*/18* 19 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10* I11 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12* I13 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14 /Q1 := /I0*/I1* I2 + /I0*/I1*/I2* I3 + /10*/11*/12*/13*/14*/15* 16 + /10*/11*/12*/13*/14*/15*/16* 17 + /10*/11*/12*/13*/14*/15*/16*/17*/18*/19* 110 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10* I11 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14 /Q2 := /I0*/I1*/I2*/I3* I4 + /I0*/I1*/I2*/I3*/I4* I5 /10*/11*/12*/13*/14*/15* 16 /10*/11*/12*/13*/14*/15*/16* 17 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11* I12 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12* I13 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/II0*/II1*/II2*/II3* I14 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14 /Q3 := /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7* I8 + /10*/11*/12*/13*/14*/15*/16*/17*/18* 19 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9* I10 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10* I11 + /I0*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11* I12 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12* I13 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13* I14 + /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/II0*/II1*/II2*/II3*/II4 /FLAG = /IO*/I1*/I2*/I3*/I4*/I5*/I6*/I7*/I8*/I9*/I10*/I11*/I12*/I13*/I14 ``` # ;FUNCTION TABLE FOR PALASM 1 ;CLK /OC 114 113 112 111 110 19 18 17 16 15 14 13 12 11 10 Q3 Q2 Q1 Q0 FLAG | ; CHIP ; CONTROL | FIFTEEN INPUTS | OUTPUTS | | | |-------------------------------|----------------------------------------------------|------------------------------------|------------------------------------------------------------------|--------------------------| | ;CLK /OC | | 3210 FLAG | COMMENTS | | | ; C L ; C L ; C L ; C L ; C L | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | HHHH H HHLL H HHLL H HLHH H | IO INTERRUPT I1 INTERRUPT I2 INTERRUPT I3 INTERRUPT I4 INTERRUPT | (HIGHEST PRIORITY INPUT) | | ; C L ; C L | XXXXXXXHLLLLLL<br>XXXXXXXXHLLLLLL<br>XXXXXXXXX | HLHL H<br>HLLH H<br>HLLL H | I5 INTERRUPT<br>I6 INTERRUPT<br>I7 INTERRUPT | | | ; C L ; C L ; C L | XXXHLTTTTTTTT<br>XXXXHTTTTTTTTT<br>XXXXXHTTTTTTTTT | LHHH H LHLL H LHLL H | 18 INTERRUPT<br>19 INTERRUPT<br>110 INTERRUPT<br>111 INTERRUPT | | | ; C L ; C L ; C L ; X H | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | LLHH H LLHL H LLLH H LLLL L ZZZZ X | I12 INTERRUPT I13 INTERRUPT I14 INTERRUPT NO INTERRUPT TEST HI-Z | (LOWEST PRIORITY INPUT) | #### ; DESCRIPTION ;THE 15 INPUT REGISTERED PRIORITY ENCODER ACCEPTS FIFTEEN ACTIVE-LOW INPUTS ;(10-114) TO LOAD THE BINARY WEIGHTED CODE OF THE PRIORITY ORDER INTO THE OUTPUT ;REGISTER (Q3-Q0) ON THE RISING EDGE OF THE CLOCK (CLK). A PRIORITY IS ASSIGNED ;TO EACH INPUT SO THAT WHEN TWO INPUTS ARE SIMULTANEOUSLY ACTIVE, THE INPUT WITH ;THE HIGHEST PRIORITY IS LOADED INTO THE OUTPUT REGISTER. THEREFORE THE HIGHEST ;PRIORITY INPUT (10=H) PRODUCES HHHH IN THE OUTPUT REGISTER AND THE LOWEST ;PRIORITY INPUT (114=H) PRODUCES LLLH IN THE OUTPUT REGISTER. THE NON-REGIST-;ERED INTERRUPT FLAG (FLAG) GOES HIGH WHEN AN INTERRUPT IS PRESENT AND REMAINS ;LOW WHEN THERE IS NO INTERRUPT PRESENT. #### ; OPERATIONS TABLE | ; | /oc | CLK | I14-I0 | Q3-Q0 | FLAG | OPERATION | | |---|-----|-----|--------|-------|------|-----------------------|-----------------------------| | ; | н | x | x | Z | х | HI-Z | | | ; | L | С | L | 0 | L | NO INTERRUP | | | ; | L | С | IO =H | 15 | H | IO INTERRU | PT (HIGHEST PRIORITY INPUT) | | ; | L | С | Il =H | 14 | H | Il INTERRU | PT | | ; | L | C | I2 =H | 13 | H | I2 INTERRU | <b>PT</b> | | ; | L | С | I3 =H | 12 | H | I3 INTERRU | PT | | ; | L | С | I4 =H | 11 | H | I4 INTERRU | PT | | ; | L | C | I5 =H | 10 | H | I5 INTERRU | PT | | ; | L | С | I6 =H | 9 | H | I6 INTERRU | <b>PT</b> | | • | L | С | I7 =H | 8 | H | 17 INTERRU | PT | | ; | L | C | I8 =H | 7 | H | 18 INTERRU | <b>PT</b> | | | L | С | I9 =H | 6 | H | <pre>19 INTERRU</pre> | PT | | • | L | С | I10=H | 5 | Н | IlO INTERRU | $\mathbf{PT}$ | | | L | С | Ill=H | 4 | н | Ill INTERRU | PT | | | L | С | I12=H | 3 | н | Il2 INTERRU | PT | | | L | c | I13=H | 2 | н | Il3 INTERRU | ${f PT}$ | | ; | L | Ċ | I14=H | 1 | H | I14 INTERRU | PT (LOWEST PRIORITY INPUT) | # 8 Input Registered Priority Encoder ``` Title 8 INPUT REGISTERED PRIORITY ENCODER WITH INTERRUPT FLAG Pattern P7093 Revision A VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 06/21/82 CHIP 8 INPUT REGISTERED PRIORITY ENCODER WITH INTERRUPT FLAG PAL16R4 CLK IO I1 I2 I3 I4 I5 I6 I7 GND /OC /E4 /E3 Q3 Q2 Q1 Q0 E2 E1 VCC EQUATIONS /Q0 := /I0*I1 ;DECODE IO=L AND I1=H + /10*/11*/12* 13 ; DECODE IO-2=L AND I3=H + /10*/11*/12*/13*/14* 15 ; DECODE IO-4=L AND I5=H + /I0*/I1*/I2*/I3*/I4*/I5*/I6* I7 ;DECODE IO-6=L AND I7=H /Q1 := /I0*/I1* I2 ;DECODE IO-1=L AND I2=H + /10*/11*/12* 13 ; DECODE IO-2=L AND I3=H + /I0*/I1*/I2*/I3*/I4*/I5* I6 ; DECODE IO-5=L AND I6=H + /10*/11*/12*/13*/14*/15*/16* 17 ;DECODE IO-6=L AND I7=H /Q2 := /I0*/I1*/I2*/I3* I4 ;DECODE IO-3=L AND I4=H + /10*/11*/12*/13*/14* 15 ; DECODE IO-4=L AND I5=H + /10*/11*/12*/13*/14*/15* 16 ; DECODE IO-5=L AND I6=H + /10*/11*/12*/13*/14*/15*/16* 17 ;DECODE IO-6=L AND I7=H /O3 := E1* E2* E3* E4* I0 ; INTERRUPT FLAG (IO) E1* E2* E3* E4* I1 ; INTERRUPT FLAG (I1) E1* E2* E3* E4* I2 ; INTERRUPT FLAG (I2) ; INTERRUPT FLAG (I3) E1* E2* E3* E4* I3 E1* E2* E3* E4* I4 ; INTERRUPT FLAG (14) ``` E1\* E2\* E3\* E4\* I5 E1\* E2\* E3\* E4\* I6 E1\* E2\* E3\* E4\* I7 ; INTERRUPT FLAG (15) ; INTERRUPT FLAG (16) ; INTERRUPT FLAG (I7) # ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC E1 E2 /E3 /E4 I7 I6 I5 I4 I3 I2 I1 I0 Q3 Q2 Q1 Q0 | CHIP<br>CONTROL<br>CLK /OC | IN | PUT | OUR-<br>ENAI<br>/E3 | BLES | 8 INPUTS<br>IIIIIIII<br>76543210 | OUTPUTS<br>Q QQQ<br>3 210 | COMMENTS | |----------------------------|----|-----|---------------------|------|----------------------------------|---------------------------|-------------------------------------------| | C L | L | Н | L | L | ххххххн | н ннн | IO INTERRUPT NOT ENABLED (E1=I | | C L | H | L | L | L | XXXXXXXH | н ннн | IO INTERRUPT NOT ENABLED (E2=I | | C L | H | H | H | L | XXXXXXXH | н ннн | IO INTERRUPT NOT ENABLED(/E3=H | | СГ | | H | L | H | XXXXXXXH | н ннн | IO INTERRUPT NOT ENABLED(/E4=H | | C L | Н | H | L | L | XXXXXXXH | L HHH | IO INTERRUPT (HIGHEST PRIORITY | | C L | L | H | L | L | XXXXXXHL | H HHL | Il INTERRUPT NOT ENABLED (El=I | | C L | Н | L | L | L | XXXXXXHL | H HHL | Il INTERRUPT NOT ENABLED (E2=I | | C L | H | H | H | L | XXXXXXHL | H HHL | Il INTERRUPT NOT ENABLED (/E3=H | | C L | H | H | L | H | XXXXXXHL | H HHL | Il INTERRUPT NOT ENABLED(/E4=H | | C L | H | H | L | L | XXXXXXHL | L HHL | Il INTERRUPT | | C L | L | Н | L | L | XXXXXHLL | H HLH | I2 INTERRUPT NOT ENABLED (E1=I | | C L | Н | L | L | L | XXXXXHLL | H HLH | I2 INTERRUPT NOT ENABLED (E2=I | | C L | H | H | H | L | XXXXXHLL | H HLH | I2 INTERRUPT NOT ENABLED(/E3=F | | C L | H | Н | L | H | XXXXXHLL | H HLH | I2 INTERRUPT NOT ENABLED(/E4=H | | C L | H | H | L | L | XXXXXHLL | L HLH | I2 INTERRUPT | | C L | L | H | L | L | XXXXHLLL | H HLL | I3 INTERRUPT NOT ENABLED (E1=I | | C L | Н | L | L | L | XXXXHLLL | H HLL | I3 INTERRUPT NOT ENABLED (E2=1 | | C L | H | H | H | L | XXXXHLLL | H HLL | I3 INTERRUPT NOT ENABLED(/E3=F | | C L | H | Н | L | H | XXXXHLLL | H HLL | I3 INTERRUPT NOT ENABLED(/E4=F | | C L | H | Н | L | L | XXXXHLLL | L HLL | I3 INTERRUPT | | C L | L | H | L | L | XXXHLLLL | H LHH | I4 INTERRUPT NOT ENABLED (E1=I | | C L | H | L | L | L | XXXHLLLL | H LHH | I4 INTERRUPT NOT ENABLED (E2=1 | | C L | H | H | H | L | XXXHLLLL | H LHH | <pre>14 INTERRUPT NOT ENABLED(/E3=H</pre> | | C L | H | H | L | Н | XXXHLLLL | H LHH | <pre>14 INTERRUPT NOT ENABLED(/E4=H</pre> | | C L | H | H | L | L | XXXHLLLL | L LHH | I4 INTERRUPT | | C L | L | H | L | L | XXHLLLLL | H LHL | I5 INTERRUPT NOT ENABLED (E1=1 | | C L | H | L | L | L | XXHLLLLL | H LHL | I5 INTERRUPT NOT ENABLED (E2=1 | | C L | H | H | H | L | XXHLLLLL | H LHL | I5 INTERRUPT NOT ENABLED(/E3=H | | C L | H | H | L | H | XXHLLLLL | H LHL | <pre>15 INTERRUPT NOT ENABLED(/E4=H</pre> | | C L | H | H | L | L | XXHLLLLL | L LHL | I5 INTERRUPT | | C L | L | H | L | L | XHLLLLLL | H LLH | <pre>16 INTERRUPT NOT ENABLED (E1=)</pre> | | C L | H | L | L | L | XHLLLLLL | H LLH | I6 INTERRUPT NOT ENABLED (E2=1 | | C L | H | Н | H | L | XHLLLLLL | H LLH | <pre>16 INTERRUPT NOT ENABLED(/E3=H</pre> | | C L | H | H | L | H | XHLLLLL | H LLH | <pre>16 INTERRUPT NOT ENABLED(/E4=F</pre> | | C L | H | Н | L | L | XHLLLLLL | L LLH | I6 INTERRUPT | | C L | L | н | L | L | HLLLLLL | H LLL | 17 INTERRUPT NOT ENABLED (E1=1 | | C L | H | L | L | L | HLLLLLLL | H LLL | 17 INTERRUPT NOT ENABLED (E2=1 | | C L | H | Н | н | L | HLLLLLLL | H LLL | I7 INTERRUPT NOT ENABLED(/E3= | | C L | н | Н | L | н | HLLLLLLL | H LLL | I7 INTERRUPT NOT ENABLED(/E4=1 | | C L | H | Н | L | L | HLLLLLLL | L LLL | 17 INTERRUPT (LOWEST PRIORITY) | | C L | н | | L | L | LLLLLLL | н ннн | NO INTERRUPT INPUT (Q3=H) | | х н | x | X | $\bar{\mathbf{x}}$ | x | XXXXXXX | Z ZZZ | TEST HI-Z | # 8 Input Registered Priority Encoder #### ; DESCRIPTION ;THE 8 INPUT REGISTERED PRIORITY ENCODER ACCEPTS SIXTEEN ACTIVE-LOW INPUTS ;(10-17) TO LOAD THE BINARY WEIGHTED CODE OF THE PRIORITY ORDER INTO THE OUTPUT ;REGISTER (Q2-Q0) ON THE RISING EDGE OF THE CLOCK (CLK) PROVIDING THE FOUR ;ENABLE INPUTS ARE TRUE (E1=H,E2=H,/E3=L,/E4=L). A PRIORITY IS ASSIGNED TO EACH ;INPUT SO THAT WHEN TWO INPUTS ARE SIMULTANEOUSLY ACTIVE, THE INPUT WITH THE ;HIGHEST PRIORITY IS LOADED INTO THE OUTPUT REGISTER. THEREFORE THE HIGHEST ;PRIORITY INPUT (10=H) PRODUCES HHH IN THE OUTPUT REGISTER AND THE LOWEST ;PRIORITY INPUT (17=H) PRODUCES LLL IN THE OUTPUT REGISTER. ;THE PRIORITY INTERRUPT ENCODER REGISTERS (Q3-Q0) ARE UPDATED ON THE RISING EDGE;OF THE CLOCK (CLK) PROVIDING THE FOUR ENABLE INPUTS ARE TRUE (E1=H,E2=H,/E3=L,;/E4=L). THE PREVIOUS DATA IS HELD IN THE PRIORITY ENCODER REGISTERS IF ANY OF;THE ENABLE INPUTS ARE FALSE (E1=L,E2=L,/E3=H,/E4=H) REGARDLESS OF CLOCK;TRANSITIONS. NOTE THAT THE POLARITY OF THE ENABLES CAN BE CHANGED BY MERELY;EDITING THE LOGIC EQUATIONS. ;OUTPUT Q4 SERVES AS THE INTERRUPT FLAG AND IS TRUE (Q4=L) WHEN ANY OF THE 8;INPUTS ARE ACTIVE (I=H) ON THE RISING EDGE OF THE CLOCK (CLK) PROVIDING THE ;FOUR ENABLE INPUTS ARE TRUE (E1=H,E2=H,/E3=L,/E4=L). THE INTERRUPT FLAG IS;FALSE (Q4=H) WHEN ALL INPUTS ARE INACTIVE (I=L) OR WHEN ANY ONE OF THE FOUR ;ENABLE INPUTS ARE FALSE (E1=L,E2=L,/E3=H,/E4=H). #### OPERATIONS TABLE | ;/oc | CLK | El | E2 | /E3 | /E4 | 17-10 | Q4 | Q3-Q0 | OPERATION | |------|-----|----|----|-----|-----|-------|----|-------|-------------------------------------------| | ; | x | | х | х | х | х | z | z | HI-Z | | ; L | С | L | X | Х | X | Х | H | Q | NOT ENABLED (E1=L) | | , L | C | Х | L | x | Х | X | H | Q | NOT ENABLED (E2=L) | | ; L | С | X | X | H | X | x | H | Q | NOT ENABLED (/E3=H) | | ; L | С | X | Х | X | H | X | H | Q | NOT ENABLED (/E4=H) | | ; L | С | H | Н | L | L | L | H | X | NO INTERRUPT FLAG | | ; L | С | H | H | L | L | IO=H | L | 7 | IO INTERRUPT (HIGHEST PRIORITY) | | ; L | C | H | Н | L | L | Il=H | L | 6 | Il INTERRUPT | | ; L | C | н | H | L | L | Il=H | L | 5 | I2 INTERRUPT | | ; L | С | Н | H | L | Ĺ | Il=H | L | 4 | I3 INTERRUPT | | ; L | С | H | H | L | L | Il=H | L | 3 | I4 INTERRUPT | | ; L | С | н | н | L | L | Il=H | L | 2 | I5 INTERRUPT | | ; L | С | H | H | L | L | I1=H | L | 1 | I6 INTERRUPT | | ; L | C | H | H | L | Ī | Il=H | L | 0 | <pre>17 INTERRUPT (LOWEST PRIORITY)</pre> | ``` Title DUAL STEPPER MOTOR CONTROLLER Pattern P7094 Revision A Author COLI/SACKETTE Company MMI SUNNYVALE, CALIFORNIA 12/07/82 CHIP DUAL STEPPER MOTOR CONTROLLER PALLERS CLK /ENA SETA ROTA MODEA /ENB SETB ROTB MODEB GND /OC /SW1B /SW2B /SW3B /SW4B /SW4A /SW3A /SW2A /SW1A VCC EQUATIONS */ENA ; HOLD SW1A (DISABLE) /SW2A */SW4A* ENA* ROTA* MODEA ; HALF-STEP MOTOR CW SW3A * ENA* ROTA*/MODEA ; FULL-STEP MOTOR CW /SW2A*/SW3A * ENA*/ROTA* MODEA ; HALF-STEP MOTOR CCW SW4A* ENA*/ROTA*/MODEA ; FULL-STEP MOTOR CCW ENA * SETA TO STEP 1 */ENA SW1A := SW1A SW2A */ENA ;HOLD SW2A (DISADLE, +/SW1A */SW3A * ENA* ROTA* MODEA*/SETA ;HALF-STEP MOTOR CW + SW4A* ENA* ROTA*/MODEA*/SETA ;FULL-STEP MOTOR CW +/SW1A */SW4A* ENA*/ROTA*/MODEA*/SETA ;HALF-STEP MOTOR CCW + SW3A * ENA*/ROTA*/MODEA*/SETA ;FULL-STEP MOTOR CCW SW3A */ENA ;HOLD SW3A (DISABLE) */SW4A* ENA* ROTA* MODEA ;HALF-STEP MOTOR CW SW2A * ENA* ROTA*/MODEA ;FULL-STEP MOTOR CW /SW2A */SW4A* ENA*/ROTA* MODEA ;HALF-STEP MOTOR CCW ENA * SETA TO STEP 1 SW3A := SWIA SW4A := * ENA*/ROTA* MODEA*/SETA ;HALF-STEP MOTOR CCW * ENA*/ROTA*/MODEA*/SETA ;FULL-STEP MOTOR CCW SW2A */ENB ; HOLD SW1B (DISABLE) B */SW4B* ENB* ROTB* MODEB ; HALF-STEP MOTOR CW SW3B * ENB* ROTB*/MODEB ; FULL-STEP MOTOR CW B*/SW3B * ENB*/ROTB* MODEB ; HALF-STEP MOTOR CCW SW4B* ENB*/ROTB*/MODEB ; FULL-STEP MOTOR CCW SW1B := SW1B + /SW2B /SW2B*/SW3B * SETB ;SET B TO STEP 1 ENR SW2B := SW2B */ENB ;HOLD SW2B (DISABLE) B * ENB* ROTB* MODEB*/SETB ;HALF-STEP MOTOR CW SW4B* ENB* ROTB*/MODEB*/SETB ;FULL-STEP MOTOR CW */SW4B* ENB*/ROTB* MODEB*/SETB ;HALF-STEP MOTOR CCW + /SW1B */SW3B + /SW1B SW3B * ENB*/ROTB*/MODEB*/SETB ; FULL-STEP MOTOR CCW ;HOLD SW3B (DISABLE) SW3B := SW3B */ENB */SW4B* ENB* ROTB* MODEB ;HALF-STEP MOTOR CW * ENB* ROTB*/MODEB ;FULL-STEP MOTOR CW */SW4B* ENB*/ROTB* MODEB ;HALF-STEP MOTOR CCW * ENB*/ROTB*/MODEB ;FULL-STEP MOTOR CCW + /SW1B ;FULL-STEP MOTOR CW SW2B ;HALF-STEP MOTOR CCW /SW2B FULL-STEP MOTOR CCW * SETB ;SET B TO STEP 1 SW1B ``` # **Dual Stepper Motor Controller** ``` SW4B := SW4B*/ENB ;HOLD SW4B (DISABLE) + /SW2B*/SW3B * ENB* ROTB* MODEB*/SETB ;HALF-STEP MOTOR CW + SW1B * ENB* ROTB*/MODEB*/SETB ;FULL-STEP MOTOR CW + SW2B * ENB*/ROTB*/MODEB*/SETB ;FULL-STEP MOTOR CCW ``` ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC /ENA SETA ROTA MODEA SW1A SW2A SW3A SW4A /ENB SETB ROTB MODEB SW1B ;SW2B SW3B SW4B | ; CH | IP<br>TROL | STE | PPER | MOT | OR A | SSSS | STE | PPER | MOT | OR B | SSSS | | |------|------------|-----|------|-----|------|------|-----|------|-------|------|------|-----------------------| | ;CLK | /oc | /EN | SET | ROT | MODE | 1234 | /EN | SET | ROT | MODE | 1234 | COMMENTS | | ; C | L | L | н | х | х | HLHL | L | н | <br>х | x | HLHL | SET A AND B TO STEP 1 | | ; C | L | L | | н | H | HLLL | L | L | L | H | LLHL | FULL STEP A CW, B CCW | | ; C | L | L | L | H | Н | HLLH | L | L | L | H | LHHL | FULL STEP A CW, B CCW | | ; C | L | н | L | н | Н | HLLH | н | L | L | H | LHHL | HOLD MOTOR POSITION | | ; C | L | L | L | H | H | LLLH | L | L | L | H | LHLL | FULL STEP A CW, B CCW | | ; C | L | L | L | H | H | LHLH | L | L | | H | LHLH | FULL STEP A CW, B CCW | | ; C | L | L | L | H | H | LHLL | L | L | L | H | LLLH | FULL STEP A CW, B CCW | | ; C | L | L | L | H | H | LHHL | L | L | L | H | HLLH | FULL STEP A CW, B CCW | | ; C | L | L | L | H | H | LLHL | L | L | L | H | HLLL | FULL STEP A CW, B CCW | | ; C | L | L | L | H | H | HLHL | L | L | L | H | HLHL | FULL STEP A CW, B CCW | | ; C | L | H | L | L | L | HLHL | H | L | H | L | HLHL | HOLD MOTOR POSITION | | ; C | L | L | L | L | L | LHHL | L | L | H | L | HLLH | HALF STEP A CCW, B CW | | ; C | L | L | L | L | L | LHLH | L | L | H | L | LHLH | HALF STEP A CCW, B CW | | ; C | L | L | L | L | L | HLLH | L | L | H | L | LHHL | HALF STEP A CCW, B CW | | ; C | L | L | L | L | L | HLHL | L | L | Н | L | HLHL | HALF STEP A CCW, B CW | | ; X | H | Х | Х | х | Х | ZZZZ | Х | X | Х | X | ZZZZ | TEST HI-Z | | ;CLK | /oc | /EN | SET | ROT | MOE | E SW | 1-S | W4 | COMMENTS | |------|-----|-----|-----|-----|-----|-------|-----|----|----------------------------------| | ; | н | X | Х | Х | х | | z - | | HI-Z | | ;C | L | H | X | X | X | HC | LD | | HOLD MOTOR POSITION | | C | L | L | H | X | Х | | 1 | | SET MOTOR POSITION TO STEP 1 | | C | L | L | L | H | H | SW PI | US | 1 | HALF-STEP MOTOR CLOCKWISE | | C | L | L | L | H | L | SW PI | US | 2 | FULL-STEP MOTOR CLOCKWISE | | :C | L | L | L | L | H | SW MI | NUS | 1 | HALF-STEP MOTOR COUNTERCLOCKWISE | | ;C | L | L | L | L | L | SW MI | NUS | 2 | FULL-STEP MOTOR COUNTERCLOCKWISE | ``` Title CLEAN OCTAL LATCH ``` Pattern P7096 Revision A Author VINCENT COLI Company MMI SUNNYVALE, CALIFORNIA Date 03/10/83 CHIP CLEAN OCTAL LATCH PAL20L10 G NC D0 D1 D2 D3 D4 D5 D6 D7 NC GND /OC NC Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 NC VCC #### **EQUATIONS** IF(OC) $$\sqrt{Q5} = G*/D5$$ ; LOAD LATCH (Q5) + $\sqrt{G*/Q5}$ ; LATCH OUTPUT + $\sqrt{D5*/O5}$ . COVER ALWAYS HIG IF(OC) $$/Q6 = G*/D6$$ ; LOAD LATCH $^{\circ}(Q6)$ + $/G*/Q6$ ; LATCH OUTPUT IF(OC) $$/Q7 = G*/D7$$ ;LOAD LATCH (Q7) + $/G*/Q7$ ;LATCH OUTPUT + /D7\*/Q7 ; COVER ALWAYS HIGH HAZARD #### ; FUNCTION TABLE FOR PALASM 1 /OC G D7 D6 D5 D4 D3 D2 D1 D0 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | ;CONTROL | DDDDDDDD | QQQQQQQ | COMMENTS | |-------------------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ;/OC G | 76543210 | 76543210 | | | ; L H ; L L ; L H ; L L ; L H ; L L ; L H ; L L ; L H | LLLLLLLL XXXXXXX HHHHHHHH XXXXXXXX HHHHHHHH | LLLLLLL LLLLLL HHHHHHHH HHHHHHHHH HLHLHLHL HLHLHLHL LHLHLHLH LHLHLHLH LZZZZZZZZ | LOAD ALL ZEROS LATCH ALL ZEROS LOAD ALL ONES LATCH ALL ONES LOAD EVEN CHECKERBOARD LATCH EVEN CHECKERBOARD LOAD ODD CHECKERBOARD LATCH ODD CHECKERBOARD TEST HI-Z | #### :DESCRIPTION ;THIS PAL16L8 IMPLEMENTS AN 8-BIT LATCH FUNCTION WITH THREE-STATE OUTPUTS. THE ;LATCH PASSES EIGHT BITS OF DATA (D7-D0) TO THE EIGHT OUTPUTS (Q7-Q0) WHEN LATCH ;ENABLE IS TRUE (G=HIGH). THE DATA IS LATCHED WHEN LATCH ENABLE IS FALSE ;(G=LOW). THE OUTPUTS WILL BE DISABLED (HI-Z) WHEN OUTPUT ENABLE IS TRUE ;(/OC=TRUE) REGARDLESS OF ANY OTHER INPUTS. | ; | /0C | G | D7-D0 | Q7-Q0 | COMMENTS | |---|-----|---|-------|-------|--------------| | ; | н | x | х | Z | HI-Z | | ; | L | L | X | Q | LATCH OUTPUT | | ; | L | H | D | D | LOAD LATCH | | • | | | | | | ;THIS DESIGN SHOWS HOW TO IMPLEMENT A "CLEAN" LATCH SINCE THERE ARE NO OUTPUT;GLITCHES AS THE DEVICE CHANGES STATE. THE KARNAUGH MAP BELOW FOR O+;ILLUSTRATES THIS. THE TWO HORIZONTAL CIRCLES REPRESENT THE "LOAD LATCH" AND;"LATCH OUTPUT" PRODUCT LINES. THE VERTICAL CIRCLE LINKS TOGETHER THE OTHER;CIRCLES IN ORDER TO COVER A POTENTIAL SWITCHING HAZARD WHICH WOULD OCCUR WHEN;THE OUTPUTS ARE ALWAYS HIGH. ``` Title SHAFT ENCODER No. 1PAL16R4 Pattern P7097 Revision A ``` Author WILLY VOLDAN Company MMI GMBH MUNICH Date 09/09/82 CHIP SHAFT ENCODER No. 1 PAL16R4 CLK PHI0 PHI90 X4 NC NC NC NC /SSET GND /OC DOWN NC S4 S3 S2 S1 NC UP VCC #### EQUATIONS /S1 := /PHI0 + SSET /S2 := /S1 + SSET /S3 := /PHI90 + SSET /S4 := /S3 + SSET IF (VCC) /DOWN = S1\* S2\* S3\*/S4\* PHIO\* PHI90 + /S1\*/S2\*/S3\* S4\*/PHIO\*/PHI90 + S1\*/S2\*/S3\*/S4\* PHIO\*/PHI90 + /S1\* S2\* S3\* S4\*/PHIO\* PHI90 IF (VCC) /UP = /S1\*/S2\* S3\*/S4\*/PHI0\* PHI90 + S1\* S2\*/S3\* S4\* PHI0\*/PHI90 + S1\*/S2\* S3\* S4\* PHI0\* PHI90 + /S1\* S2\*/S3\*/S4\*/PHI0\*/PHI90 ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC /SSET PHIO PHI90 S4 S3 S2 S1 UP DOWN ;CHECK FOR PHIO ;INITIALIZE S1=L ;CHECK FOR S1 ;INITIALIZE S2=L ;CHECK FOR PHI90 ;INITIALIZE S3=L ;CHECK FOR S3 ;INITIALIZE S4=L ;PHIO LEADS PHI90 ;PHIO LEADS PHI90 ;PHIO LEADS PHI90 ;PHIO LEADS PHI90 ;PHI90 LEADS PHI0 ;PHI90 LEADS PHI0 ;PHI90 LEADS PHI0 ;PHI90 LEADS PHI0 # Shaft Encoder #1 | | | LS<br>/SSET | INP<br>PHIO | UTS<br>PHI90 | SSSS<br>4321 | | PUTS<br>DOWN | COMMENTS | |---|---|-------------|-------------|--------------|--------------|--------|--------------|------------------------------------------| | С | | L | х<br>х | | LLLL | н | н | CLEAR REGISTERS | | C | L | H | L | L | LLLL | Н | н | 아즐 돌아가 그 동안 얼굴됐다. 나는 그 | | С | L | H | L | L | LLLL | H | H | | | С | L | H | L | H | LHLL | L | н | COUNT UP | | C | L | H | L | H | HHLL | H | н | | | C | L | H | H | н | HHLH | L | H | COUNT UP | | С | L | H | H | H | нннн | Н | н | 대학교 등이 걸었게 되고 있다는 회사들이 | | С | L | н | H | L | HLHH | L | H | COUNT UP | | С | L | н | н | L | LLHH | Н | н | | | C | L | H | L | L | LLHL | L | H | COUNT UP | | C | L | H | L | L | LLLL | H | H | | | С | L | H | L | H | LHLL | L | H | COUNT UP | | С | L | H | L | H | HHLL | H | H | | | C | L | H | H | H | HHLH | L | H | COUNT UP | | С | L | H | H | H | нннн | H | H | | | С | L | H | H | L | HLHH | L | H | COUNT UP | | С | L | H | H | L | LLHH | H | H | | | C | L | H | L | L | LLHL | L | H | COUNT UP | | С | L | H | L | L | LLLL | H | H | | | С | L | H | L | H | LHLL | L | H | COUNT UP | | C | Ŀ | <b>H</b> | L | н | HHLL | H | H | | | C | L | H | H | H | HHLH | L | H | COUNT UP | | C | Ŀ | H | H | H | нннн | H | H | | | C | Ŀ | H | H | L | HLHH | L | H | COUNT UP | | C | L | H | H | Ŀ | LLHH | H | H | 불발발 <u>품병도 1호</u> ( <u>호호</u> 왕이 50 원 원) | | C | Ŀ | H | L | L | LLHL | L | H | COUNT UP | | C | L | H | L | L | LLLL | H | H | F - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | | C | L | L | X | X | LLLL | H | H | CLEAR REGISTERS | | C | L | H | L | L | LLLL | H | H | | | C | L | H | L | L | LLLL | H | H | | | C | L | H | H | Ţ | LLLH | H | L | COUNT DOWN | | C | L | H | H | L | LLHH | H | Ħ | COLUMN DOLLAR | | C | L | H | H | H | LHHH | H | T. | COUNT DOWN | | C | ŗ | н | H | H | нннн | H | H | COLUMN DOLDI | | C | L | H | L | H | HHHL | H | L | COUNT DOWN | | C | L | H | L | H | HHLL | H | H | COLINE POINT | | C | L | H | L | ŗ | HLLL | H | L | COUNT DOWN | | C | Ļ | H | L | L | LLLL | H | H | COLINE DOLLA | | C | Ļ | H | H | Ļ | LLLH | H | L | COUNT DOWN | | C | L | H | H | L | LLHH | H | H<br>L | COLINE DOWN | | C | L | H | H | H | LHHH | Н | | COUNT DOWN | | C | L | H | H | H | HHHH | H | H<br>L | COUNT DOWN | | C | L | H | L | H | HHHL | H<br>H | H | COUNT DOWN | | C | L | H | L | H | HHLL | H<br>H | L<br>L | COUNT DOWN | | C | Ļ | H | Ļ | L<br>L | HLLL | H | H | COOMI DOWN | | C | L | H | L | | LLLL | | | COUNT DOWN | | C | L | H | H | Ļ | LLLH | H<br>H | L<br>H | COOMI DOWN | | C | L | H | H | L | LLHH | | | COUNT DOWN | | C | L | H | H | H | LHHH | H<br>H | L<br>H | COUNT DOWN | | C | Ľ | H | H | H | HHHH | | n<br>L | COUNT DOWN | | C | Ļ | H | Ļ | H | HHHL | H<br>H | H | COOM T DOWN | | C | L | H | L | H | HHLL | H | L | COUNT DOWN | | C | Ľ | H | Ļ | Ļ | HLLL | H | H<br>L | COOMI DOWN | | | L | H | L | L | LLLL | 11 | X | | #### ; DESCRIPTION: :THIS PAL16R4 IMPLEMENTS A TWO CHANNEL SHAFT ENCODER OF THE TYPE USED IN SPEED :CONTROLLERS AND OPTICAL DEVICES. ; BOTH THE "UP" AND "DOWN" OUTPUTS OF THE PAL ARE NORMALLY HIGH. ; WHEN THE SIGNAL AT THE "PHIO" INPUT LEADS THE SIGNAL AT THE "PHI90" INPUT, THE ; "DOWN" OUTPUT ALTERNATES BETWEEN HIGH AND LOW LEVELS AT HALF THE "CLK" ; FREQUENCY RATE. ALSO, WHEN THE SIGNAL AT THE "PHIO" INPUT LAGS THE SIGNAL AT ; THE "PHI90" INPUT, THE "UP" OUTPUT ALTERNATES BETWEEN HIGH AND LOW LEVELS AT ; HALF THE "CLK" FREQUENCY RATE. ;THE SHAFT ENCODER FEATURES THE CONFIGURATION AND OUTPUT POLARITY TO DRIVE AN ;74S193 TYPE UP/DOWN COUNTER. ;THIS DESIGN WITH GLITCHFREE OUTPUTS WILL BE EXTREMELY USEFUL IN ELECTRICALLY; NOISY ENVIRONMENTS. THE PINNING IS GIVEN AS A FIRST PROPOSAL AND CAN BE; CHANGED ACCORDING TO THE PC-BOARD LAYOUT. 74 #### Shaft Encoder #2 ``` SHAFT ENCODER No. 2 Title Pattern P7098 Revision A Author WILLY VOLDAN Company MMI GMBH MUNICH Date 09/09/82 CHIP SHAFT ENCODER No. 2 PAL16R8 CLK PHIO PHI90 X4 NC NC NC NC /SSET GND /OC UD NC S4 S3 S2 S1 NC COUNT VCC EQUATIONS := /PHI0 /S1 ;CHECK FOR PHIO SSET ;INITIALIZE S1=L := /PHI90 ; CHECK FOR PHI90 /S3 SSET ; INITIALIZE S3=L ; CHECK FOR /S1 /S2 Sl ;INITIALIZE S2=L SSET /S4 S3 ;CHECK FOR /S3 := ;INITIALIZE S4=L SSET /COUNT := S1* S2*/S3* S4 ;THIS OUTPUT ALTERNATES + /S1*/S2* S3*/S4 ;BETWEEN HIGH AND LOW WITH + /S1* S2*/S3*/S4* X4 ;HALF OR QUARTER THE ;CLK FREQUENCY S1*/S2* S3* S4* X4 + S1* S2* S3*/S4 + /S1*/S2*/S3* S4 + /S1* S2* S3* S4* X4 S1*/S2*/S3*/S4* X4 ;THIS OUTPUT DETERMINES := /S1* S2*/S3* S4 /UD + /S1* S2* S3* S4 ; IF SIGNAL PHIO LEADS + /S1* S2* S3*/S4 ;OR LAGS SIGNAL PHI90 S1* S2* S3*/S4 S1*/S2* S3*/S4 + S1*/S2*/S3*/S4 ``` TROTOTOM + S1\*/S2\*/S3\* S4 + /S1\*/S2\*/S3\* S4 # ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC /SSET PHIO PHI90 X4 S1 S2 S3 S4 COUNT UD | ;CONTROLS<br>;CLK /OC /SSET | INPUTS<br>PHIO PHI90 | X<br>4 | SSSS<br>1234 | -OUTPU<br>COUNT | TS-<br>UD | COMMENTS | |-----------------------------|----------------------|--------|--------------|---------------------|-----------|----------------------------| | ; C L L | хх | x | LLLL | Н | н | CLEAR REGISTERS | | ; C L H | L L | L | LHLH | H | H | COUNT UP X4=L | | ; C L H | H L | L | HHLH | H | L | | | ; C L H | H L | L | HLLH | L | H | | | ; C L H | н н | L | HLHH | н | L | | | ; C L H | н н | L | HLHL | H | H | | | ; C L H | L H | L | LLHL | H | L | | | ; C L H | L H | L | LHHL | L | H | | | ; C L H | L L | L | LHLL | Н | L | | | ; C L H | L L | L | LHLH | H | H | | | ; C L H | H L | L | HHLH | H | L | 크림까게 하기 뭐무요 그렇는다 | | ; C L H | H L | L | HLLH | L | H | | | ; C L H | н н | L | HLHH | H | L | | | ; C L H | н н | L | HLHL | н | H | 이 기교화가 하는 사람들이 얼마다 | | ; C L H | L H | L | LLHL | H | L | | | ; C L H | L H | L | LHHL | L | H | | | ; C L H | LLL | H | LHLL | H | L | COUNT UP X4=L | | ; C L H | LLL | н | LHLH | L | H | 그 [10] [11] 다시 내고 17:66 () | | ; C L H | H L | H | HHLH | н | L | | | ; C L H | H L | н | HLLH | L | H | 무취를 하셨다. 이 경기를 하는 하나의 얼마? | | ; C L H | н н | H | HLHH | Ħ | L | | | ; C L H | н н | H | HLHL | L | H | | | ; C L H | L H | н | LLHL | $ \bar{\mathbf{H}}$ | L | 네 됐다. 이 회문 사람이 가는 그 때 | | ; C L H | L H | H | LHHL | L | H | | | ; C L H | L L | H | LHLL | H | L | | | ; C L H | L L | H | LHLH | Ĺ | H | | | ; C L H | H L | H | HHLH | н | L | | | ; C L H | H L | H | HLLH | Ĺ | H | | | ; C L H | H H | H | HLHH | H | Ĺ | | | ; C L H | н н | H | HLHL | Ĺ | H | | | ; C L L | X X | x | LLLL | H | L | CLEAR REGISTERS | | ; C L H | L L | Ĺ | LHLH | H | H | COUNT DOWN X4=L | | ; C L H | L H | ī | LHHH | H | Ë | COUNT DOWN AT L | | ; C L H | L H | Ĺ | LHHL | H | ī | | | ; C L H | н н | ī | HHHL | H | Ĺ | | | ; C L H | н н | Ĺ | HLHL | Ë | Ĩ. | | | ; C L H | H L | Ĺ | HLLL | H | ī | 영화 기계 등 경기 이 보고 있다. | | ; C L H | H L | ī | HLLH | H | ī | | | ; C L H | L L | ī | LLLH | Ĥ | Ē | | | ; C L H | Ī Ī | Ī | LHLH | Ĺ | Ĺ | | | ; C L H | L H | ī | LHHH | H | Ĺ | | | ; Č L H | L H | Ĺ | LHHL | H | ī | | | ; č L H | й й | Ĺ | HHHL | Ĥ | ī | | | ; C L H | н н | L | HLHL | Ĺ | Ĺ | | | ; C L H | H L | Ĺ | HLLL | H | Ĺ | | | ; C L H | H L | Ľ | HLLH | H | Ĺ | | | ; C L H | L L | H | LLLH | H | L | COUNT DOWN X4=H | | | L L | H | LHLH | L L | L | | | ; C L H<br>; C L H | T H | H | LHHH | H | L | | | ; C L H | L H | H | LHHL | L L | Ĺ | | | ; C L H | н н | H | HHHL | H | Ĺ | | | | н н | H | HLHL | L | Ľ | | | ; C L H | | | | | 45.9 | TB01020 | ### Shaft Encoder #2 | .1 | ; ( | C | L | H | | H | L | | H | | HLLL | H | L | | | | |----|-----|---|---|---|--|---|---|-------------------------------------|---|---------|------|---|---|------|------|--| | | ; ( | C | L | H | | Н | L | | H | | HLLH | L | L | | | | | | ; ( | С | L | H | | L | L | | Н | grada i | LLLH | H | L | | | | | | ; ( | C | L | H | | L | L | | H | | LHLH | L | L | | | | | | ; ( | C | L | H | | L | H | | Н | | LHHH | H | L | | | | | | ; ( | С | L | H | | L | Н | | H | | LHHL | L | L | | | | | | ; ( | С | L | H | | H | H | tulevi i i i i i<br>Kalendaliki i i | H | | HHHL | H | L | | | | | | ; ( | С | L | H | | Н | H | | H | | HLHL | L | L | | | | | | ; | X | H | X | | X | X | | X | | ZZZZ | Z | Z | TEST | HI-Z | | | | | | | | | | | | | | | | | | | | #### ; DESCRIPTION - ; THIS PALLERS IMPLEMENTS A TWO CHANNEL SHAFT ENCODER OF THE TYPE USED IN SPEED ; CONTROLLERS AND OPTICAL DEVICES. - ;THE "COUNT" OUTPUT OF THE PAL IS NORMALLY HIGH. DURING SHAFT ENCODING THIS ;OUTPUT ALTERNATES BETWEEN HIGH AND LOW. - ; INPUT "X4" SELECTS BETWEEN HALF (X4=H) OR QUARTER (X4=L) CLK FREQUENCY OF THE ; "COUNTER" OUTPUT. - ;OUTPUT "UD" DETERMINES WHETHER SIGNAL PHIO LEADS (UD=H) OR LAGS (UD=L) SIGNAL ;PHI90. - ;THE SHAFT ENCODER FEATURES THE CONFIGURATION AND OUTPUT POLARITY TO DRIVE AN ;74S697 TYPE UP/DOWN COUNTER. - ;THIS DESIGN WITH GLITCHFREE OUTPUTS WILL BE EXTREMELY USEFUL IN ELECTRICALLY; NOISY ENVIRONMENTS. THE PINNING IS GIVEN AS A FIRST PROPOSAL AND CAN BE; CHANGED ACCORDING TO THE PC-BOARD LAYOUT. ``` Title SHAFT ENCODER No. 3 (WITH INTERNAL 4-BIT UP/DOWN COUNTER) Pattern P7099 Revision A Author WILLY VOLDAN Company MMI GMBH MUNICH Date 09/09/82 CHIP SHAFT ENCODER No. 3 (WITH INTERNAL 4-BIT UP/DOWN COUNTER) PAL20X10 EQUATIONS CLK PHIO PHI90 X4 /LD NC D3 D2 D1 D0 /SSET GND /OC DOWN S4 S3 S2 S1 Q3 Q2 Q1 Q0 UP VCC /S1 := /PHIO ;CHECK FOR PHIO SSET :INITIALIZE S1=L /S1 /S2 := ; CHECK FOR S1 SSET ; INITIALIZE S2=L /S3 := /PHI90 CHECK FOR PHI90 SSET ;INITIALIZE S3=L /S3 /S4 := ;CHECK FOR S3 SSET ;INITIALIZE S4=L S1* S2* S3*/S4* PHIO* PHI90* X4 /DOWN := ; PHIO LEADS PHI90 - COUNT=FREQ/2 + /S1*/S2*/S3* S4*/PHI0*/PHI90* X4 ; PHIO LEADS PHI90 - COUNT=FREQ/2 :+: S1*/S2*/S3*/S4* PHIO*/PHI90 ; PHIO LEADS PHI90 - COUNT=FREO/4 /S1* S2* S3* S4*/PHIO* PHI90 ;PHIO LEADS PHI90 - COUNT=FREQ/4 := /S1*/S2* S3*/S4*/PHI0* PHI90 /UP ;PHI90 LEADS PHIO - COUNT=FREQ/4 S1* S2*/S3* S4* PHIO*/PHI90 ;PHI90 LEADS PHIO - COUNT=FREQ/4 S1*/S2* S3* S4* PHIO* PHI90* X4 ;PHI90 LEADS PHI0 - COUNT=FREQ/2 :+: /S1* S2*/S3*/S4*/PHI0*/PHI90* X4 ; PHI90 LEADS PHI0 - COUNT=FREQ/2 := /SSET* LD*/D0 /Q0 ;LOAD DO (LSB) /SSET*/LD*/Q0 ;HOLD QO :+: /SSET*/LD* UP*/DOWN ; DECREMENT /SSET*/LD*/UP* DOWN ; INCREMENT := /SSET* LD*/D1 ;LOAD D1 /Ql /SSET*/LD*/Q1 ;HOLD Q1 :+: /SSET*/LD* UP*/DOWN*/Q0 ; DECREMENT /SSET*/LD*/UP* DOWN* Q0 ; INCREMENT := /SSET* LD*/D2 /Q2 ;LOAD D2 + /SSET*/LD*/Q2 ;HOLD Q2 :+: /SSET*/LD* UP*/DOWN*/Q0*/Q1 ; DECREMENT /SSET*/LD*/UP* DOWN* Q0* Q1 ; INCREMENT := /SSET* LD*/D3 ;LOAD D3 (MSB) /Q3 ;HOLD Q3 + /SSET*/LD*/Q3 :+: /SSET*/LD* UP*/DOWN*/Q0*/Q1*/Q2 ; DECREMENT + /SSET*/LD*/UP* DOWN* Q0* Q1* Q2 ; INCREMENT ``` # ; FUNCTION TABLE FOR PALASM 1 ;CLK /OC /SSET /LD X4 PHI0 PHI90 S1 S2 S3 S4 UP DOWN D3 D2 D1 D0 Q3 Q2 Q1 Q0 | | -CON | TROL | S | | INP | יחד ז | | | | | | | |-----|--------|------|-----|-------|-----|-------|-------------|----|------|------|------|---------------------------| | | / | | , | • | PH | | ssss | | | DDDD | QQQQ | COMMENTS | | | | SSET | | 4 | | 90 | | UP | DOWN | 3210 | 3210 | (Q HEX VALUE) | | c | L | L | x x | | | <br>x | LLLL | н | н | XXXX | нннн | INITIALIZE REGISTERS (F) | | Č | Ē | | LX | | X | | XXXX | X | x | HLHL | HLHL | LOAD (A) | | č | L | | HL | | Ĺ | | LLLL | H | H | XXXX | HLHL | HOLD (A) | | č | L | | H L | | H | | HLLL | H | H | XXXX | HLHL | HOLD (A) PHIO LEADS PHIO | | č | L | | H L | | н | | HHLL | H | ï. | XXXX | HLHL | HOLD (A) X4=H - FREQ/4 | | č | L | | H L | | Н | | HHHL | H | H | XXXX | HLLH | DECREMENT (9) | | Č | ī | | H L | | Н | | нннн | H | H | XXXX | HLLH | HOLD (9) | | Č. | Ē | | H L | | L | | LHHH | H | H | XXXX | HLLH | HOLD (9) | | Č | L | | H L | | L | | LLHH | H | L | XXXX | HLLH | HOLD (9) | | Č | L | | H L | 10.7% | L | | LLLH | H | H | XXXX | HLLL | DECREMENT (8) | | č | L | | H L | | ī | | LLLL | H | H | XXXX | HLLL | HOLD (8) | | Č | L | | H L | | H | | HLLL | H | H | XXXX | HLLL | HOLD (8) | | č | Ē | | H L | | Н | | HHLL | H | L | XXXX | HLLL | HOLD (8) | | č | ī | | H L | | н | | HHHL | H | H | XXXX | LHHH | DECREMENT (7) | | Ċ | L | | H L | 4 | Н | | нннн | H | H | XXXX | LHHH | HOLD (7) | | C | L | | H L | | L | | LHHH | H | H | XXXX | LHHH | HOLD (7) | | Č | L | | H L | | L | | LLHH | H | L | XXXX | LHHH | HOLD (7) | | Č | L | | нн | | ī | | LLLH | H | H | XXXX | LHHL | DECREMENT (6) | | Č | L | | н н | | L | | LLLL | H | L | XXXX | LHHL | HOLD (6) X4=H - FREQ/2 | | Č | L | | н н | | H | | HLLL | H | H | XXXX | LHLH | DECREMENT (5) | | Č | L | | н н | | Н | | HHLL | H | L | XXXX | LHLH | HOLD (5) | | c | L | | н н | | Н | | HHHL | H | H | XXXX | LHLL | DECREMENT (4) | | c | L | | н н | | Н | | нннн | H | L | XXXX | LHLL | HOLD (4) | | Č | L | | нн | | L | | LHHH | H | H | XXXX | LLHH | DECREMENT (3) | | Č | - L | | н н | | L | | LLHH | H | L | XXXX | LLHH | HOLD (3) | | C | L | | н н | | L | | LLLH | Н | H | XXXX | LLHL | DECREMENT (2) | | C | L | | н н | | | | LLLL | Н | L | XXXX | LLHL | HOLD (2) | | С | L | | н н | | | | HLLL | н | H | XXXX | LLLH | DECREMENT (1) | | C | L | | н н | | Н | | HHLL | H | L | XXXX | LLLH | HOLD (1) | | C | L | | н н | | | | HHHL | н | H | XXXX | LLLL | DECREMENT (0) | | Ċ | L | | н н | | H | | нннн | Н | L | XXXX | LLLL | HOLD (0) | | Ċ | L | | н н | | L | | LHHH | H | H | XXXX | нннн | DECREMENT (F) (ROLL UNDER | | C | L | | н н | | | Н | LLHH | Н | L | XXXX | нннн | HOLD (F) | | Č | Ī | | нн | | | L | LLLH | H | H | XXXX | HHHL | DECREMENT (E) | | Č | L | | LX | | × | | XXXX | X | X | LHLH | LHLH | LOAD (5) | | C | L | | H L | | L | | LLLL | H | H | XXXX | LHLH | HOLD (5) | | C | L | | H L | | L | | LLHL | H | H | XXXX | LHLH | HOLD (5) PHI90 LEADS PHI | | C | L | | H L | | | H | LLHH | L | H | XXXX | LHLH | HOLD (5) X4=L - FREQ/4 | | Č | L | | H L | | H | | HLHH | H | H | XXXX | LHHL | INCREMENT (6) | | C | Ľ | | H L | | Н | | нннн | H | H | XXXX | LHHL | HOLD (6) | | | Ľ | | H L | | H | | HHLH | H | H | XXXX | LHHL | HOLD (6) | | - | L | | H L | | H | | HHLL | Ľ | н | XXXX | LHHL | HOLD (6) | | | L | | H L | | L | | LHLL | H | H | XXXX | LHHH | INCREMENT (7) | | | L | | H L | | | L | LLLL | н | H | XXXX | LHHH | HOLD (7) | | | L | | | J. | L | | LLLL | H | Н | XXXX | LHHH | HOLD (7) | | C | | | | | | | | | H | | LHHH | HOLD (7) | | C | Ļ | | H L | | | H | LLHH | L | | XXXX | | | | C | L | | H L | | H | | HLHH | H | H | XXXX | HLLL | INCREMENT (8) | | ; C | L | | H L | | H | | нннн | H | H | XXXX | HLLL | HOLD (8) | | C | L | | H L | | | L | HHLH | H | H | XXXX | HLLL | HOLD (8) | | C | L<br>L | | H L | | | L | HHLL | L | H | XXXX | HLLL | HOLD (8) | | ; C | | H | H H | | т. | Ŀ | ${ t LHLL}$ | H | H | XXXX | HLLH | INCREMENT (9) | | ; C | Ĺ | H | H | H | L L 4/ | LLLL | L | H | XXXX | HLLH | HOLD (9) X4=H - FREQ/2 | |-----|---|---|---|---|--------|------|---|---|------|------|---------------------------| | ; C | L | H | H | H | LH | LLHL | H | H | XXXX | HLHL | INCREMENT (A) | | ; C | L | H | H | H | LH | LLHH | L | H | XXXX | HLHL | HOLD (A) | | ; C | L | H | H | H | нн | HLHH | H | H | XXXX | HLHH | INCREMENT (B) | | ; C | L | H | H | H | нн | нннн | L | Н | XXXX | HLHH | HOLD (B) | | ; C | L | H | H | H | H L | HHLH | H | H | XXXX | HHLL | INCREMENT (C) | | ; C | L | H | H | H | H L | HHLL | L | H | XXXX | HHLL | HOLD (C) | | ; C | L | H | H | H | LL | LHLL | H | H | XXXX | HHLH | INCREMENT (D) | | ; c | L | H | H | H | LL | LLLL | L | H | XXXX | HHLH | HOLD (D) | | ; C | L | H | H | H | LH | LLHL | H | H | XXXX | HHHL | INCREMENT (E) | | ; C | L | H | H | H | LH | LLHH | L | H | XXXX | HHHL | HOLD (E) | | ; C | L | H | H | H | нн | HLHH | H | H | XXXX | нннн | INCREMENT (F) | | ; C | L | H | H | H | HH | нннн | L | H | XXXX | нннн | HOLD (F) | | ; C | L | H | H | H | H L | HHLH | H | H | XXXX | LLLL | INCREMENT (0) (ROLL OVER) | | ; C | L | H | H | H | H L | HHLL | L | H | XXXX | LLLL | HOLD (0) | | ; C | L | H | Η | H | LL | LHLL | H | H | XXXX | LLLH | INCREMENT (1) | | ; C | L | H | L | X | XX | XXXX | X | X | LLLH | LLLH | LOAD (1) | | ; C | L | H | L | X | XX | XXXX | X | X | LLHH | LLHH | LOAD (3) | | ; C | L | H | L | X | XX | XXXX | X | X | LHLH | LHLH | LOAD (5) | | ; C | L | H | L | X | ХХ | XXXX | X | X | LHHH | LHHH | LOAD (7) | | ; C | L | H | L | X | XX | XXXX | X | X | HLLH | HLLH | LOAD (9) | | ; C | L | H | L | X | XX | XXXX | X | X | HLHH | HLHH | LOAD (B) | | ; C | | H | L | X | хх | XXXX | X | X | HHLH | HHLH | LOAD (D) | | ; C | | H | L | X | X X | XXXX | X | X | нннн | нннн | LOAD (F) | | ; X | H | X | X | X | XX | ZZZZ | Z | Z | XXXX | ZZZZ | TEST HI-Z | | | | | | | | | | | | | | #### ; DESCRIPTION ;THIS PAL20X10 IMPLEMENTS A TWO CHANNEL SHAFT ENCODER WITH AN INTERNAL 4-BIT;UP/DOWN COUNTER. ; BOTH THE "UP" AND "DOWN" OUTPUTS OF THE PAL ARE NORMALLY AT HIGH. ; WHEN THE SIGNAL AT THE "PHIO" INPUT LEADS THE SIGNAL AT THE "PHI90" INPUT, THE ; "DOWN" OUTPUT ALTERNATES BETWEEN HIGH AND LOW LEVELS AND THE COUNTER WILL COUNT; DOWN. WHEN THE SIGNAL AT THE "PHI0" INPUT LEADS THE SIGNAL AT THE "PHI90"; INPUT, THE "UP" OUTPUT ALTERNATES BETWEEN HIGH AND LOW LEVELS AND THE COUNTER; WILL COUNT UP. ;INPUT "X4" SELECTS BETWEEN HALF (X4=H) OR QUARTER (X4=L) CLK FREQUENCY OF THE ;COUNTER OUTPUTS. ;THE INTERNAL 4-BIT SYNCHRONOUS COUNTER HAS COUNT UP, COUNT DOWN CAPABILITIES.;ALSO, THE COUNTER CAN PARALLEL LOAD AND HOLD DATA INDEPENDENTLY OF THE SHAFT;ENCODER SECTION. THE REGISTERS ARE SYNCHRONOUSLY INITIALIZED WHEN /SSET IS HEL;LOW. ;THE CONTROL INPUTS PROVIDE THESE OPERATIONS WHICH OCCUR SYNCHRONOUSLY AT THE ;RISING EDGE OF THE CLOCK. 4tol6 Decoder 4-16DEC.PDS ``` Meninaz Hada Monolithic Memories, Santa Clara, CA 1/9/85 Company Date CHIP Decoder PAL6L16 Q0 Q1 Q2 A B C D EN1 EN2 Q3 Q4 GND Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15 VCC ;Decode 0000 ;Decode 0001 ;Decode 0010 ;Decode 0011 ;Decode 0100 :Decode 0101 ;Decode ;Decode 0110 1000 1001 1010 ;Decode ;Decode Decode Decode 1011 ;Decode :Decode 1101 ;Decode 1110 ;Decode 1111 ``` #### SIMULATION Title Pattern Revision TRACE\_ON D B C A QO Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15 ``` SETF /D /C /B /A EN1 EN2 SETF A SETF B SETF C SETF D SETF /D SETF /C SETF /A SETF /A SETF /A SETF /EN1 SETF /EN1 SETF SET outputs to high SETF /EN1 SETF SET outputs to high ``` ;The 4 to 16 decoder, decodes four binary decoded inputs;into one of 16 mutually exclusive outputs, whenever the ;two enable lines EN1 and EN2 are high. When one or both; of the enable lines are low the outputs are all set to;high values. ### **Simulation Results** # **XPLOT Output** TOTAL FUSES BLOWN: # **Logic Symbol** TB01690N ``` Title PC I/O Mapper Pattern MemIO.pds Author A G Gilbert Company Date 1/8/85 ;Personal computers which are hardware compatible with the ;ubiquitous IBM PC share this {\rm I/O} map. NC NC A9 A8 A7 A6 A5 A4 A3 AEN /CSNONOCHRMAD GND /CSCAMEIOAD /CSOSIORAD /CSPRINTERAD /CSSFLOPPIAD /CSRS232AD /CSNNIMKRG /CSOMARGMG /CSPPICHIP/CSTIMECRHIP/CSINTACCHIP/CSDMACCHIP VCC ;DMA controller ;Chip select ;HEX address 000-00F CSDMACCHIP = /A9*/A8*/A7*/A6*/A5 * /A4*/AEN CSINTCCHIP = /A9*/A8*/A7*/A6*A5 * /A4*/A3*/AEN ;Interupt controller ;Chip select ;HEX address 020-021 CSTIMERCHIP = /A9*/A8*/A7*A6*/A5 * /A4*/A3*/AEN Timer ;Chip select ;HEX address 040-043 ;Parallel peripheral interface ;Chip select ;HEX address 060-063 CSPPICHIP = /A9*/A8*/A7*A6*A5 * /A4*/A3*/AEN ;DMA page register ;Chip select ;HEX address 080-083 CSDMAPGRG = /A9*/A8*A7*/A6*/A5 * /A4*/A3*/AEN CSNMIMKRG = /A9*/A8*A7*/A6*A5 * /A4*/AEN ;NMI mask register ;Chip select ;HEX address OAX :RS 232 module :Device select :HEX address 3F8-3FF CSRS232AD = A9*A8*A7*A6*A5 * A4*A3*/AEN ;5.25 floppy disk module ;Device select ;HEX address 3F0-3F7 CS5FLOPPYAD = A9*A8*A7*A6*A5 * A4*/A3*/AEN ;Parallel printer module ;Device select ;HEX address 378-37F CSPRINTERAD = A9*/A8*/A7*A6*A5 * A4*A3*/AEN ;Color graphics video module ;Device select ;HEX address 3D0-3DF CSCOLORAD = A9*A8*A7*A6*/A5 * A4*/AEN ;Game I/O module ;Device select ;HEX address 200-20F CSGAMEIOAD = A9*/A8*/A7*/A6*/A5 * /A4*/AEN ;Monochrome video module ;Device select ;HEX address 3B0-3BF CSMONOCHRMAD = A9*A8*A7*/A6*A5 * A4*/AEN ``` #### SIMULATION TRACE\_ON A9 A8 A7 A6 A5 A4 A3 AEN /CSMONOCHRMAD /CSGAMEIOAD /CSCOLDRAD /CSPRINTERAD /CSSFLOPPYAD /CSRS232AD /CSNMIMKRG /CSDMAPGRG /CSPPICHIP /CSTIMERCHIP /CSIMTCCHIP /CSDMACCHIP ``` SETF ABN SETF A5 SETF A5 SETF A6 SETF A5 SETF A6 SETF A6 SETF A6 SETF A6 SETF A7 SETF A4 SETF A7 ``` ### **Simulation Results** | Page : 1 | | | |---------------|-------------|-----| | | ggggggggg | gg | | A9 | XLLLLLHHH | HH | | A8 | XLLLLLHHH | LH | | A7 | XLLLHHHHHHH | LH | | λ6 | XLLHHHLHHH | LL | | A5 | XIHHLHHHHL | LH | | λ4 | XLLLLLHHHH | LH | | A3 | XLLLLLLHLL | LL | | AEN | HLLLLLLLLL | LL | | /CSMONOCHRMAD | нинининин | HT. | | /CSGAMEIOAD | нинининин | LH | | /CSCOLORAD | нининининт. | нн | | /CSPRINTERAD | нинининини | нн | | /CS5FLOPPYAD | нининнини | нн | | CSRS232AD | HHHHHHHHHHH | нн | | /CSNMIMKRG | нинининин | нн | | /CSDMAPGRG | нинининини | HH | | | HHHHHHIHHH | HH | | /CSPPICHIP | | | | /CSTIMERCHIP | нининини | HH | | /CSINTCCHIP | нигининин | HH | | /CSDMACCHIP | нтининини | HH | | | | | # **XPLOT Output** | Auth | sion<br>or<br>oany | : A ( | | ert<br>nic Memo | orie | |-------------|--------------------|-------|------|-----------------|------| | PALE<br>PC_ | BL14 | | | | | | | | | 11 | 1111 | | | | 0123 | 4567 | 8901 | 2345 | | | | xxxx | | | | | | - 1 | -x-x | -x-x | -x-x | X | | | | XXXX | | | | | | 3 | -X-X | -x-x | XX | -x-x | | | | -x-x | | | | | | | | | | -x-x | | | | | | | -x-x | | | | | | | X | | | 8 | X-X- | x-x- | x-x- | XX | | | 9 | X-X- | X-X- | X-X- | -x-x | | | | | | | xx | | | 11 | X-X- | X-X- | -xx- | x | | | | | | | X | | | 13 | xx | -x-x | -X-X | X | | # TOTAL FUSES BLOWN: 10 Logic Symbol Title Octal\_Comparator Pattern Octcomp.pds Revision A Author Mehrnaz Hada Company Monolithic Memories Inc., Santa Clara,CA 1/29/85 ;The octal comparator establishes when two 8-bit data ;strings (A7-A0) and (B7-B0) are equivalent (EQ=H) or ;equivalent (NE=H). CHIP OctalComparato PAL16C1 A7 A0 B0 A1 B1 A2 B2 A3 B3 GND A4 B4 A5 B5 EQ NE A6 B6 B7 VCC #### EQUATIONS | NE | | A0*/B0 | + | /A0* | BO | | ; A0 | :+: | во | |----|-----|--------|---|------|----|--|------|-----|-----------| | | + | A1*/B1 | + | /A1* | B1 | | ;A1 | :+: | Bl | | | + | A2*/B2 | + | /A2* | B2 | | ; A2 | :+: | B2 | | | + | A3*/B3 | + | /A3* | B3 | | ; A3 | :+: | В3 | | | + | A4*/B4 | + | /A4* | B4 | | ; A4 | :+: | B4 | | | . + | A5*/B5 | + | /A5* | B5 | | ; A5 | :+: | <b>B5</b> | | | + | A6*/B6 | + | /A6* | B6 | | 1A6 | :+: | B6 | | | + | A7*/B7 | + | /A7* | B7 | | ; A7 | :+: | B7 | | | | | | | | | | | | #### SIMULATION # TRACE\_ON A7 A6 A5 A4 A3 A2 A1 A0 NE B7 B6 B5 B4 B3 B2 B1 B0 | SETF A7 /A6 /A5 /A4 /A3 /A2 /A1 /A0 | ;A7=H, B7=L | |--------------------------------------|-----------------------------------------| | /B7 /B6 /B5 /B4 /B3 /B2 /B1 /B0 | | | SETF /A7 A6 | ;A6=H, B6=L | | SETF /A6 A5 | ;A5=H, B5=L | | SETF /A5 A4 | ; A4=H, B4=L | | | ;A3=H, B3=L | | SETF /A3 A2 | ;A2=H, B2=L | | | ;Al=H, Bl=L | | SETF /Al AO | ;A0=H, B0=L | | SETF /A7 /A6 /A5 /A4 /A3 /A2 /A1 /A0 | | | B7 | , , 2, 5, | | SETF /B7 B6 | ;A6=L, B6=H | | SETF /B6 B5 | ;A5=L, B5=L | | | ;A4=L, B4=H | | SETF /B5 B4 | | | SETF /B4 B3 | ; A3=L, B3=H | | SETF /B3 B2 | ;A2=L, B2=H | | SETF /B2 B1 | ;Al=L, Bl=H | | SETF /B1 B0 | ;A0=L, B0=H | | SETF /BO | ;Test all L's | | SETF A7 A6 A5 A4 A3 A2 A1 A0 | :Test all H's | | B7 B6 B5 B4 B3 B2 B1 B0 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | SETF /A7 A6 /A5 A4 /A3 A2 /A1 A0 | ;Test even ones | | /B7 B6 /B5 B4 /B3 B2 /B1 B0 | , 1000 Oven ones | | | .maab add amaa | | SETF A7 /A6 A5 /A4 A3 /A2 A1 /A0 | Test odd ones | | B7 /B6 B5 /B4 B3 /B2 B1 /B0 | | #### ;Function Table for PALASM1 ;A7 A6 A5 A4 A3 A2 A1 A0 B7 B6 B5 B4 B3 B2 B1 B0 NE EQ | ; | | Input B<br>76543210 | | | Comments | |-----|----------|---------------------|-----|---|-----------------------| | ; | HLLLLLLL | LLLLLLL | н | L | A7=H, B7=L | | : | LHLLLLLL | LLLLLLL | H | L | A6=H, B6=L | | ; | LIHLLLLL | LLLLLLLL | | | A5=H, B5=L | | ÷ | LLIHLLLL | LLLLLLLL | н | L | A4=H, A5=L | | ÷ | LLLLHLLL | LLLLLLL | H | L | A3=H, B3=L | | ÷ | | LLLLLLL | | | A2=H, B2=L | | ÷ | LLLLLLHL | LLLLLLL | H | | Al=H, Bl=L | | | | LLLLLLL | | | AO=H, BO=L | | ÷ | | HLLLLLLL | | | A7=L, B7=H | | ٠, | | LHLLLLLL | | | A6=L, B6=H | | ÷ | | LLHLLLLL | | | A5=L, B5=H | | ٠, | | LLLHLLLL | | | | | ٠. | | LLLLHLLL | | | | | ': | | LLLLHLL | | | A2=L, B2=H | | : | | LLLLLL | | | Al=L, Bl=H | | : | | LLLLLLH | | | AO=L, BO=H | | • | | LLLLLLL | | | | | ٠. | | нининин | | | Test all H'S | | • | | HLHLHLHL | | | | | į | | | | | | | , | THINIMIH | THIHIHIH | ىدى | n | rest oud checkerboard | | - 2 | | | | | | # Simulation Results | Page | | • | |------|------------|------------| | | ggggggggg | adadadadad | | A7 | HLLLLLLLL | | | A6 | LHLLLLLLLL | | | A5 | LLHLLLLLLL | LLLLLLLHLH | | A4 | LLLHLLLLLL | LLLLLLHHL | | A3 | LLLLHLLLLL | LLLLLLLHLH | | A2 | LLLLLHLLLL | LLLLLLHHL | | Al | LLLLLLHLLL | LLLLLLLHLH | | ΑO | LLLLLLHLL | LLLLLLHHL | | NE | нинининин | HHHHHHLLLI | | B7 | LLLLLLLLL | LLLLLLHLH | | B6 | LLLLLLLLH | LLLLLLHHI | | B5 | LLLLLLLLL | HLLLLLLHLH | | B4 | LLLLLLLLL | LHLLLLLHHI | | B3 | LLLLLLLLL | LIHLLLIHIH | | B2 | LLLLLLLLL | LLLHLLLHHI | | Bl | LLLLLLLLL | LLLLHLLHLH | | ВО | LLLLLLLLL | LLLLHLHHI | | | | | # **Logic Symbol** TB01710M Title 3to8\_Dmux 3to8Dmux.pds Title Pattern 3 to85mux.pds Revision A Author Mehrnaz Hada Company Monolithic Memories Inc., Santa Clara, CA 1/29/85 :The 3-to-8 demultiplexer with control storage provides a ;conventional 8-bit demux function combined with control storage functions:load true, load complement, hold, toggle, ;polarity, clear and preset. Five inputs(/LD,/CLR,/PR,POL, ;TOG) select one of six operations. The six operations are ;summarized in the following operations table: | | | cLK | Fui<br>/CLR | ncti<br>/PR | | | | Inputs<br>ABC | Outputs<br>Q7-Q0 | Operation | |---|---|-----|-------------|-------------|-----|---|---|---------------|------------------|--------------| | ; | н | x | х | × | × | × | × | × | z | HI-Z | | ; | L | С | L | X | X | X | X | X | L | Clear | | ; | L | С | H | L | X | X | X | x | H | PRESET | | ; | L | С | H | H | j L | H | X | I | MUX | Load true | | ; | L | C | H | H | L | L | X | I | /MUX | Load COMP | | ; | L | C | H | Н | H | x | L | X | Q | Hold | | ; | L | c | H | H | H | X | H | <b>X</b> | /Q | Tog polarity | CHIP 3to8Dmux PAL16R8 CLK /CLR /PR A B C /LD POL TOG GND /OC Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC #### EQUATIONS /07 := SIMULATION ``` /Q0 := CLR + /PR* LD*/POL*/C*/B*/A + /PR* LD* POL* A + /PR* LD* POL* B + /PR* LD* POL* C + /PR*/LD*/TOC*/Q0 + /PR*/LD*/TOC*/Q0 ;Clear Q0 ;Decode 00; ;Load true ;Load true ;Load true :Hold ;Toggle polarity /Q1 := CLR + /PR* LD*/POL*/C*/B* A + /PR* LD* POL* /A + /PR* LD* POL* B + /PR* LD* POL* C + /PR*/LD*/TOC*/Q1 + /PR*/LD*/TOC*/Q1 :Clear Ol ;Decode 001 ;Load true :Load true :Hold ;Toggle polarity /Q2 := CLR + /PR* LD*/POL*/C* B*/A + /PR* LD* POL* A + /PR* LD* POL* C + /PR* LD* POL* C + /PR*/LD*/POC*/Q2 + /PR*/LD* TOG* Q2 ;Clear Q2 ;Decode 010 ;Load true :Load true ;Load true :Hold ;Toggle polarity ;Clear Q3 ;Decode 011 ;Load true /Q3 := CLR = CLR + /PR* LD*/POL*/C* B* A + /PR* LD* POL* /A + /PR* LD* POL* /B + /PR* LD* POL* C + /PR*/LD*/TOG*/Q3 + /PR*/LD* TOG* Q3 ;Load true ;Load true Hold ;Toggle polarity /Q4 := CLR + /PR* LD*/POL* C*/B*/A + /PR* LD* POL* A + /PR* LD* POL*/C + /PR* LD* POL*/C + /PR*/LD*/TOC*/Q4 + /PR*/LD* TOG* Q4 ;Clear Q4 ;Decode 100 ;Load true ;Load true ;Load true ;Toggle polarity /Q5 := CLR + /PR* LD*/POL* C*/B* A + /PR* LD* POL* /A + /PR* LD* POL*/C + /PR* LD* POL*/C + /PR*/LD*/TOC*/Q5 + /PR*/LD* TOG* Q5 ;Clear Q5 ;Decode 101 ;Load true ;Load true :Load true ;Hold ;Toggle polarity := CLR + /PR* LD*/POL* C* B*/A + /PR* LD* POL* A + /PR* LD* POL* /B + /PR* LD* POL*/C + /PR*/LD* TOG* Q6 + /PR*/LD* TOG* Q6 ;Clear Q6 /Q6 := ;Decode 110 ;Load true ;Load true :Load true ;Toggle polarity = CLR + /PR* LD*/POL* C* B* A + /PR* LD* POL* /A + /PR* LD* POL* /B + /PR* LD* POL*/C + /PR*/LD*/TOG*/Q7 + /PR*/LD* TOG* Q7 ``` TRACE\_ON /OC /CLR /PR /LD POL TOG C B A Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | SETF OC CLR PR LD POL /TOG | ;Clear | |----------------------------|--------------------| | CLOCKF CLK | | | SETF /CLR | ;Preset | | CLOCKF CLK | | | SETF /PR /C /B /A | ;Load 0 | | CLOCKF CLK | | | SETF A | ;Load l | | CLOCKF CLK | | | SETF B /A | ;Load 2 | | CLOCKF CLK | | | SETF A | ;Load 3 | | CLOCKF CLK | | | SETF /LD | ;Hold | | SETF TOG | Toggle polarity | | CLOCKF CLK | | | CLOCKF CLK | Toggle polarity | | SETF /POL LD /C /B /A | ;Load 0 complement | | CLOCKF CLK | | | SETF A | ;Load 1 complement | | CLOCKF CLK | | | SETF /OC | ;Test HI-Z | | CLOCKF CLK | | | | | ;Function Table for PALASM1 :/OC CLK /CLR /PR /LD POL TOG C B A Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | | trol | Fur<br>/CLR | /PR | | | rity<br>TOG | Input<br>CBA | Output<br>Q7Q0 | Comments | | |-----|------|-------------|-----|---|---|-------------|--------------|-----------------|-----------|---| | ; L | с | L | L | L | н | L | xxx | LLLLLLL | Clear | - | | ; L | c | H | L | L | H | L | XXX | нинининн | PRESET | | | ; L | Č | н | H | L | H | x | LLL | LLLLLLH | Load 0 | | | ; ī | C | н | H | L | H | - X | LLH | LLLLLLHL | Load 1 | | | ; ī | c | H | H | L | H | x | LHL | LLLLLHLL | Load 2 | | | ; L | C | H | H | L | H | X | LHH | LLLLHLLL | Load 3 | | | ; L | c | H | н | L | н | x | HLL | LLLHLLLL | Load 4 | | | ; L | c | H | H | L | н | X | HLH | LLHLLLL | Load 5 | | | ; L | C | H | н | L | H | X | HHL | LHLLLLLL | Load 6 | | | ; L | c | H | H | L | н | х | HHH | HLLLLLLL | Load 7 | | | ; L | C | H | н | H | x | L | XXX | HLLLLLLL | Hold 7 | | | ; L | c | H | H | H | x | н | XXX | ГИНИНИНИ | Hold | | | ; L | c | H | н | н | X | H | XXX | HLLLLLLL | Hold | | | L | C | н | H | L | L | X | LLL | HHHHHHL | Load 0 | | | ; L | C | H | H | L | L | х | LLH | HHHHHHLH | Load 1 | | | ; L | C | H | H | L | L | X | LHL | нининцин | Load 2 | | | ; L | C | H | H | L | L | X | LHH | HHHHLHHH | Load 3 | | | ; L | Ċ | H | H | L | L | . x | HLL | HHHLHHHH | Load 4 | | | : L | Č | н | н | L | L | X | HLH | HHLHHHHH | Load 5 | | | ; L | C | H | н | L | L | X | HHL | HLHHHHHH | Load 6 | | | ; L | Č | H | н | L | L | X | HHH | LHHHHHHH | Load 7 | | | ; L | c | H | н | H | X | L | XXX | LHHHHHHH | Hold 7 | | | ; ī | č | н | н | н | X | H | XXX | HLLLLLLL | Hold | | | įī | Č | н | н | н | X | H | XXX | <b>L</b> HННННН | Hold | | | ; н | x | x | × | × | X | x | XXX | 2222222 | Test HI-Z | | ### **Simulation Results** | Page | : 1 | | | |------|-------------|-------------|---------| | | g cgcgcgc | gcgcgc cgc | gcg c | | /oc | LLLLLLLLL | LLLLLLLLL | LLHHHHH | | /CLR | LLLLHHHHHHH | нинининин | нининин | | /PR | LLLLLHHHH | нинининин | нининин | | /LD | LLLLLLLLL | LLLLHHHHLL | LLLLLL | | POL | нинининин | HHHHHHHLL | LLLLLL | | TOG | LLLLLLLLL | LLLLHHHHHHH | нининин | | C | XXXXXXLLLL | LLLLLLLLLL | LLLLLLL | | В | XXXXXXLLLL | HHHHHHHLL | LLLLLL | | A | XXXXXXLLHH | LLHHHHHHLL | нининин | | Q7 | XXXLLHHLLL | LLLLLHHLLH | HHHZZZZ | | Q6 | XXXLLHHLLL | LLLLLHHLLH | HHHZZZZ | | Q5 | XXXLLHHLLL | LLLLLHHLLH | HHHZZZZ | | Q4 | XXXLLHHLLL | LLLLLHHLLH | HHHZZZZ | | Q3 | XXXLLHHLLL | LLLHHLLHHH | HHHZZZZ | | Q2 | XXXLLHHLLL | LHHLLHHLLH | HHHZZZZ | | Ql | XXXLLHHLLH | HLLLLHHLLH | HLLZZZZ | | QO | XXXLLHHHHL | LLLLLHHLLL | LHHZZZZ | | | | | | TB01720N ;Clear Q7 ;Decode 111 ;Load true ;Load true ;Load true ;Hold ;Toggle polarity Title Basic Flip Flops Pattern FlipFlop.pds Revision A Author Vincent Coli Company Monolithic Memories Inc., Santa Clara, CA Date 2/28/85 CHIP FlipFlop PAL16RP8 CLK J K T PR CLR D S R GND /OC /SRC /SRT /DC /DT /TC /TT /JKC /JKT VCC JKT := J\*/JKT\*/CLR + /K\* JKT\*/CLR + PR ;JK Flio-Flop ;(JKC = /Q) ;Preset Q ;JK Flip-Flop ;(JK = /Q) JKC := /J\* K \*/PR + /J\*/JKT\*/PR + K\* JKT\*/PR + CLR ;Clear /Q TT := T\*/TT\*/CLR + /T\* TT\*/CLR + PR ;T Flip-Flop ;(TT = Q) Preset Q := /T\*/TT\*/CLR + T\* TT\*/PR + CLR ;T Flip-Flop ;(TC = /Q) ;Clear /Q DT := D\*/CLR + PR ;D Flip-Flop ;Preset Q ;D Flip-Flop DC := /D\*/PR + CLR ;Clear /Q SRT := S\* /CLR + /R\* SRT\*/CLR + PR :Set-Reset Flip-Flop ;(SRT = Q) ;Preset Q ;Set-Reset Flip-Flop SRC := /S\* R \*/PR + /S\*/SRT\*/PR + CLR ;(SRC = /Q);Clear /Q #### SIMULATION TRACE ON /OC PR CLR J K JKT T TT D DT S R SRT | SETF OC /PR CLR | | ; Clear | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | CLOCKF | | | | SETF /CLR /J /K | | | | CLOCKF | | | | SETF K | | | | CLOCKF | | | | SETF J | | ; Toggle | | CLOCKF | | | | SETF /K | | | | CLOCKF | | | | SETF /J | | | | CLOCKF | | | | SETF K | | | | CLOCKF | | | | SETF PR | | ; Preset | | CLOCKF | | | | SETF /PR J K | | ; Toggle | | CLOCKF | | | | SETF /K | | | | CLOCKF | The second second | | | | The second secon | | | SETF CLR | | ; Clear | | CLOCKF | | | | SETF /CLR /T | | | | CLOCKF | | | | SETF T | | ; Toggle | | CLOCKF | | | | SETF /T | | ; Toggle | | CLOCKF | | | | | | | | | | | | SETF CLR | 경기 많은 그 가는 그 살이 가득하다. | ; Clear | | CLOCKF | | Legacionale Paris | | SETF /D | | | | CLOCKF | in Bank in the second by | | | SETF D | | | | CLOCKF | | | | SETF /D | | | | CLOCKF | | | | SETF CLR | | | : Clear | |-----------------|---------------|-----|---------| | CLOCKE | | 5.4 | | | SETF /CLR /S /R | | | | | | | | | | CLOCKF | | | : Set | | SETF S | | | , 366 | | CLOCKF | | | | | SETF /S R | | | ; Reset | | CLOCKF | and efficient | | 4.49 | | SETF /S R | | | ; Hold | | CLOCKF | | | | | SETF /OC | | | ; HI-Z | | CTOCKE | | | | ### **Simulation Results** | | | g cg cg cg | | | |------|----------------|-------------|------------|------------| | /OC | | LLLLLLLLL | | | | PR | | LLLLLLLLL | | | | CLR | | LLLLLLLLL | | | | J | | HHHHHHLLLL | | | | K | XXXXLLLHHH | HHHLLLLLLH | HHHHHHHLL | | | JKT | XXXLLLLLLL | LLHHHHHHHHH | | HHHLLLHHHH | | T | XXXXXXXXX | | | XXXXLLLHHH | | TT | | XXXXXXXXX | | XXXLLLLLLH | | Ď | XXXXXXXXX | XXXXXXXXX | | XXXXXXXXX | | DT | | | | XXXLLLXXXX | | S | XXXXXXXXX | XXXXXXXXX | | XXXXXXXXX | | R | XXXXXXXXX | XXXXXXXXX | | XXXXXXXXX | | SRT | XXXLLLXXXX | XXXXXXXXX | XXXXHHHXXX | XXXLLLXXXX | | | | | | | | Page | | | | | | | d cd cd cd | cg cgcg c | d cd cdcd | | | | LLLLLLLLL | | | | | PR | | LLLLLLLLL | | | | | LLLHHHHHHH | | | | | J | | нинининин | | | | K | | LLLLLLLLL | | | | | HHHHHLLLLL | | | | | T | | LLLLLLLLL | | | | TT | | LLLLLLLLL | | | | D | | HHLLLLLLL | | | | DT | | LLLLLLLLL | | | | S | | XXXXXXXLLL | | | | R | | XXXXXXXLLL | | | | SRT | XXXXXII.I.I.I. | TILLLLLLL | | | | | | | | | # **Logic Symbol** TB01730M Title 9BitRegister Pattern 9BitReg.pds Revision A Author Vincent Coli/Mehrnaz Hada Author Vincent Coli/Mehrnaz Hada Company Monolithic Memories Inc., Santa Clara, CA 1/30/85 ;This is a design of a 9-bit register with parallel load ;and hold capabilities. The operations of this register are ;summarized in the following operations table: OC CLK /LD D8-D0 Q8-Q0 Operation н HI-Z Load CHIP 9BitRegister PAL20X10 CLK DO D1 D2 D3 D4 D5 D6 D7 D8 /LD GND /OC NC Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC EQUATIONS | /Q0 | := /D0* LD<br>+ /Q0*/LD | ;Load Do<br>;Hold Qo | |-----|-------------------------|----------------------| | /Q1 | := /D1* LD<br>+ /Q1*/LD | ;Load D; | | /Q2 | := /D2* LD<br>+ /Q2*/LD | ;Load D;<br>;Hold Q; | | /Q3 | := /D3* LD<br>+ /Q3*/LD | ;Load D; | | /Q4 | := /D4* LD<br>+ /Q4*/LD | ;Load De;Hold Qe | | /Q5 | := /D5* LD<br>+ /Q5*/LD | ;Load D:<br>;Hold Q: | | /Q6 | := /D6* LD<br>+ /Q6*/LD | ;Load De;Hold Qe | | /Q7 | := /D7* LD<br>+ /Q7*/LD | ;Load D'<br>;Hold Q' | | | := /D8* LD<br>+ /O8*/LD | ;Load D;<br>;Hold Q | SIMULATION TRACE\_ON /OC CLK /LD D8 D7 D6 D5 D4 D3 D2 D1 D0 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 SETF OC LD /D8 /D7 /D6 /D5 /D4 /D3 /D2 /D1 /D0 CLOCKF CLK SETF /LD CLOCKF CLK SETF LD D8 D7 D6 D5 D4 D3 D2 D1 D0 CLOCKF CLK SETF /LD CLOCKF CLK SETF LD /D8 D7 /D6 D5 /D4 D3 /D2 D1 /D0 CLOCKF CLK SETF /LD CLOCKF CLK ;Hold even ones ;Hold zeros ;Load ones :Hold ones SETF LD D8 /D7 D6 /D5 D4 /D3 D2 /D1 D0 SETF /LD CLOCKF CLK :Hold odd ones SETF OC :Test HI-Z :Function Table for PALASM1 ;/OC CLK D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 ;Q9 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 # **Simulation Results** | ; | Data In | Data Out | | | |----------------------|--------------------------|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ;Control<br>;/OC CLK | DDDDDDDDDD<br>9876543210 | 9876543210 | Comment | in the second se | | ; L C | LLLLLLLLL | LLLLLLLLL | Load all zero | 3 | | LL | XXXXXXXXX | LLLLLLLLL | Hold all zero | s | | , L C | нинининин | нинининин | Load all ones | | | ; L L | XXXXXXXXX | нинининин | Hold all ones | | | ; L C | HLHLHLHLHL | HLHLHLHLHL | Load even che | | | ; L L | XXXXXXXXX | HLHLHLHLHL | Hold even che | | | ; L C | LHLHLHLHLH | LHLHLHLHLH | | ckerboard | | L L | XXXXXXXXX | LHLHLHLHLH | Hold odd che | ckerboard | | ; н х | XXXXXXXXX | ZZZZZZZZZZ | Test HI-Z | | | | | | | | | Page | : 1 | | | |------|------------|-------------|-----| | | g cgcgcgc | | C | | /oc | LLLLLLLLL | LLLLLLLHH | | | CLK | XXHLHLHLHL | HLHLHLLLL | HHL | | /LD | LLLLHHLLHH | LLHHLLHHHH | HHH | | D8 | LLLLLHHHH | LLLLHHHHHHH | HHH | | D7 | LLLLLHHHH | HHHHLLLLLL | LLL | | D6 | LLLLLHHHH | LLLLHHHHHHH | HHH | | D5 | LLLLLHHHH | HHHHLLLLLL | LLL | | D4 | LLLLLHHHH | LLLLHHHHHHH | HHH | | D3 | LLLLLHHHH | HHHHLLLLLL | LLL | | D2 | LLLLLHHHH | LLLLHHHHHHH | HHH | | Dl | LLLLLHHHH | HHHHLLLLLL | LLL | | DO | LLLLLHHHH | LLLLHHHHHH | HHH | | Q8 | XXXLLLLHHH | HLLLLHHHHZ | ZZZ | | Q7 | XXXLLLLHHH | HHHHHLLLLZ | ZZZ | | Q6 | XXXLLLLHHH | HLLLLHHHHZ | ZZZ | | Q5 | XXXLLLLHHH | HHHHHLLLLZ | ZZZ | | Q4 | XXXLLLLHHH | HLLLLHHHHZ | ZZZ | | Q3 | XXXLLLLHHH | HHHHLLLLZ | ZZZ | | Q2 | XXXLLLLHHH | HLLLLHHHHZ | ZZZ | | Q1 | XXXLLLLHHH | HHHHHLLLLZ | ZZZ | | QO | XXXLLLLHHH | HLLLLHHHHZ | ZZZ | | | | | | TB01740M 10BitRegister 10BitReg.pds Title Pattern Revision A Author Vincent Coli/Mehrnaz Hada Company Monolithic Memories Inc., Santa Clara, CA Date 1/28/85 :The 10-bit register loads the data (D9-D0) on the rising ;edge of the clock(CLK) into the register(Q9-Q0). The data ;is held in the register until the next positive edge of | /oc | CLK | D9-D0 | Q9-Q0 | Operation | |-----|-----|-------|-------|-----------| | н | x | X | z | HI-Z | | L | С | D | D | Load | | L | L | × | Q | Hold | CHIP 10BitReg PAL20X10 CLK DO D1 D2 D3 D4 D5 D6 D7 D8 D9 GND /OC Q9 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC EQUATIONS | /Q0 := /D0 | | ;Load DO | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | /Q1 := /D1 | | ;Load Dl | | /Q2 := /D2 | | ;Load D2 | | /Q3 := /D3 | | ;Load D3 | | /Q4 := /D4 | | ;Load D4 | | /Q5 := /D5 | | ;Load D5 | | /Q6 := /D6 | | ;Load D6 | | /Q7 := /D7 | and the second of o | ;Load D7 | | /Q8 := /D8 | | ;Load D8 | | /Q9 := /D9 | | ;Load D9 | | | | | SIMULATION TRACE\_ON /OC CLK Q9 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 SETF OC /D9 /D8 /D7 /D6 /D5 /D4 /D3 /D2 /D1 /D0 CLOCKF CLK ;Load all zeros SETF D9 D8 D7 D6 D5 D4 D3 D2 D1 D0 CLOCKF CLK SETF D9 /D8 D7 /D6 D5 /D4 D3 /D2 D1 /D0 CLOCKF CLK SETF /D9 D8 /D7 D6 /D5 D4 /D3 D2 /D1 D0 CLOCKF CLK SETF /OC CLOCKF CLK ;Test HI-Z ;Function Table for PALASM1 ;/OC CLK D9 D8 D7 D6 D5 D4 D3 D2 D1 D0; Q9 Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | ; | Data In | Data Out | Comment | |----------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | ;Control | DDDDDDDDDD | QQQQQQQQQ | | | ;/OC CLK | 9876543210 | 9876543210 | | | ; L C; | LLLLLLLL<br>XXXXXXXXX<br>HHHHHHHHH<br>XXXXXXXXX<br>HLHLHLHL | LLLILLLLL LLEALLLLLL HHHHHHHHHH HHHHHHHHHH HLHLHLHLH LLHLHLHLHLL LHLHLHLHLH LHLHLHLHLH ZZZZZZZZ | Load all zeros Hold all zeros Load all ones Hold all ones Load even checkerboard Hold even checkerboard Load odd checkerboard Hold odd checkerboard Test HI-Z | ### Simulation Results | age | : 1 | | |------|---------------|------------| | | g cg cg | cg cg c | | oc. | LLLLLLLLL | LLLLLHHHHH | | CLK | XXHHLLHLLH | HLLHLLLHHL | | Q9 | XXXLLLLHHH | HHHHLLZZZZ | | Q8 | XXXLLLLHHH | LLLLHHZZZZ | | Q7 | XXXLLLLHHH | HHHHLLZZZZ | | Õ6 | XXXLLLLHHH | LLLLHHZZZZ | | Q5 | XXXLLLLHHH | HHHHLLZZZZ | | Q4 | XXXLLLLHHH | LLLLHHZZZZ | | Ō3 · | XXXLLLLHHH | HHHHLLZZZZ | | Q2 | XXXLLLLHHH | LLLLHHZZZZ | | õī | XXXLLLLHHH | HHHHLLZZZZ | | Q0 | XXXLLLLHHH | LLLLHHZZZZ | | D9 | LLLLLHHHHH | HHLLLLLLLL | | D8 | LLLLLHHHLL | LLHHHHHHHH | | D7 | LLLLLHHHHH | HHLLLLLLLL | | D6 | LLLLLHHHLL | LLHHHHHHHH | | D5 | LLLLLHHHHH | HHLLLLLLLL | | D4 | LLLLLHHHLL | LLHHHHHHHH | | D3 | LLLLLHHHHH | HHLLLLLLLL | | D2 | LLLLLHHHLL | тлинининни | | Dì | LLLLLHHHHH | HHLLLLLLL | | DO | T.T.T.T.HHHLL | тлинининн | | | | | | man along the second se | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Title Barrel Shifter Pattern Barrel-pds Revision A Author Mehrnaz Hada Company Monolithic Memories Inc. Santa Clara, CA | + S3 * S2 * /S1 * /S0 * D15<br>+ S3 * S2 * /S1 * S0 * D0<br>+ S3 * S2 * S1 * /S0 * D1<br>+ S3 * S2 * S1 * /S0 * D1 | ; Shift 12 spaces<br>; Shift 13 spaces<br>; Shift 14 spaces<br>; Shift 15 spaces | | Date 1/15/85 The 16-bit barrel shifter will shift 16 bits of data; (D15-D0) a number of locations into the output pins, as issuedified by the binary encoded input. A compacted | Q4 :- /S3 * /S2 * /S1 * /S0 * D4<br>+ /S3 * /S2 * /S1 * S0 * D5<br>+ /S3 * /S2 * S1 * /S0 * D6<br>+ /S3 * /S2 * S1 * S0 * D7<br>+ /S3 * S2 * /S1 * S0 * D7<br>+ /S3 * S2 * /S1 * /S0 * D8 | ; No shift<br>; Shift 1 space<br>; Shift 2 spaces<br>; Shift 3 spaces<br>; Shift 4 spaces | | <pre>;equation can be used to specify this design. It can be<br/>;specified as following:<br/>;;(Q(J=015) :=</pre> | + /S3 * S2 * /S1 * /S0 * D8<br>+ /S3 * S2 * /S1 * S0 * D9<br>+ /S3 * S2 * S1 * /S0 * D10<br>+ /S3 * S2 * S1 * S0 * D11 | ; Shift 5 spaces<br>; Shift 6 spaces<br>; Shift 7 spaces | | ; OR[K=015](D[(J+K)-((J+K)/16)*16]*BIN[K,I=30]S(I));<br>;Inputs are shown by D. Si are shift amount inputs and | + S3 * /S2 * /S1 * /S0 * D12<br>+ S3 * /S2 * /S1 * S0 * D13<br>+ S3 * /S2 * S1 * S0 * D14<br>+ S3 * /S2 * S1 * S0 * D15 | ; Shift 8 spaces<br>; Shift 9 spaces<br>; Shift 10 spaces<br>; Shift 11 spaces | | 10) are outputs. 16 product terms in each output pair<br>yare directed to one output; thus only 16 out of 32<br>youtput pins are used. | + S3 * S2 * /S1 * /S0 * D0<br>+ S3 * S2 * /S1 * S0 * D1<br>+ S3 * S2 * /S1 * S0 * D1<br>+ S3 * S2 * S1 * /S0 * D2<br>+ S3 * S2 * S1 * S0 * D3 | ; Shift 12 spaces<br>; Shift 13 spaces<br>; Shift 14 spaces<br>; Shift 15 spaces | | CHIP BarrelShift PAL64R32 | | ; No shift | | D7 D6 D5 D4 D3 D2 D1 D0 /PL1 /PB1 GND CLK1 /OC1 Q0 NC Q1 NC Q2 NC Q3 NC Q4 NC Q5 C Q6 NC Q7 NC /OC2 CLK2 VCC /PS2 /PL2 NC | Q5 := /S3 * /S2 * /S1 * /S0 * D5<br>+ /S3 * /S2 * /S1 * S0 * D6<br>+ /S3 * /S2 * S1 * /S0 * D7<br>+ /S3 * /S2 * S1 * S0 * D8<br>+ /S3 * S2 * /S1 * S0 * D9<br>+ /S3 * S2 * /S1 * S0 * D9<br>+ /S3 * S2 * S1 * /S0 * D10<br>+ /S3 * S2 * S1 * /S0 * D11<br>+ /S3 * S2 * S1 * /S0 * D12<br>+ S3 * /S2 * /S1 * /S0 * D13<br>+ S3 * /S2 * /S1 * S0 * D13<br>+ S3 * /S2 * /S1 * S0 * D14 | ; Shift 1 space; Shift 2 spaces; Shift 3 spaces; Shift 4 spaces; Shift 4 spaces; Shift 6 spaces; Shift 7 spaces; Shift 7 spaces; Shift 8 spaces; Shift 9 spaces | | EQUATIONS | + S3 * /S2 * S1 * /S0 * D15 | ; Shift 10 spaces | | Q0 := /S3 * /S2 * /S1 * /S0 * D0 ; No shift<br>+ /S3 * /S2 * /S1 * S0 * D1 ; Shift 1 space | + S3 * /S2 * S1 * S0 * D0<br>+ S3 * S2 * /S1 * /S0 * D1<br>+ S3 * S2 * /S1 * S0 * D2 | ; Shift 11 spaces<br>; Shift 12 spaces | | + /S3 * /S2 * S1 * /S0 * D2 ; Shift 2 spaces | + S3 * S2 * /S1 * S0 * D2<br>+ S3 * S2 * S1 * /S0 * D3<br>+ S3 * S2 * S1 * S0 * D4 | ; Shift 13 spaces<br>; Shift 14 spaces | | + /S3 * /S2 * S1 * S0 * D3 ; Shift 3 spaces<br>+ /S3 * S2 * /S1 * /S0 * D4 ; Shift 4 spaces | | ; Shift 15 spaces | | + /S3 * S2 * /S1 * S0 * D5 ; Shift 5 spaces<br>+ /S3 * S2 * S1 * /S0 * D6 ; Shift 6 spaces<br>+ /S3 * S2 * S1 * S0 * D7 ; Shift 7 spaces<br>+ /S3 * S2 * /S1 * S0 * D7 ; Shift 7 spaces<br>+ S3 * /S2 * /S1 * S0 * D8 ; Shift 8 spaces<br>+ S3 * /S2 * S1 * S0 * D10 ; Shift 10 spaces<br>+ S3 * /S2 * S1 * S0 * D10 ; Shift 10 spaces<br>+ S3 * /S2 * S1 * S0 * D11 ; Shift 11 spaces | Q6:=\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \) D6<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \) D7<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \) D8<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S0<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S0<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1<br>\( \)/S3 \( \)/S2 \( \)/S1 \( \)/S0 \( \)/S1 | ; No shift; Shift 1 space; Shift 2 spaces; Shift 3 spaces; Shift 4 spaces; Shift 5 spaces; Shift 5 spaces | | + S3 * S2 * /S1 * /S0 * D12 ; Shift 12 spaces<br>+ S3 * S2 * /S1 * S0 * D13 ; Shift 13 spaces<br>+ S3 * S2 * S1 * /S0 * D14 ; Shift 14 spaces<br>+ S3 * S2 * S1 * S0 * D15 ; Shift 15 spaces | + S3 * /S2 * /S1 * /S0 * D14<br>+ S3 * /S2 * /S1 * S0 * D15<br>+ S3 * /S2 * S1 * /S0 * D0 | ; Shift 7 spaces<br>; Shift 8 spaces<br>; Shift 9 spaces<br>; Shift 10 spaces | | Q1 := /S3 * /S2 * /S1 * /S0 * D1 ; No shift<br>+ /S3 * /S2 * /S1 * S0 * D2 ; Shift 1 space<br>+ /S3 * /S2 * S1 * /S0 * D3 ; Shift 2 spaces<br>+ /S3 * /S2 * S1 * S0 * D4 ; Shift 3 spaces | + \$3 * /\$2 * \$1 * \$0 * D1<br>+ \$3 * \$2 * /\$1 * /\$0 * D2<br>+ \$3 * \$2 * /\$1 * \$0 * D3<br>+ \$3 * \$2 * \$1 * /\$0 * D4<br>+ \$3 * \$2 * \$1 * /\$0 * D4<br>+ \$3 * \$2 * \$1 * \$0 * D5 | ; Shift 11 spaces<br>; Shift 12 spaces<br>; Shift 13 spaces<br>; Shift 14 spaces<br>; Shift 15 spaces | | + /S3 * S2 * /S1 * /S0 * D5 ; Shift 4 spaces<br>+ /S3 * S2 * /S1 * S0 * D6 ; Shift 5 spaces | 07 := /S3 * /S2 * /S1 * /S0 * D7 | ; No shift | | + /S3 * S2 * S1 * S0 * D8 ; Shift 7 spaces | + /S3 * /S2 * /S1 * S0 * D8<br>+ /S3 * /S2 * S1 * /S0 * D9<br>+ /S3 * /S2 * S1 * S0 * D10 | ; Shift 1 space<br>; Shift 2 spaces | | + S3 * /S2 * /S1 * /S0 * D9 ; Shift 8 spaces<br>+ S3 * /S2 * /S1 * S0 * D10 ; Shift 9 spaces | + /S3 * /S2 * S1 * S0 * D10<br>+ /S3 * S2 * /S1 * /S0 * D11 | ; Shift 3 spaces<br>; Shift 4 spaces | | + S3 * /S2 * S1 * /S0 * D11 ; Shift 10 spaces | + /S3 * S2 * /S1 * S0 * D12<br>+ /S3 * S2 * S1 * /S0 * D13 | ; Shift 5 spaces<br>; Shift 6 spaces | | + S3 * S2 * S1 * S0 * D12 ; Shift 12 spaces<br>+ S3 * S2 * /S1 * S0 * D14 ; Shift 13 spaces<br>+ S3 * S2 * S1 * /S0 * D15 ; Shift 14 spaces<br>+ S3 * S2 * S1 * S0 * D0 ; Shift 15 spaces | + /S3 * S2 * S1 * S0 * D14<br>+ S3 * /S2 * /S1 * /S0 * D15 | ; Shift 7 spaces<br>; Shift 8 spaces | | + S3 * S2 * S1 * /S0 * D15 ; Shift 14 spaces<br>+ S3 * S2 * S1 * S0 * D0 ; Shift 15 spaces | + S3 * /S2 * /S1 * S0 * D0<br>+ S3 * /S2 * S1 * /S0 * D1 | ; Shift 9 spaces<br>; Shift 10 spaces | | | + S3 * /S2 * S1 * S0 * D2<br>+ S3 * S2 * /S1 * /S0 * D3 | ; Shift 11 spaces<br>; Shift 12 spaces | | + /S3 * /S2 * /S1 * S0 * D3 ; Shift 1 space<br>+ /S3 * /S2 * S1 * /S0 * D4 ; Shift 2 spaces | + S3 * S2 * /S1 * S0 * D4<br>+ S3 * S2 * S1 * /S0 * D5 | ; Shift 13 spaces | | | + S3 * S2 * S1 * S0 * D6 | ; Shift 14 spaces<br>; Shift 15 spaces | | + /S3 * S2 * /S1 * S0 * D7 ; Shift 5 spaces<br>+ /S3 * S2 * S1 * /S0 * D8 ; Shift 6 spaces | Q8 := /S3 * /S2 * /S1 * /S0 * D8 | ; No shift | | + /S3 * S2 * S1 * S0 * D9 | + /S3 * /S2 * /S1 * S0 * D9<br>+ /S3 * /S2 * S1 * /S0 * D10 | ; Shift 1 space<br>; Shift 2 spaces | | + \$3 * \\$2 * \\$1 * \\$0 * Dl0 | | ; Shift 3 spaces<br>; Shift 4 spaces | | | + /S3 * S2 * S1 * /S0 * D14 | ; Shift 5 spaces<br>; Shift 6 spaces | | + \$3 * \$2 * \\$1 * \\$0 * D14 ; Shift 12 spaces<br>+ \$3 * \$2 * \\$1 * \$0 * D15 ; Shift 13 spaces<br>+ \$3 * \$2 * \\$1 * \\$0 * D15 ; Shift 13 spaces<br>+ \$3 * \$2 * \$1 * \\$0 * D0 ; Shift 14 spaces | + /S3 * S2 * S1 * S0 * D15<br>+ S3 * /S2 * /S1 * /S0 * D0 | ; Shift 7 spaces<br>; Shift 8 spaces | | + S3 * S2 * S1 * S0 * D1 ; Shift 15 spaces | + S3 * /S2 * /S1 * S0 * D1<br>+ S3 * /S2 * S1 * /S0 * D2 | ; Shift 9 spaces<br>; Shift 10 spaces | | Q3 := /S3 * /S2 * /S1 * /S0 * D3 ; No shift<br>+ /S3 * /S2 * /S1 * S0 * D4 ; Shift 1 space | + S3 * /S2 * S1 * S0 * D3<br>+ S3 * S2 * /S1 * /S0 * D4 | ; Shift 11 spaces<br>; Shift 12 spaces | | + /S3 * /S2 * S1 * /S0 * D5 ; Shift 2 spaces | + S3 * S2 * S1 * /S0 * D6 | ; Shift 13 spaces<br>; Shift 14 spaces | | + /S3 * S2 * /S1 * /S0 * D7 ; Shift 4 spaces | + S3 * S2 * S1 * S0 * D7 | ; Shift 15 spaces | | + /S3 * S2 * S1 * /S0 * D9 ; Shift 6 spaces | + /83 * /82 * /81 * 80 * 010 | ; No shift<br>; Shift 1 space | | + S3 * /S2 * /S1 * /S0 * D11 : Shift 8 spaces | + /S3 * /S2 * S1 * /S0 * D11<br>+ /S3 * /S2 * S1 * S0 * D12 | ; Shift 2 spaces<br>; Shift 3 spaces | | + S3 */S2 */S1 * S0 * D12 ; Shift 9 spaces<br>+ S3 */S2 * S1 */S0 * D13 ; Shift 10 spaces<br>+ S3 */S2 * S1 * S0 * D14 ; Shift 11 spaces | + /S3 * S2 * /S1 * S0 * D14 | ; Shift 4 spaces<br>; Shift 5 spaces | | " / Da DV - Die // Smitt il spaces | + /S3 * S2 * S1 * /S0 * D15 | ; Shift 6 spaces | | | | 1001/00M | ``` /S0 * D3 S0 * D4 /S0 * D5 S0 * D6 /S0 * D7 S0 * D8 /S0 * D9 S0 * D10 /S0 * D11 /S0 * D12 /S0 * D13 S0 * D14 /S1 * /S0 /S1 * S0 S1 * S0 S1 * S0 S1 * S0 /S1 * S0 S1 * S0 /S1 * S0 /S1 * S0 /S1 * S0 /S1 * S0 /S1 * S0 /S1 * S0 * S0 * /S0 * S0 * /S0 * S0 * /S0 * S0 * /S0 /S3 S3 S3 S3 S3 ; Shift 4 spaces ; Shift 5 spaces ; Shift 6 spaces ; Shift 7 spaces ; Shift 8 spaces $2 /$2 /$2 /$2 /$2 Shift 7 Shift 8 Shift 9 S2 S2 S2 S2 /S2 ****** ***** $1 /$1 /$1 $1 $1 /$1 /$1 $1 * D0 * D1 * D2 * D3 * D4 * D5 * D6 * D7 * D8 spaces /S3 /S3 /S3 /S3 S3 S3 ****** spaces spaces Shift Shift D2 D3 D4 D5 D6 D7 D8 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces Shift 8 spaces Shift 10 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces S2 S2 /S2 /S2 53 S3 S3 S3 S3 S3 /S2 S2 S2 S2 S2 S2 S2 S2 No shift Shift 1 space Shift 2 spaces Shift 3 spaces Shift 4 spaces Shift 5 spaces Shift 6 spaces Shift 7 spaces Shift 8 spaces Shift 10 Spaces Shift 10 Spaces Shift 11 spaces Q10 :=/S3 /S1 /S1 S1 S1 /S1 S1 S1 /S1 S1 /S1 /S1 S1 S1 ********* ********* ********* /S0 /S0 /S0 /S0 /S0 /S0 /S0 /S0 ********* D10 D11 D12 D13 D14 D15 D0 D1 D2 /83 /83 /83 /S3 /S3 /S3 /S3 S3 S3 S3 S3 S3 S3 TRACE_ON CLK1 CLK2 CLK3 CLK4 OC1 OC2 OC3 OC4 PL1 PL2 PL3 PL4 PS1 PS2 PS3 PS4 S3 S2 S1 S0 D0 11 D2 D3 D4 D5 D6 D7 D8 D9 D10 D11 D12 D13 D14 D15 Q0 Q1 Q2 Q3 Q4 Q5 Q Q70 Q11 Q12 Q1 D3 D4 D5 D6 D7 D8 50 /S0 S0 /S0 Shift 10 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces SETF OC1 OC2 OC3 OC4 /PS1 /PS2 /PS3 /PS4 /PL1 /PL2 /PL3 /PL4 /S3 /S2 /S1 /SO DO /D1 /D2 /D3 /D4 /D5 /D6 /D7 /D8 /D9 /D10 /D11 /D12 /D13 /D14 /D15 53 52 50 De CLOCKF CLK1 CLK2 CLK3 CLK4 :Clock /52 /81 D11 No shift Shift 1 space Shift 2 spaces Shift 3 spaces Shift 4 spaces Shift 5 spaces Shift 6 spaces Shift 7 spaces Shift 7 spaces Shift 9 spaces Shift 10 spaces Shift 11 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 14 spaces Shift 15 spaces 011 :=/53 ********** /S0 /S0 /S0 /S0 /S0 /S0 D11 D13 D14 D15 D0 D1 * D1: * D1: * D1: * D1: * D0 * D1: * D2 * D3 * D4 /S3 /S3 /S3 /S3 /S3 /S3 /S3 S3 /S2 /S2 /S2 S2 S2 S2 /S2 /S2 /S2 ********* /S1 S1 /S1 /S1 /S1 S1 ***** ;Shift 1 SETF /S3 /S2 /S1 S0 CLOCKF CLK1 CLK2 CLK3 CLK4 SETF /S3 /S2 S1 /S0 CLOCKF CLK1 CLK2 CLK3 CLK4 :Shift 2 SO SETF /S3 /S2 S1 S0 CLOCKF CLK1 CLK2 CLK3 CLK4 ;Shift 3 SO /S1 /S0 /S0 /S0 /S0 D5 D6 D7 D8 D9 53 53 /S2 /S2 S1 S1 * SETF /S3 S2 /S1 /S0 CLOCKF CLK1 CLK2 CLK3 CLK4 * D6 * D7 * D8 * D9 * D10 S2 S2 S2 /S1 /S1 S1 S1 S3 S3 SETF /S3 S2 /S1 S0 CLOCKF CLK1 CLK2 CLK3 CLK4 ;Shift 5 53 so * /S2 * | S1 * | S0 * | D10 * /S2 * | S1 * | S0 * | D12 * /S2 * | S1 * | S0 * | D13 * /S2 * | S1 * | S0 * | D14 * /S2 * | S1 * | S0 * | D14 * /S2 * | S1 * | S0 * | D14 * | S2 * | S1 * | S0 * | D14 * | S2 * | S1 * | S0 * | D2 * | S2 * | S1 * | S0 * | D2 * | S2 * | S1 * | S0 * | D2 * | S2 * | S1 * | S0 * | D3 * | /S2 * | S1 * | S0 * | D4 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D6 * | /S2 * | S1 * | S0 * | D1 * | /S2 * | S1 * | S0 * | D1 :=/S3 * + /S3 * + /S3 * - No shift Shift 1 space Shift 2 spaces Shift 3 spaces Shift 4 spaces Shift 5 spaces Shift 6 spaces Shift 7 spaces Shift 8 spaces Shift 9 spaces Shift 10 spaces SETF /S3 S2 S1 /S0 CLOCKF CLK1 CLK2 CLK3 CLK4 ;Shift 6 Q12 :Shift 7 SETF /S3 S2 S1 S0 CLOCKF CLK1 CLK2 CLK3 CLK4 SETF S3 /S2 /S1 /S0 CLOCKF CLK1 CLK2 CLK3 CLK4 ;Shift 8 ;The 16-bit barrel shifter will shift 16 bits of data ;(D15-D0) a number of locations into the output pins, as ;specified by the binary encoded input. A compacted ;equation can be used to specify this design. It can be ;specified as following: Shift 10 spaces Shift 11 spaces S3 S3 * * * * * * Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces S3 S3 ;Q[J=0..15] := ; OR[K=0..15]{D[(J+K)-((J+K)/16)*16]*BIN[K,I=3..0]S(I)} No shift Shift 1 space Shift 2 spaces Shift 3 spaces Shift 4 spaces Shift 5 spaces Shift 6 spaces Shift 7 spaces Shift 10 spaces Shift 10 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces Shift 15 spaces :=/$3 + /$3 + /$3 + /$3 + /$3 + /$3 + /$3 /S2 /S2 /S2 /S2 S2 S2 S2 * D11 * D14 * D15 * D0 * D1 * D2 * D3 * D4 * D5 * D6 * D7 * D8 * D9 * D10 * D10 * D10 ********** ********** ;Inputs are shown by D. Si are shift amount inputs and ;Qi are outputs. 16 product terms in each output pair ;are directed to one output; thus only 16 out of 32 ;output pins are used. /83 S2 Simulation Results /S2 /S2 53 S3 /S2 /S2 /S2 S2 S2 S2 S2 S2 S3 S3 S3 S3 S3 S3 No shift Shift 1 space Shift 2 spaces Shift 3 spaces Shift 4 spaces Shift 5 spaces Shift 6 spaces Shift 7 spaces /50 D14 /S2 /S2 /S2 /S2 S2 S2 S2 /S1 /S1 /S1 /S1 /S1 /S1 /S1 ***** /S3 /S3 /S3 /S3 /S3 /S3 /S3 /S0 /S0 /S0 /S0 D15 ***** DO Dì HHHHHLLLIN LLLLLHHHHH LHHHLLLLH D2 50 /S0 S0 /S0 * D3 * D4 * D5 * D6 * D7 * D8 * D9 * D10 * D11 * D12 * D13 ``` Shift 8 spaces Shift 9 spaces Shift 9 spaces Shift 10 spaces Shift 11 spaces Shift 12 spaces Shift 13 spaces Shift 14 spaces Shift 15 spaces ; No shift ; Shift 1 space ; Shift 2 spaces ; Shift 3 spaces /53 /S2 S3 S3 S3 /S2 /S2 \*\*\*\*\* \* \* \* \* \* \* /S2 S2 S2 S2 S2 S2 S3 S3 S3 S3 \* \* \* \* \* \* \* /S2 /S2 /S2 /S3 /S3 /S3 \* /S0 \* S0 \* /S0 \* S0 \* /S0 \* S0 \* S0 /S1 /S1 /S1 /S1 /S1 S1 /S1 \* /S0 \* D15 /S1 \* S0 \* D0 S1 \* /S0 \* D1 S1 \* S0 \* D2 | TITLE<br>PATTERN | 16-BIT ADDRESSABLE REGISTER ADREG16.PDS | |-------------------------------|-------------------------------------------------------------------| | REVISION<br>AUTHOR<br>COMPANY | | | DATE | 2/11/85 The 16-bit addressable register loads one of 16 registers | CHIP ADREGI6 PALJ2R16 Q0 Q1 Q2 Q3 /E1 NC NC A0 A1 VCC A2 A3 DATA NC /PRLD2 CLK2 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 /E2 NC NC NC NC GND NC NC NC NC /PRLD1 CLK1 Q12 Q13 Q14 Q15 | EQUATI | CONS | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | Q0 | := A0 | ;hold<br>;hold<br>;hold<br>;hold | | Q1 | + /A0*/A1*/A2*/A3*DATA<br>:= /A0 | ;load<br>;hold<br>;hold<br>;hold | | Q2 | + \(\lambda^{\lambda}\) | ;load<br>;hold<br>;hold<br>;hold | | Q3 | + /A0* A1*/A2*/A3*DATA := /A0 | ;load ;hold ;hold ;hold ;hold ;load | | Q4 | := A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q5 | := /A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q6 | := A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q7 | := /A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q8 | := A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q9 | := /A0 | thold | | Q10 | := A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Qll | := /A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q12 | := A0 | ;hold<br>;hold<br>;hold<br>;hold<br>;load | | Q13 | := /A0 +Q13 | ;hold | := A0 + /A1 + /A2 | | +<br>+ /A0* A1* A2* | A3+Q14<br>A3+DATA | ;hold<br>;load | |-----|---------------------|-------------------|----------------| | Q15 | := /A0 | <b>*Q15</b> | hold | | | + /Al | *Q15 | hold | | | + /A2 | *Q15 | thold | | | + | /A3*Q15 | hold | | | + A0* A1* A2* | A3*DATA | ;load | | | | | | SIMULATION TRACE\_ON QO Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15 A0 A1 A2 A3 DATA SETF F1 E2 /DATA /PRID1 /PRID2 SETF /A0 /A1 /A2 /A3 CLOCKF CLK1 CLK2 SETF A0 /A1 /A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 /A2 /A3 CLOCKF CLK1 CLK2 SETF A0 A1 /A2 /A3 CLOCKF CLK1 CLK2 SETF A0 /A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 /A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 /A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 A2 A3 CLOCKF CLK1 CLK2 SETF /A0 /A1 A2 A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 A3 CLOCKF CLK1 CLK2 SETF /A0 A1 A2 A3 CLOCKF CLK1 CLK2 SETF A0 ### **Simulation Results** | Page | : 1 | | | | |------|-------------|------------|------------|----------| | | g g cgcgcg | cgcgcgcgcg | cgcgcgcgcg | cgcgcgc | | QO | XXXXLLLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLIH | | Ql | XXXXXXLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLLL | | Q2 | XXXXXXXXLL | LLLLLLLLL | LILLLLLLL | LLLLLLL | | Q3 | XXXXXXXXX | LLLLLLLLL | LLLLLLLLL | LLLLLLL | | Q4 | XXXXXXXXX | XXLLLLLLL | LLLLLLLLL | LLLLLL | | 05 | XXXXXXXXXX | XXXXLLLLLL | LILLIALIA | LLLLLLL | | Q6 | XXXXXXXXXX | XXXXXXLLLL | LILLILLIA | LLLLLLL | | 07 | XXXXXXXXXX | XXXXXXXXIT | LILLILLIA | LILLLLL | | Q8 | XXXXXXXXXX | | LLLLLLLLL | | | 09 | XXXXXXXXXX | | XXLLLLLLL | | | 010 | XXXXXXXXXX | | XXXXLLLLLL | | | 011 | XXXXXXXXXXX | | XXXXXXLLLL | | | 012 | XXXXXXXXXXX | | XXXXXXXXX | | | 013 | XXXXXXXXXX | | XXXXXXXXXX | | | 014 | XXXXXXXXXXX | | XXXXXXXXXX | | | 015 | XXXXXXXXXX | | XXXXXXXXXX | | | AO. | KATTINHITA | | HITHHITH | | | | XXLLLLLHHH | | | | | λl | XXIIIIIIII | HLLLLHHHHL | | | | A2 | | LHHHHHHHL | | HHHHHLL | | A3 | XXLLLLLLL | | | | | DAT | LILLILLILL | LILLILLIA | TTTTTTTT | LILLLIHH | TB01780N ;hold ;hold ;hold # **XPLOT Output** | PALASM XPLOT, V2.06 - BETA RELEASE<br>(C) - COPYRIGHT MONLITHIC MEMORIES INC., 1984 | | | | | | | | | |-------------------------------------------------------------------------------------|-------------|------------------------------------------------------|----------------------|----------------------|----------------------|---------------------|----------------------|----------------| | Titl | e : 10 | -BIT Addr | essable R | egister | | | | | | Patt | ern : Al | 5-BIT Addr<br>OREG16.PDS<br>ohn Birkne | | | | | | | | Auth | or : Jo | ohn Birkne<br>onolithic | Memories | Tno | | | | | | Date | : 2, | /11/85 | Nemot 169 | The | | | | | | | | | | | | | | | | | 2R16<br>G16 | | | | | | | | | | 01234567 | 111111<br>89012345 | 11112222<br>67890123 | 22222233<br>45678901 | 33333333<br>23-56789 | 4444444<br>01234567 | 44555555<br>89012345 | 55556<br>67890 | | 0 | | | | | | | | -x | | 2 | X | | | | | | | | | 4 | -xx | x | | | | | | xx | | 5 | XXXXXXXX XXXXX | | 7 | XXXXXXXX | XXXXXXX | XXXXXXXX | XXXXXXX | XXXXXXXX | XXXXXXX | XXXXXXX | XXXXX | | 9 | XXXXXXXX XXXXX | | 10 | XXXXXXXX | XXXXXXXX | xxxxxxx | XXXXXXX | xxxxxxx | xxxxxxx | xxxxxxx | XXXXX | | 12 | X | | | | | | | x | | 13 | X | X<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXX | | | | | | x | | | | | | | | | | | | 16 | | | | | | | X- | -x | | 18 | X | | | | | | x- | | | 20 | x | XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX<br>XXXX | | | | | x- | x | | 21<br>22 | XXXXXXXX XXXXX | | 23 | XXXXXXX XXXXX | | 24<br>25 | XXXXXXXX XXXXX | | 26<br>27 | XXXXXXXX | XXXXXXXX | xxxxxxx | xxxxxxx | xxxxxxx | XXXXXXX | xxxxxxx | XXXXX | | 28<br>29 | x | | | | | | x | | | 30 | X | | | | | | X | x | | 31 | | | | | | | x | X | | 32<br>33 | | <br>XXXXXXXX<br>XXXXXXXXX<br>XXXXXXXXX<br>XXXXXX | | | | X- | | -x | | 34<br>35 | -x | | | | | X- | | | | 36 | xx | x | | | | | | xx | | 37<br>38 | XXXXXXXX XXXXX | | 39<br>40 | XXXXXXXX XXXXX | | 41 | XXXXXXXX XXXXX | | 42 | XXXXXXXX | XXXXXXXX | xxxxxxx | XXXXXXX | xxxxxxx | XXXXXXXX | xxxxxxxx | -xx | | 44 | X | | | | | X | | | | 46 | | X | | | | x | | | | 47 | | | | | | x | | X | | 48<br>49 | | | | | X- | | | -xx | | 50<br>51 | -XY | | | | X- | | | | | 52<br>53 | XX | X | ******** | | ******** | ******** | ******** | X | | 54 | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXX | XXXXXXX | XXXXXXXX | XXXXXXXX | XXXXX | | 55<br>56 | XXXXXXXX XXXXX | | 57<br>58 | XXXXXXXX XXXXX | | 59 | XX | X | ****** | ******** | | | | -X | | 60<br>61 | -xx | | | | x | | | | | 62<br>63 | | X<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXX | | | x | | | xX | | 64 | | | | y_ | | | | -x | | 65 | | | | X- | | | | | | 67 | x | | | X- | | | | | | 68<br>69 | XXXXXXXX | XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX<br>XXXXXXXX | xxxxxxx | XXXXXXXX | xxxxxxx | xxxxxxx | xxxxxxx | XXXXX | | 70 | XXXXXXXX XXXXX | | 72 | XXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXX | | 73 | XXXXXXXX XXXXX | | 75<br>76 | -xx | X | | | | | | -xx | | 77 | х | | | x | | | | | | 78<br>79 | | | | x | | | | x | | 80 | | | | | | | | | | 81 | X | | x- | | | | | X | | 83 | x | | x- | | | | | | | 84 | -xx | XXXXXXXX | XXXXXXX | XXXXXXX | XXXXXXXX | xxxxxxx | xxxxxxx | XXXXX | | 86 | XXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXX | | 88 | XXXXXXX | XXXXXXXX | XXXXXXX | XXXXXXX | xxxxxxx | XXXXXXX | XXXXXXX | XXXXX | | 90 | XXXXXXX | ************************************** | XXXXXXXX | XXXXXXX | XXXXXXXX | XXXXXXXX | XXXXXXXX | XXXXX | | 92 | v | | V | | | | | | | 93 | X | | x | | | | | | | 95 | | | x | | | | | x | | | | | | | | | | | | 96 | | | | | | | | -x | |-----|----------|---------|---------|---------|---------|---------|---------|-------| | 97 | | X- | | | | | | | | 98 | -X | X- | | | | | | | | | X | X- | | | | | | | | | | | | | | | | | | 101 | XXXXXXX XXXXX | | 102 | XXXXXXX XXXXX | | | | | XXXXXXX | | | | | | | 104 | XXXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXXXX | XXXXX | | | | | XXXXXXX | | | | | | | 106 | XXXXXXX XXXXX | | 107 | xx | X | | | | | | -xx | | 108 | X | X | | | | | | | | 109 | -X | X | | | | | | | | 110 | | X | | | | | | | | 111 | | X | | | | | | X | | | | | | | | | | | | 112 | X- | | | | | | | -x | | 113 | X- | | | | | | | X | | 114 | -xx- | | | | | | | | | 115 | X-X- | | | | | | | | | 116 | xx | X | | | | | | X | | | | | XXXXXXX | | | | | | | | | | XXXXXXX | | | | | | | | | | XXXXXXX | | | | | | | | | | XXXXXXX | | | | | | | | | | XXXXXXX | | | | | | | 122 | XXXXXXX XXXXX | | 123 | xx | X | | | | | | -X | | 124 | x-x | | | | | | | | | 125 | -xx | | | | | | | | | 126 | x | | | | | | | x | | 127 | X | | | | | | | X | | | | | | | | | | | OUTPUT PINS: 111222223334 1234789012347890 POLARITY FUSE: ------ OUTPUT BANK: 4-40 17-24 FLUSH FUSE: X X TOTAL FUSES BLOWN: 5008 TB01790 ### State Machine Design Example Figure 1 illustrates a simple traffic intersection consisting of two one-way streets, direction 1 and direction 2. Each direction has a signal consisting of red, yellow, and green lamps which are activated with appropriately named active high signals. Also each direction has a sensor which provides an active high signal indicating the presence of an oncoming vehicle. Our controller is to manage this intersection with the sensors as inputs and the lamps as outputs, as shown in Figure 2. Figure 1. Traffic Intersection Figure 2 also includes the system clock and an initialize (or reset) signal, which drives the controller to a predefined initial state. This raises two important issues in designing sequential logic with PAL devices. First, all circuit implementations of sequential logic with PAL devices are totally synchronous. This implies that all state variables (flip-flops) change at the same time, precisely after the rising edge of the clock. Second, PAL sequential logic designs should include a means for initialization to implement test programs and ensure reliable circuit operation. The specifics of the controller operations are detailed with a state diagram shown in Figure 3. Figure 2 Figure 3. State Diagram — Traffic Signal Controller Each circle in Figure 3 represents a stable state, i.e. an output configuration lasting at least one clock cycle. Inside the circles is the name of the state (S0 – S7) and the outputs associated with that state. For the sake of simplicity in the state diagram, the transitions involving INIT are omitted; INIT simply drives the circuit to S0 from any state, regardless of other inputs. Since RED1 = /RED2, RED1 is implemented with one flip-flop and RED2 with an external inverter. ``` TRAFFIC SIGNAL CONTROLLER TRAFFIC1.PDS REVISION KELVIN CHOW COMPANY MONOLITHIC MEMORIES INC., SANTA CLARA 2/28/85 CHIP TRAFFIC PALLERPS CLK SEN1 SEN2 INIT NC NC NC NC NC GND /OE Q2 Q1 Q0 R1 Y1 G1 Y2 G2 VCC STRING I1 ' /SEN1*/SEN2*/INIT STRING I2 ' /SEN1*SEN2*/INIT STRING I3 ' SEN1*/SEN2*/INIT STRING I4 ' SEN1*SEN2*/INIT STRING I5 ' INIT STATE = BIN(4)(R1,Y1,G1,Y2,G2) = BIN(4)(R1,Y1,G1,Y2,G2) = BIN(4)(R1,Y1,G1,Y2,G2) = BIN(8)(R1,Y1,G1,Y2,G2) = BIN(8)(R1,Y1,G1,Y2,G2) = BIN(17)(R1,Y1,G1,Y2,G2) = BIN(17)(R1,Y1,G1,Y2,G2) = BIN(17)(R1,Y1,G1,Y2,G2) = BIN(18)(R1,Y1,G1,Y2,G2) SO S1 S2 S3 S4 S5 EQUATIONS = 11*$1 + 12*$2 + 13*$0 + 14*$1 + 15*$0 = 11*$2 + 12*$2 + 13*$2 + 14*$2 + 15*$0 = 11*$3 + 12*$3 + 13*$3 + 14*$3 + 15*$0 = 11*$4 + 12*$4 + 13*$4 + 14*$4 + 15*$0 SO S2 S3 - 11*54 + 12*54 + 13*56 + 14*55 = 11*55 + 12*54 + 13*56 + 14*55 = 11*56 + 12*56 + 13*56 + 14*56 = 11*57 + 12*57 + 13*57 + 14*57 = 11*50 + 12*50 + 13*50 + 14*50 S4 I5*S0 + I5*S0 + I5*S0 S6 57 SIMULATION TRACE ON CLK INIT SEN1 SEN2 R1 Y1 G1 Y2 G2 SETF OE INIT CLOCKE CLOCKE CHECK /R1 /Y1 G1 /Y2 /G2 SETF /INIT /SEN1 /SEN2 CLOCKE SETF SEN1 /SEN2 CHECK /R1 /Y1 G1 /Y2 /G2 SETF /SEN1 SEN2 CLOCKF CHECK /R1 /Y1 G1 /Y2 /G2 SETF SEN1 SEN2 CLOCKF CHECK /R1 Y1 /G1 /Y2 /G2 SETF /SEN1 /SEN2 CLOCKF CHECK R1 /Y1 /G1 /Y2 G2 SETF /SEN1 SEN2 CLOCKE CHECK R1 G2 CLOCKF CHECK R1 G2 CLOCKE CHECK R1 /Y1 /G1 Y2 /G2 CHECK /R1 /Y1 G1 /Y2 /G2 CLOCKE CLOCKE CLOCKE ; This simulation was done using the alpha release version ``` # **Simulation Results** | 10.0 | g c cg c | g cg cg cg | cgccc | ccc c | |------|------------|------------|------------|----------| | CLK | | LHLLHLLHLL | | | | INIT | | LLLLLLLLL | LLLLLLLLL | LLLLLLL | | SEN1 | XXXXXXXLLL | HHHLLLHHHL | LLLLLLLLL | LLLLLLL | | SEN2 | XXXXXXXLLL | LLLHHHHHHL | LLHHHHHHHH | нининини | | Rl | XXXXXLLLLL | LLLLLLLLL | ГИНИНИНИНИ | LLLLLHH | | Yl | XXXXXLLLLL | LLLLLLLHH | HLLLLLLLL | LLLLHHLL | | G1 | хххххиннин | HHHHHHHLL | LLLLLLLLL | HHHHLLLL | | Y2 | XXXXXLLLLL | LLLLLLLLL | LLLLLLLHH | LLLLLLL | | G2 | XXXXXLLLLL | LLLLLLLLL | LHHHHHHHLL | LLLLLHH | # **Logic Symbol** TB01810M ; of Palasm2 software. ### State Machine Design Example A typical control logic problem is the memory-to-processor handshake on memory transfer used in many computer architectures. The processor makes a transfer request by activating a request line (REQ) and specifies a read or write operation on a Read/Write line (R/W). During a read operation, the processor waits for a Data Available signal at which time the data bus is sampled and the request line lowered, thus completing the cycle. During a write operation, the processor places data on the bus and waits for a Write Complete signal after the write cycle is finished. Upon WAIT REQ • RW • ADDR REQ • RW • ADDR REQ + ADDR WRITE1 READ1 COUNT READ2 READ3 COUNT REQ • RW • ADDR REQ + RW + ADDR COUNTS WRITE2 REQ • RW • ADDR WRITE3 REQ + RD + ADDR Figure 1. State Diagram - Memory Handshake Logic write complete, the request line is lowered, hence completing the cycle. Table 1 shows the state assignments and the appropriate outputs. The state diagram is shown in Figure 1. Also the handshaking operation is illustrated in the timing diagram of Figure 2. The memory-board logic to implement this function may be designed with gates and edge-triggered flip-flops as shown in Figure 3. This particular design would require about five SSI/MSI packages, but the same design can be implemented by a single PAL16RP6. The PAL design specification using state equations is shown on the next page. | STATE | DOUT | DA | WE | wc | CO | C1 | |--------|------|-----|----|----|----|----| | WAIT | 0 | 0 | 0 | 0 | 0 | 0 | | READ1 | 1 | 0 | 0 | 0 | 0 | 0 | | READ2 | 1 | . 1 | 0 | 0 | 0 | 0 | | READ3 | 0 | 0 | 0 | 0 | 0 | 0 | | COUNT1 | 0 | 0 | 1 | 0 | 1 | 0 | | COUNT2 | 0 | 0 | 1 | 0 | 0 | 1 | | COUNT3 | 0 | 0 | 1 | 0 | 1 | 1 | | WRITE1 | 0 | 0 | 1 | 0 | 0 | 0 | | WRITE2 | 0 | 0 | 1 | 1 | 0 | 0 | | WRITE3 | 0 | 0 | 0 | 1 | 0 | 0 | # **Memory Handshake Logic** Figure 2. Memory Handshake Timing Figure 3. Memory Handshake Logic ``` MEMORY HANDSHAKE LOGIC PATTERN MEMORY1.PDS A KELVIN CHOW AUTHOR COMPANY MONOLITHIC MEMORIES INC., SANTA CLARA, CA 2/28/85 CHIP MEMORY PAL16RP6 CLK ADDR1 ADDR2 ADDR3 ADDR4 REQ RW INIT NC GND /OE NC /WC C1 CO /WE /DA /DOUT NC VCC STRING I1 'REQ*RW*ADDR1*ADDR2*ADDR3*ADDR4*/INIT' STRING I2 'REQ*/RW*ADDR1*ADDR2*ADDR3*ADDR4*/INIT' STRING I3 '/REQ*/ADDR1*ADDR2*ADDR3*/ADDR4' /NITI' STRING I4 '(/REQ*/RW*/ADDR1*/ADDR2*/ADDR3*/ADDR4) */INIT' STRING I5 'INIT' STATE = BIN[0](DOUT,DA,WE,WC,CO,C1) = BIN[32](DOUT,DA,WE,WC,CO,C1) = BIN[48](DOUT,DA,WE,WC,CO,C1) = BIN[0](DOUT,DA,WE,WC,CO,C1) = BIN[0](DOUT,DA,WE,WC,CO,C1) = BIN[0](DOUT,DA,WE,WC,CO,C1) WAIT READ1 READ2 READ3 WRITEL = BIN[9](DOUT,DA,WE,WC,CO,C1) = BIN[1](DOUT,DA,WE,WC,CO,C1) = BIN[12](DOUT,DA,WE,WC,CO,C1) = BIN[4](DOUT,DA,WE,WC,CO,C1) COUNT2 COUNT3 WRITE2 WRITE3 EQUATIONS := I2*WRITE1 + I1*READ1 + I3*WAIT WAIT + I5*WAIT := I4*READ2 + I3*READ2 + I2*READ2 + I1*READ2 READL + I5*WAIT READ2 := I4*READ3 + I3*READ3 + I2*READ3 + I1*READ3 + I5*WAIT := I1*READ3 + I4*WAIT READ3 + I5*WAIT := I4*COUNT1 + I3*COUNT1 + I2*COUNT1 + I1*COUNT1 WRITEL + I5*WAIT COUNT1 := I4*COUNT2 + I3*COUNT2 + I2*COUNT2 + I1*COUNT2 I5*WAIT COUNT2 I4*COUNT3 + I3*COUNT3 + I2*COUNT3 + I1*COUNT3 + I5*WAIT = I4*WRITE2 + I3*WRITE2 + I2*WRITE2 + I1*WRITE2 COUNTS + T5*WATT WRITE2 := I4*WRITE3 + I3*WRITE3 + I2*WRITE3 + I1*WRITE3 + I5*WAIT := I1*WRITE3 + I4*WAIT WRITE3 + TS#WATT STMULATION TRACE_ON REQ RW CLK /DOUT /DA /WE /WC SETF INIT /REQ OE RW ADDR1 ADDR2 ADDR3 ADDR4 CLOCKF CLK CHECK /DOUT SETF REQ /INIT CLOCKE CLOCKE CLOCKE CHECK DOUT DA SETF /REQ CHECK / DOUT / DA SETF REQ /RW CLOCKE CLOCKE CLOCKE CLOCKE CLOCKE CLOCKE SETF /REQ ``` ; This simulation was done using the alpha release version of CLOCKE ; Palasm2 software. # Simulation Results | Page | : 1 | | | | |-------|-------------|------------|------------|----------| | | q cq c | c c cg cg | cccc | C CG C C | | CLK | XXHLLHHLHH | LHLHLLHHLL | HHLHLHLHLH | LHLLHLHL | | REQ | LLLLHHHHHHH | HHHHHLLLLH | нинининин | HHHLLLLL | | RW | нинининин | HHHHHHHHL | LLLLLLLLL | LLLLLLL | | /DOUT | XXXHHHLLLL | LLLLLLHHH | нинининин | нининин | | /DA | | LLLLLLHHH | | | | /WE | хххнининни | нинининин | HLLLLLLLLL | LLHHHHHH | | /WC | | нинининин | | | | | | | | | # **Logic Symbol** TROTEAN ``` Title Pattern 4Bit_Counter 4cnt.pds Revision Author A Mehrnaz Hada Company Date Monolithic Memories Inc. Santa Clara, CA 1/14/85 CHIP 4BitCounter PAL16RP4 CLK UP AT BI CT DI CLR LOAD NC GND /OC NC NC D C B A NC NC VCC EQUATIONS := /A*/B*/C*/D*/UP*/LOAD*/CLR + /A* B* C* D* UP*/LOAD*/CLR + A* B* /D*/UP*/LOAD*/CLR + A*/B* C* UP*/LOAD*/CLR + A* /C* UP*/LOAD*/CLR + A* D*/UP*/LOAD*/CLR ;When CLR=1, A=0. ;Else it will count ;UP or DOWN. UP*/LOAD*/CLR D*/UP*/LOAD*/CLR LOAD*/CLR* AI ;New value is loaded ;when LOAD=1, CLR=0. /B*/C*/D*/UP*/LOAD*/CLR /B* C* D* UP*/LOAD*/CLR B* C*/D* /LOAD*/CLR B*/C* UP*/LOAD*/CLR B* D*/UP*/LOAD*/CLR LOAD*/CLR* BI :When CLR=1, B=0. :Else it will count. ;New value is loaded ;when LOAD=1, CLR=0. /C*/D*/UP*/LOAD*/CLR /C* D* UP*/LOAD*/CLR C*/D* UP*/LOAD*/CLR C* D*/UP*/LOAD*/CLR LOAD*/CLR* CI ;When CLR=1, C=0. ;Else it will count. c := ;New value is loaded ;when LOAD=1, CLR=0. /LOAD*/CLR /D* := Count ;New value is loaded ;when LOAD=1, CLR=0. LOAD*/CLR* DI SIMULATION TRACE ON AI BI CI DI LOAD CLR UP A B C D SETF LOAD /CLR AI BI CI DI OC ;Load all registers ;to HIGH and count up SETF CLR ;Clear all registers CLOCKF CLK SETF /CLR UP /LOAD ;Start Counting up FOR I:= 1 TO 16 DO ;Count up 16 clock BEGIN cycles CLOCKF CLK ;Load all registers SETF LOAD /CLR /UP AI BI CI DI CLOCKF SETF /LOAD FOR I:= 1 TO 16 DO BEGIN ;to HIGH and count ;down ;Count down 16 clock ;cycles CLOCKF CLK SETF LOAD CLR AI /BI CI /DI :Test setting LOAD ;and CLR on at the CLOCKF CLK ``` ;The 4-bit counter counts up or down and has the clear and ;load capability. The clear operation overrides count and ;load. The counter counts up when CLR=low, LOAD=low, and ;UP=nigh. It counts down whenever CLR=low, LOAD=low, and # Simulation Results | E | age | : 1 | | | | |---|------|-------------|-------------|-------------|------------| | | | g cgcgc c | CCCCC | CCCCC | ccccgc | | | AI . | нинининин | нинининини | нинининин | нинининин | | | BI | нинининини | нинининин | нининини | нинининин | | | CI | нинининини | инининини | нинининин | нинининин | | | DI | нинининини | нинининин | нининини | нининини | | | LOAD | HHHHHHLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLLLHH | | | CLR | LLLLHHLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLLLL | | | UP | XXXXXXHHHH | нинининин | нинининини | HHHHHHHLL | | | λ | XXXHHLLLLL | LILLILLILL | ГНИНИНИННИ | ниниптини | | | 3 | XXXHHLLLLL | LLLHHHHHHH | HLLLLLLLH | HHHHHHLLH | | | c | XXXHHLLLLLH | HHHLLLLIHHH | HLLLLHHHHL | LLLHHHHLLH | | | D | XXXHHLLHHL | LHHLLHHLLH | HLLHHLLHHL. | LHHLLHHLLH | ### **Logic Symbol** TB018508 :same time. Title 8Count Pattern 8count.pds Revision A Author Mehrnaz Hada Company Monolithic Memories Inc. Santa Clara, CA 1/15/85 This 8-bit up/down counter has the hold and load ;capabilities. It sets all the outputs high if SET= CHIP SBitCounter PAL20XS CLK UP DO D1 D2 D3 D4 D5 D6 D7 LD GND /OC SET Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 CIN VCC #### EQUATIONS | /Q0 := /SET* LD*/D0 | ;Load DO | |----------------------------------------|-------------| | + /SET*/LD*/Q0 | ;Hold | | :+: /SET*/LD*CIN* UP | ;Increment | | + /SET*/LD*CIN*/UP | ;Decrement | | | | | /Q1 := /SET* LD*/D1 | ;Load Dl | | + /SET*/LD*/Q1 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0 | ;Decrement | | /Q2 := /SET* LD*/D2 | :Load D2 | | + /SET*/LD*/Q2 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1 | :Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1 | Decrement | | 어디어 그렇게 그림생적, 이번, 이번 때 이번 나는 그 | | | /Q3 := /SET* LD*/D3 | ;Load D3 | | + /SET*/LD*/Q3 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1* Q2 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1*/Q2 | ;Decrement | | /Q4 := /SET* LD*/D4 | ;Load D4 | | + /SET*/LD*/Q4 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1* Q2* Q3 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1*/Q2*/Q3 | ;Decrement | | /Q5 := /SET* LD*/D5 | ;Load D5 | | + /SET*/LD*/Q5 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1* Q2* Q3 | | | * Q4 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1*/Q2*/Q3 | | | */Q4 | ;Decrement | | /Q6 := /SET* LD*/D6 | ;Load D6 | | + /SET*/LD*/Q6 | :Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1* Q2* Q3 | | | * Q4* Q5 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1*/Q2*/Q3 | , Increment | | */Q4*/Q5 | ;Decrement | | ###################################### | , Decrement | | /Q7 := /SET* LD*/D7 | ;Load D7 | | + /SET*/LD*/Q7 | ;Hold | | :+: /SET*/LD*CIN* UP* Q0* Q1* Q2* Q3 | | | * Q4* Q5* Q6 | ;Increment | | + /SET*/LD*CIN*/UP*/Q0*/Q1*/Q2*/Q3 | | | */Q4*/Q5*/Q6 | ; Decrement | | | | #### SIMULATION SETF /CIN CLOCKF CLK CLOCKF CLK FND ;Holding ;The outputs hold to ;their values ;Counting down SETF /UP CIN SETF LD /D7 D6 /D5 D4 /D3 D2 /D1 D0 CLOCKF CLK CHECK /D7 Q6 /Q5 Q4 /Q3 Q2 /Q1 Q0 SETF /LD UP FOR T:=1 TO 5 D0 BEGIN FOR I:=1 TO 5 BEGIN CLOCKF CLK IF I=3 THEN BEGIN SETF /UP END ;Loading some data ;Checking the output ;for the loaded data ;Counting up after ;removing HOLD, count ;up 3 cycles, count ;down for 2 cycles. ### **Simulation Results** | Page | : 1 | | | | |------|------------|------------|------------|----------| | | g cgc c c | ccccc | cgc cgcgc | c cgc c | | SET | HHHHLLLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLLL | | LD | XXXXLLLLLL | LLLLLLLLL | LLLLLHHLL | LLLLLLL | | CIN | XXXXHHHHHH | нинининин | HHLLLLHHHH | нининини | | UP | XXXXHHHHHH | нинининин | HHHHHHLLHH | HHHHLLLL | | DO | XXXXXXXXX | XXXXXXXXX | XXXXXXHHHH | нининини | | Dl | XXXXXXXXX | XXXXXXXXX | XXXXXXLLLL | LLLLLLL | | D2 | XXXXXXXXX | XXXXXXXXX | XXXXXXHHHH | нининин | | D3 | XXXXXXXXX | XXXXXXXXX | XXXXXXLLLL | LLLLLLL | | D4 | XXXXXXXXX | XXXXXXXXX | XXXXXXHHHH | нининини | | D5 | XXXXXXXXX | XXXXXXXXX | XXXXXXLLLL | LLLLLLL | | D6 | XXXXXXXXX | XXXXXXXXX | XXXXXXHHHH | нининини | | D7 | XXXXXXXXX | XXXXXXXXX | XXXXXXLLLL | LLLLLLL | | Q0 | XXXHHLLHHL | LHHLLHHLLH | HLLLLLHHL | LHHLLHHL | | Q1 | XXXHHLLLLH | HHHLLLLHHH | HLLLLLLLL | HHHLLHHH | | Q2 | XXXHHLLLLL | LLLHHHHHHH | HLLLLLHHH | HHHLLHHH | | Q3 | XXXHHLLLLL | LLLLLLLLL | LHHHHHHLLL | LLLHHLLL | | Q4 | XXXHHLLLLL | LLLLLLLLL | LLLLLLHHH | нининин | | Q5 | XXXHHLLLLL | LLLLLLLLL | LLLLLLLLL | LLLLLLL | | Q6 | XXXHHLLLLL | LLLLLLLLL | LLLLLLHHH | нининин | | Q7 | XXXHHLLLLL | LLLLLLLL | LLLLLLLL | LLLLLLL | # **Logic Symbol** TB01860 Title 9BitCounter Pattern 9BitCnt.pds Revision A Author Mehrnar Hada Company Monolithic Memories Inc., Santa Clara, CA 1/28/85 :The 9-bit synchronous counter has parallel load, increment, and hold capabilities. The carry out pin (/CO) shows how to implement a carry out using a register by anticipated one count before the terminal count if counting and the terminal count if loading. #### Operations Table | ; | /oc | CLK | /LD | D8-D0 | Q8-Q0 | Operation | |---|-----|-----|-----|-------|----------|-----------| | ; | | | | | | | | , | H | . X | x | X · | Z | HI-Z | | ; | L | L | X | X | Q | Hold | | ; | L | C | L | D | D | Load | | ; | L | C | H | X | Q PLUS 1 | Increment | | | | | | | | | CHIP 9BitCounter PAL20X10 CLK DO D1 D2 D3 D4 D5 D6 D7 D8 /LD GND /OC /CO Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC #### EQUATIONS | /00 | + | /LD*/<br>LD*/<br>/LD | | | | | | | | | | ;Hold Q0<br>;Load D0 (LSB)<br>;Count | |-----|----------------|-----------------------|-------------|------------|------------|------------|--------------------------|------------|------------|------------|--------------------|--------------------------------------------------| | /Q1 | + | /LD*/<br>LD*/<br>/LD* | /D1 | | | | 19 - 7<br>7 - 5<br>7 - 5 | | | | raiksi.<br>Laiksi. | ;Hold Q1<br>;Load D1<br>;Count | | /Q2 | + | /LD*/<br>LD*/ | /D2 | Q1 | | | | | | | | ;Hold Q2<br>;Load D2<br>;Count | | /Q3 | + | /LD*,<br>/LD* | /D3 | Q1* | Q2 | | | | | | | ;Hold Q3<br>;Load D3<br>;Count | | /Q4 | + | /LD*<br>LD*<br>/LD* | /D4 | Q1* | Q2* | Q3 | | | | | | ;Hold Q4<br>;Load D4<br>;Count | | /Q5 | + | /LD* | /D5 | Q1* | Q2* | Q3* | Q4 | | | | | ;Hold Q5;Load D5;Count | | /Q6 | + | /LD*<br>LD*<br>/LD* | /D6 | Q1* | Q2* | Q3* | Q4* | Q5 | | | | ;Hold Q6<br>;Load D6<br>;Count | | /07 | + | /LD* | /D7 | Q1* | Q2* | Q3* | Q4* | Q5* | Q6 | | | ;Hold Q7<br>;Load D7<br>;Count | | /Q8 | :=<br>+<br>:+: | /LD*<br>LD*<br>/LD* | /D8 | Q1* | Q2* | Q3* | Q4* | Q5* | Q6* | Q7 | | ;Hold Q8<br>;Load D8 (MSB)<br>;Count | | | * | LD* | /Q0*<br>D0* | Q1*<br>D1* | Q2*<br>D2* | Q3*<br>D3* | Q4*<br>D4* | Q5*<br>D5* | Q6*<br>D6* | Q7*<br>D7* | Q8<br>D8 | ;Carry out (Anticipate<br>;Carry out (Anticipate | | SIM | ULAT | 'ION | | | | | | | | | | | TRACE\_ON /OC /LD D8 D7 D6 D5 D4 D3 D2 D1 D0 /CO Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | SETF OC LD<br>CLOCKF CLK | /D8 /D7 /D6 /D5 /D4 /D3 /D2 /D1 /D0 ;Load | |--------------------------|-------------------------------------------| | SETF /LD<br>CLOCKF CLK | ;Increment | | SETF LD /D8 | 3 /D7 /D6 /D5 /D4 /D3 /D2 /D1 D0 ;Load | | SETF /LD | ;Increment | :Load ;Increment ;Increment :Toad SETF LD /D8 /D7 /D6 /D5 /D4 /D3 D2 D1 D0 CLOCKF CLK SETF LD /D8 /D7 /D6 /D5 /D4 D3 D2 D1 D0 CLOCKF CLK SETF LD /D8 /D7 /D6 /D5 D4 D3 D2 D1 D0 CLOCKF CLK SETF /LD CLOCKF CLK SETF LD /D8 D7 D6 D5 D4 D3 D2 D1 D0 CLOCKF CLK SETF /LD CLOCKF CLK :Function Table ;CLK /OC /LD D8 D7 D6 D5 D4 D3 D2 D1 D0 /CO; Q8 Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 | | | A CALL STATE OF | | the additional and the second | | |----------------------|----|------------------------------------|-----|------------------------------------|-----------------------| | ; Control; CLK /OC / | | Data In<br>DDDDDDDDDD<br>876543210 | /co | Data Out<br>QQQQQQQQQ<br>876543210 | Comment | | ; | Ţ- | LLLLLLLL | | LLLLLLLL | Load | | CL | ñ. | XXXXXXXXX | н | LLLLLLLL | Increment | | CL | Ľ | LLLLLLLH | н | LLLLLLLLH | Load | | ; C L | ñ | XXXXXXXXX | н | LLLLLLHL | Increment | | CL | Ľ | LLLLLLHH | H | LLLLLLHH | Load | | CL | H | XXXXXXXX | н | LLLLLHLL | Increment | | CL | ī | LLLLLHHH | н | LLLLLHHH | Load | | C L | ñ | XXXXXXXXX | н | LILLLHLLL | Increment | | C L | Ľ | LLLLLHHHH | н | LLLLLHHHH | Load | | C L | H | XXXXXXXXX | н | LLLLHLLLL | Increment | | C L | L | T.I.I.I.HHHHHH | н | LLLLHHHHH | Load | | C L | H | XXXXXXXXX | н | LLLHLLLLL | Increment | | | L | LLLHHHHHH | н | LLIHHHHHH | Load | | ; C L | н | XXXXXXXXX | н | LIHLLLLLL | Increment | | C L | L | LIHHHHHHH | H | LLHHHHHHH | Load | | C L | H | XXXXXXXXX | н | LHLLLLLLL | Increment | | C L | L | LHHHHHHHH | н | LHHHHHHHH | Load | | C L | H | XXXXXXXXX | н | HLLLLLLLL | Increment | | CL | L | нининини | L | нининини | Load(Carry out) | | C L | H | XXXXXXXX | H | LLLLLLLL | Increment (Roll over) | | ; C L | L | HHHHHHHLL | H | HHHHHHLL | Load | | ; C L | н | XXXXXXXX | н | HHHHHHLH | Increment | | LL | н | XXXXXXXXX | H | нининнин | Hold | | ; C L | н | XXXXXXXXX | H | HHHHHHHL | Increment | | ; C L | н | XXXXXXXX | L | нининини | Increment (Carry out) | | ; C L | H | XXXXXXXX | H | LLLLLLLL | Increment (Roll over) | | ; X H | х | XXXXXXXX | Z | 22222222 | Test HI-Z | | | | | | | | ### **Simulation Results** | Page | : : | 1 | | | | |------|------|--------|---------|------------|---------| | | q | cgc | gcgc | gcgcgcgcgc | gcgcg c | | /oc | LL | LLLL | LLLL | LLLLLLLLL | LLLLLLL | | /LD | LL | LLHH | LLHH | LLHHLLHHLL | HHLLHHH | | D8 | LL | LLLI | LLLL | LLLLLLLLL | LLLLLLL | | D7 | T.T. | LILL | J.I.I.L | LILLLILLL | LLHHHHH | | D6 | T.T. | LLLI | LLLL | LIJIJIJIJI | LLHHHHH | | D5 | | | LLLL | | LLHHHHH | | D4 | | | | LLLLLLLHH | | | D3 | | | LLLL | LILLHHHHHH | | | D2 | | | LLLL | нинининин | | | ומ | | | LLLL | нинининин | | | DO | | | нннн | нинининнин | | | | | | | | | | /co | | | нннн | нинининин | | | . Q8 | XX | XLLI | LLLL | LLLLLLLLL | | | Q7 | XX | XLLI | LLLL | LLLLLLLLL | LLLHHLL | | Q6 | XX | XLLI | LLLL | LLLLLLLL | LLLHHLL | | 05 | XX | XLLI | LLLL | LLLLLLLLL | LHHHHLL | | Q4 | XX | XLLI | LLLL | LLLLLLHHH | HLLHHLL | | Q3 | XX | XLLI | LLLL | LLLHHHHLLH | HLLHHLL | | 02 | XX | XI.I.I | LLLL | LHHLIHHLIH | | | 01 | | | LLLH | HHHLLHHLLH | HLLHHLL | | 00 | | | HHHL | LHHLLHHLLH | | | QU | ^^ | vrrm | Innnb | LANDLANDER | urruurr | # **Logic Symbol** Title 10Bit\_Counter Pattern 10count.pds Author Company Monolithic Memories Inc. Santa Clara, CA 1/15/85 ;The 10-bit counter increments on the rising edge of the ;clock input (CLK), if CNT input is high. The outputs are ;HIGH-Z when the enable line (/OE) is high and enabled ;when the enable line (/OE) is low. The counter is ;cleared (all lows) if CLR-HIGH. CHIP 10BitCount PAL20RS10 CLK /SET NC CNT NC /CLR NC NC NC NC NC GND /OE Q5 Q3 Q6 Q2 Q7 Q1 Q8 Q0 Q9 Q4 VCC #### EQUATIONS ``` /Q0 := /SET * CNT * /CLR * Q0 + /SET * /CNT * /CLR * /Q0 + CLR ;Toggle ;Hold := /SET * CNT * /CLR * Q0 * Q1 + /SET * CNT * /CLR * /Q0 * /Q1 + /SET * /CNT * /CLR * /Q1 + CLR ;Toggle ;Toggle ;Hold /Q2 := /SET * CNT * /CLR * Q0 * Q1 * Q2 + /SET * CNT * /CLR * /Q0 * /Q2 + /SET * CNT * /CLR * /Q1 * /Q2 + /SET * /CNT * /CLR * /Q2 Q2 ;Toggle ;Toggle;Hold = /SET * CNT * /CLR * Q0 * Q1 * Q2 * Q3 + /SET * CNT * /CLR * /Q0 * /Q3 + /SET * CNT * /CLR * /Q1 * /Q3 + /SET * CNT * /CLR * /Q2 * /Q3 + /SET * /CNT * /CLR * /Q3 + CLR /Q3 := /SET * CNT * /CLR * Q0 * Q1 * ;Toggle :Toggle ;Toggle ;Toggle ;Hold :Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Hold /Q5 ;Toggle ;Toggle /SET * CNT * /CLR * /Q2 * /Q5 + /SET * CNT * /CLR * /Q2 * /Q5 + /SET * CNT * /CLR * /Q4 * /Q5 + /SET * CNT * /CLR * /Q5 + /SET * /CNT * /CLR * /Q5 + CLR ;Toggle ;Toggle ;Toggle ;Hold := /SET * CNT * /CLR * Q0 * Q1 * Q2 * Q3 * Q4 * Q5 * Q6 * /SET * CNT * /CLR * /Q0 * /Q6 * /SET * CNT * /CLR * /Q0 * /Q6 * /SET * CNT * /CLR * /Q2 * /Q6 * /SET * CNT * /CLR * /Q2 * /Q6 * /SET * CNT * /CLR * /Q2 * /Q6 * /SET * CNT * /CLR * /Q4 * /Q6 * /SET * CNT * /CLR * /Q5 * /Q6 * /SET * CNT * /CLR * /Q5 * /Q6 * /SET * /CNT * /CLR * /Q6 * /SET * /CNT * /CLR * /Q6 * /SET * /CNT * /CLR * /Q6 * /SET * /CNT * /CLR * /Q6 * /SET * /CNT * /CLR * /Q6 ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle :Hold /Q7 := /SET * CNT * /CLR * Q0 * Q1 * Q2 * Q3 * Q4 * Q5 * Q6 * Q7 * /SET * CNT * /CLR * /Q0 * Q7 * /SET * CNT * /CLR * /Q1 * /Q7 * /SET * CNT * /CLR * /Q2 * /Q7 * /SET * CNT * /CLR * /Q4 * /Q7 * /SET * CNT * /CLR * /Q4 * /Q7 * /SET * CNT * /CLR * /Q4 * /Q7 * /SET * CNT * /CLR * /Q6 * /Q7 * /SET * CNT * /CLR * /Q6 * /Q7 * /SET * CNT * /CLR * /Q6 * /Q7 * /SET * CNT * /CLR * /Q7 * CLR ;Toggle :Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Hold := /SET * CNT * /CLR * Q0 * Q1 * Q2 * Q3 * Q4 * Q5 * Q6 * Q7 * Q8 /08 ;Toggle Q8 +/SET * CNT * /CLR * /Q0 * /Q8 +/SET * CNT * /CLR * /Q1 * /Q8 +/SET * CNT * /CLR * /Q1 * /Q8 +/SET * CNT * /CLR * /Q3 * /Q8 +/SET * CNT * /CLR * /Q4 * /Q8 +/SET * CNT * /CLR * /Q5 * /Q8 +/SET * CNT * /CLR * /Q5 * /Q8 +/SET * CNT * /CLR * /Q6 * /Q8 +/SET * CNT * /CLR * /Q7 * /Q8 ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ``` ``` + /SET * /CNT * /CLR * /Q8 + CLR :Hold /Q9 := /SET * CNT * /CLR * Q0 * Q1 * Q2 * Q3 * Q4 * Q5 * Q6 * Q7 * ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle ;Toggle :Toggle :CLR SIMULATION TRACE_ON OF CLK SET CLR CNT QO Q1 Q2 Q3 04 05 06 07 08 09 SETF OF /CLR SET ;Set high all the CLOCKF CLK registers SETE CLR :Clear all the registers SETF /SET CNT /CLR ;Start counting FOR I:= 1 TO 5 DO :Count for five cycles. At the count of four check for four on the output. CLOCKF CLK IF I=4 THEN REGIN CHECK /Q0 /Q1 Q2 END END SETF /CNT CLOCKF CLK :Hold ``` ### Simulation Results | <b>U</b> | • | | | , | | 00 | - | • | |----------|----|------|------|----|------|-----|------|---| | Page | : | 1 | | | | | | | | | g | cg | cg | c | CC | c | cg | С | | OE | HH | HHHI | HHH | H | HHHH | HHF | ннн | Н | | CLK | XX | HLL | ILLE | IL | HLHI | HL | ILLH | L | | SET | HH | ннні | HLI | L | LLLI | LLI | LLL | L | | CLR | LL | LLH | HLI | L | LLLI | LLI | LLL | I | | CNT | XX | XXX | KXHE | H | HHHH | HHI | HLL | L | | Q0 | XX | XHHI | HLLI | Н | HLLE | HLI | HHH | Н | | Ql | XX | XHH | HLLI | L | LHHH | HLI | LLLL | I | | Q2 | XX | XHHI | HLLI | L | LLLI | LH | ннн | Н | | Q3 | XX | XHH | HLLI | L | LLLI | LLI | LLL | L | | Q4 | XX | XHH | HLLI | L | LLLI | LLI | LLL | I | | Q5 | XX | XHH | HLLI | L | LLLI | LLI | LLL | I | | Q6 | XX | XHH | HLLI | LL | LLLI | LLI | LLL | 1 | | Q7 | XX | XHH | HLLI | L | LLLI | LLI | LLL | I | | Q8 | XX | XHH | HLLI | L | LLLI | LLI | LLLL | I | | Q9 | XX | XHH | HLLI | LL | LLLI | LLI | LLL | L | | | | | | | | | | | ### **Logic Symbol** TB018 ### **Functional Description** Shown below is a schematic of two PAL devices implementing a 5-bit up asynchronous ring counter with programmable rollover, asynchronous load, and reset. Initial count point can be loaded by asserting /LD low. Rollover point is loaded by asserting /LR low. Q4...Q0 and R4...R0 are compared in the PAL16C1 which is implemented as a comparator. The result of the comparison is fed back from the PAL16C1 to the PAL20RA10 device through the /RST line. Note that a Master Reset must be executed first before an initial count point can be loaded. ### **Block Diagram** TC00020M Title 5-Bit Up Counter Pattern UpCount.pds Pattern UpcountyRevision A Author Bill Karkula Company Honolithic Hemories Inc., Santa Clara, CA 7/19/84 /PL D4 D3 D2 D1 D0 CK NC /LD /LR /RST GND /OE R0 R1 R2 R3 R4 Q0 Q1 Q2 Q3 Q4 VCC #### EQUATIONS | And the first state of | | 하기는 점점 취임 사용에 유민이라는 가는 것이다. | |------------------------|---------|-----------------------------------| | /Q4 | := Q4 | ;Toggle if lower MSB | | Q4.CLKF | = /Q3 | ;becomes a zero | | Q4.RSTF | = RST | ;Rollover/master RST | | Q4.SETF | = D4*LD | ;Load initial Count | | /Q3 | := Q3 | ;Toggle when Q2 | | Q3.CLKF | = /Q2 | ;becomes a zero | | Q3.RSTF | = RST | ;Rollover/master RST | | Q3.SETF | = D3*LD | ;Load initial count | | /Q2 | := Q2 | ;Toggle when Q1 | | Q2.CLKF | = /Ql | ; becomes a zero | | Q2.RSTF | = RST | ;Rollover/master RST | | Q2.SETF | = D2*LD | ;Load initial count | | /Q1 | := Q1 | ;Toggle when Q0 | | Q1.CLKF | = /Q0 | ;becomes a zero | | Q1.RSTF | = RST | ;Rollover/master RST | | Q1.SETF | = D3*LD | ;Load initial count | | /90 | := Q0 | ;Toggle LSB | | QO.CLKF | = CK | ;External CLKF input | | QO.RSTF | = RST | ;Rollover/master RST | | QO.SETF | = D0*LD | ;Load initial count | | /R4 | := /D4 | ;Load rollover point | | R4.CLKF | = LR | ;if /LR is low | | /R3 | := /D3 | ;Load rollover bit 3 | | R3.CLKF | = LR | ;if /LR is asserted | | /R2 | := /D2 | ;Load rollover bit 2 | | R2.CLKF | = LR | ;if /LR is asserted | | /R1 | := /D1 | ;Load rollover bit 1 | | R1.CLKF | = LR | ;if /LR is asserted | | /RO | := /D0 | ;Load rollover bit 0 | | RO.CLKF | = LR | ;if /LR is asserted | | | | 사람들은 사람이 되는 것이 살아왔다면 하는 사람들이 하였다. | #### SIMULATION TRACE\_ON PL OE CK QO Q1 Q2 Q3 Q4 SETF RST /LD CHECK Q0 Q1 Q2 Q3 Q4 SETF /RST SETF DO D1 D2 D3 D4 LD CHECK /Q0 /Q1 /Q2 /Q3 /Q4 SETF /OE Q4 Q3 Q2 Q1 /Q0 /LD SETF PL SETF OF /PL SETF CK SETF /CK SETF CK SETF /CK SETF CK SETF /CK SETF CK SETF /CK # Simulation Results | | a da a dad | gg gg | aa | |----|------------|------------|-----| | PL | XXXXXXXX | LLLLLLLL | LLL | | ΟĒ | XXXXXLLLHH | нинининини | нни | | CK | HXXXXXXXXX | HHLHHLHHHH | | | Q٥ | | LLLLHHHLLL | | | Q1 | | LHHHHHHHLL | | | Q2 | | LLLLLLLLH | | | Q3 | | LLLLLLLLL | | | Q4 | HHHLLZZHLL | LLLLLLLLL | LLL | | | | | | TR01900M ;Test SET function ;on reg. outputs ;Deassert SET funct ;Test RESET function ;Disable RESET(LD=0);load registers w/;HHHHL (04...Q0),;tristate registers;Load reg.'s w/ data;on output bus.;Disable PRELOAD &;TRISTATE funct. of registers; Check for high PAL16C1 ROLLO2 COMPARATOR MONOLITHIC MEMORIES INC., SANTA CLARA, CA 04 03 02 01 00 R4 R3 R2 R1 GND R0 NC NC NC NC /RST NC NC /MR VCC #### EQUATIONS | /RST | = Q4*/R4*/MR + /Q4*R4*/MR | COMPARE Q4 & R4 MSB | |------|---------------------------|---------------------| | | + Q3*/R3*/MR + /Q3*R3*/MR | COMPARE Q3 & R3 | | | + Q2*/R2*/MR + /Q2*R2*/MR | COMPARE Q2 & R2 | | | + Q1*/R1*/MR + /Q1*R1*/MR | COMPARE Q1 & R1 | | | + Q0*/R0*/MR + /Q0*R0*/MR | COMPARE QO & RO LSB | #### FUNCTION TABLE Q4 Q3 Q2 Q1 Q0 R4 R3 R2 R1 R0 /MR /RST | ;<br>;QQQQQ<br>;43210 | | | R<br>S | | | | | | | |-----------------------|-------|---|--------|-----|-------|---------|--------|-------|--| | | | | | | | | | | | | HLLLL | LLLLL | H | H | . 1 | Q4=H, | R4=L | | | | | LHLLL | LLLLL | H | H | 2 | Q3=H, | R3=L | | | | | LLHLL | LLLLL | н | H | 3 | Q2=H, | R2=L | | | | | LLLHL | LLLLL | H | H | 4 | Q1-H, | R1=L | | | | | LLLLH | LLLLL | H | H | 5 | Q0=H, | RO=L | | | | | LLLLL | HLLLL | H | H | 6 | Q4=L, | R4=H | | | | | LLLLL | LHLLL | н | H | 7 | Q3=L, | R3=H | | | | | LLLLL | LLHLL | H | H | 8 | Q2=L, | R2=H | | | | | LLLLL | LLLHL | н | H | 9 | Q1=L | R1=H | | | | | LLLLL | LLLLH | H | H | 10 | Q0=L | RO=H | | | | | LLLLL | LLLLL | H | L | 11 | TEST | ALL LOV | 15 | | | | нинин | ннннн | н | L | 12 | TEST | ALL HIC | HS | | | | LHLHL | LHLHL | н | L | 13 | TEST | EVEN CH | IECKER | BOARD | | | HLHLH | HLHLH | H | L | 14 | TEST | ODD CHI | CKERB | OARD | | | LLLLL | нинин | L | L | 15 | TEST | MASTER | RESET | | | | нинин | LLLLL | L | L | 16 | TEST | MASTER | RESET | | | | | | | | | | | 7.78 | 4 | | #### DESCRIPTION PALIGC1 DESIGN SPECIFICATION 5-BIT COMPARATOR WITH MASTER RESET OVERRIDE (SECOND OF THE TWO PALS SOLUTION ON THE 5-BIT COUNTER WITH PROGRAMMABLE ROLLOVER, ASYNCHRONOUS LOAD AND RESET.) MONOLITHIC MEMORIES INC., SANTA CLARA, CA BILL KARKULA 7/19/84 THIS DEVICE COMPARES 5 BITS OF DATA (R4...R0) WITH Q4...Q0 AND ASSERTS /RST IF THEY ARE EQUAL. THEREFORE /RST GOES LOW WHEN PROGRAMMED ROLLOVER POINT R4...R0 MATCHES COUNT Q4...Q0. /RST ALSO GOES LOW WHEN /MR GOES LOW, INDICATING A MASTER RESET. NOTE: THIS PAL DESIGN SPEC WAS ASSEMBLED ON PALASM V1.7. # 7 # **Functional Description** This application is for a seven-bit register with handshake logic. The chip can be used for interfacing between a micro-processor and its peripheral I/O. The on-chip flag flip-flop provides the handshaking capability required in typical demand-response-based data transfer. Both the register and the flag flip-flops are asynchronously cleared by CLR signal. ### **Block Diagram** Input data is stored in the register when DCLK signal is applied, and at the same time, the event is signified by asserting DRDY signal. The DRDY signal indicates that the data is available in the register. By monitoring the DRDY signal when it is high, the stored input data can be transferred to Q output port by asserting /OE three-state control signal. After moving the data, DACK signal should be applied to clear the flag flip-flop. # Handshake Operation Title 7-Bit I/U roll Port.pds Revision A Author Sadahiro Horiko / Kelvin Chow Monolithic Memories Inc., Santa Clara, Ca 3/1/85 PL DO D1 D2 D3 D4 D5 D6 CE DCLK CLR GND OE DACK DRDY NC Q6 Q5 Q4 Q3 Q2 Q1 Q0 VCC #### EQUATIONS | Q0 | := D0 | ;LSB of 7-bit reg | |-----------|--------|--------------------| | Q0.CLKF | = DCLK | External clock | | QO.SETF | = CLR | ;Clear register | | QO.TRST | = CE | ;Tristate control | | Ql | := D1 | ;Data l | | Q1.CLKF | = DCLK | ;External clock | | Ql.SETF | = CLR | ;Clear register | | Q1.TRST | = CE | ;Tristate control | | Q2 | := D2 | :Data 2 | | Q2.CLKF | = DCLK | ;External clock | | Q2.SETF | = CLR | ;Clear register | | Q2.TRST | = CE | Tristate control | | Q3 | := D3 | ;Data 3 | | Q3.CLKF | = DCLK | ;External clock | | Q3.SETF | = CLR | ;Clear register | | Q3.TRST | = CE | ;Tristate control | | Q4 | := D4 | ;Data 4 | | Q4.CLKF | = DCLK | ;External clock | | Q4.SETF | = CLR | ;Clear register | | Q4.TRST | = CE | Tristate control | | Q5 | := D5 | ;Data 5 | | Q5.CLKF | = DCLK | ;External clock | | Q5.SETF | = CLR | ;Clear register | | Q5.TRST | = CE | Tristate control | | Q6 | := D6 | :Data 6 | | Q6.CLKF | = DCLK | External clock | | Q6.SETF | = CLR | ;Clear register | | Q6.TRST | = CE | Tristate control | | DRDY | := GND | ;Handshake logic | | DRDY.CLKF | = DACK | ;Cleared by DACK | | DRDY.RSTF | = DCLK | Clear | | DRDY.SETF | = CLR | ;Asserted by DCLK | | DRDY.TRST | = VCC | ; (External clock) | | | | | #### SIMULATION TRACE\_ON CLR QO Q1 Q2 Q3 Q4 Q5 Q6 DCLK DRDY DACK SETF PL /CE /OE /DO D1 /D2 D3 /D4 D5 /D6 CLR /DCLK /DACK ;Set input values ;Tristate outputs SETF CE OE CLR ;Remove the tri-;states on the ;outputs and clear ;registers ;Remove the clock SETF CLR ;Clock the data & ;set DRDY register SETF /DCLK SETF DACK SETF DACK ;Assert DACK SETF /DACK ;Lower DACK # **Simulation Results** | Page : | 1 | *** | |--------|------------|-----| | CLR | d d dd dd | g | | 20 | XZZLLLLLLL | L | | Ql | XZZLLLHHHH | H | | Q2 | XZZLLLLLLL | L | | Q3 | XZZLLLHHHH | H | | Q4 | XZZLLLLLLL | L | | Q5 | XZZLLLHHHH | Н | | Q6 | XZZLLLLLLL | L | | DCLK | LLLLLHHLLL | L | | DRDY | XLZZLHHHHL | L | | DACK | LLLLLLLHH | L | # 7 # **Functional Description** Original application was developed by LTT, Conflans Ste. Honorine, FRANCE. Part of the schematics, reprinted with courtesy of LTT, is used to control a serial data link based upon a specialized LSI chip. Originally designed with six standard SSI/MSI circuits, this same function can now be implemented, not only into a single PAL20RA10 device, but with even more features and better performance. The function can be divided into three subfunctions: - 1. Address Decoding - 2. Control Flags - 3. Transmission Speed Selection Up to four address lines are allowed (eight were actually used), plus two extra lines which are special decoding controls (MEM/IO selection, Enable Control...). Two flip-flop load flag conditions, from the address bus (A1 and A2), providing handshake between the 6850 UART and the communication lines. They have a common clock which also serves as Chip Select (CSO) for the UART. The UART Transmit clock (TXCLK) can be directly connected to the Receive Clock (CK or RXCLK) or represents the Receive Clock value divided by sixteen. This function was performed by four D-type Flip-Flops connected as a 4-stage Asynchronous Divider. Since each basic cell, used in a PAL20RA10 device has four Product Terms available, this function could be implemented either asynchronously or synchronously. In the PAL Design Specification example, a 4-bit synchronous divider was used instead of the asynchronous circuit shown in the schematic. # **Pin Description** | 1. TEST | Allows preload function for testing. Reset line from microprocessor. Address line from address bus. Address line from address bus. Handshake line (CTS/RTS). External clock. Enable line from microprocessor. | |---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8. AUXDECOD | Extra decoding line (e.g. board level decoding). | | 9. A3<br>10. A4<br>11. A5 | Address line from address bus. Address line from address bus. Address line from address bus. | | 12. GND | Reference power supply ground. | | 13. /OE | Output enable line. | | 14. A6 | Address line from address bus. | | 15. SPEEDSEL | Speed selection line. | | 16. DIV4 | MSB 4-bit synchronous counter. | | 17. DIV3 | 3rd stage synchronous counter. | | 18. DIV2 | 2nd stage synchronous counter. | | 19. DIV1 | LSB 4-bit synchronous counter. | | 20. CS0 | UART chip select line (CSO). | | 21. BLOCREC | Bloc receive line. | | 22. DIR DIV | Direct or divided clock. | | 23. /TPH | External use flag. | | 24. VCC | 5V power supply. | | | | # **Before** Figure 6. # **After** Figure 7. Title Serial Data Link Controller Link.pds Pattern Revision Author Jose Juntas / Kelvin Chow Monolithic Memories Inc., Santa Clara, Ca Date 3/1/85 CHIP SE\_CH\_CNTRL PAL20RA10 TEST SYSRESET A2 A1 HDSHAKE CK E AUXDECOD A3 A4 A5 GND /OE A6 SPEEDSEL DIV4 DIV3 DIV2 DIV1 CSO BLOCREC DIRDIV /TPH VCC EQUATIONS | /TPH<br>/TPH.CLKF | := A2<br>= CSO | ;Load A2 as flag<br>;CLK W/ ADDR. decode | |-------------------|------------------------|------------------------------------------| | /TPH.SETF | = SYSRESET | global system reset; | | DIRDIV | :- A1 | ;Load speed ratio | | DIRDIV.CLKF | = cso | ;CLK W/ ADDR. decode | | DIRDIV.SETF | - /HDSHAKE | ;CLR by CTS/RTS line | | /BLOCREC | = /DIRDIV | ;Controlled by speed | | rental from the s | + HDSHAKE | option and CTS/RTS | | | | ;line | | CSO | = /A6*A5*A4*A3*AUXDECC | | | | | ;UART address valid | | /DIV1 | := DIV1 | ;4-bit synchronous | | | | ;divider LSB | | /DIV1.CLKF | = CK | ;CLK by CK(external) | | /DIV1.SETF | = /DIRDIV | ;CLR by speed option | | /DIV2 | := /DIV1*/DIV2 | ;2ND stage of | | | + DIV1*DIV2 | ;divider | | /DIV2.CLKF | = CK | ;CLK by CK(external) | | /DIV2.SETF | = /DIRDIV | ;CLR by speed option | | /DIV3 | := /DIV2*/DIV3 | ;3RD stage of | | , | + /DIV1*/DIV3 | divider | | | + DIV1*DIV2*DIV3 | | | /DIV3.CLKF | = CK | ;CLK by CK(external) | | /DIV3.SETF | = /DIRDIV | ;CLR by speed option | | 1 | (DUILD ) (DUIL) | ;4TH stage of | | /DIV4 | := /DIV3*/DIV4 | divider MSB | | | + /DIV2*/DIV4 | Antarder Wap | | | + /DIV1*/DIV4 | | | | + DIV1*DIV2*DIV3*DIV4 | :CLK by CK(external) | | IDIUA CIKE | = CY | | /DIV4.CLKF = CK = /DIRDIV ;CLK by CK(external);CLR by speed option SPEEDSEL SPEEDSEL.CLKF ;Load speed choice ;CLK W/ ADDR. decode ;CLR by CTS/RTS line :Reset all regs This portion; simulates divide; by four counter = /HDSHAKE SPEEDSEL.SETF SIMULATION TRACE\_ON A1,A2,A3,A4,A5,A6,E, AUXDECOD,SYSRESET,/TPH,HDSHAKE, CSO,SPEEDSEL,DIRDIV,CK, DTV1,DIV2,DIV3,DIV4 SETF SYSRESET,/HDSHAKE ;Signals to be CHECK /SPEEDSEL,/DIRDIV,TPH SETF /SYSRESET,A1,A2,A3,A4,A5,/A6,HDSHAKE, E,AUXDECOD ;condition :Check SPEEDSEL and CHECK /SPEEDSEL, DIRDIV ;DIRDIV regs FOR I:=1 TO 15 DO BEGIN SETF CK SETF /CK END # Simulation Results | Page : 1 | | | | | |----------|-------------------|------------|------------|------------| | | g g g gg | gg gg gg g | g gg gg gg | | | Al . | ххнининини | нинининин | нинининин | нинининин | | λ2 | <b>ХХНИНИННИН</b> | нинининин | нининини | нинининин | | A3 | <b>ХХНИНИНИН</b> | нинининин | нинининин | нинининин | | λ4 | ххнининини | нинининин | нинининии | нинининин | | λ5 | <b>ХХНИНИННИН</b> | нинининин | нинининин | нининини | | λ6 | XXLLLLLLLL | LLLLLLLLL | LILLILLILL | LLLLLLLLL | | E | ххниннинн | нинининини | нинининин | нинининин | | AUXDECOD | ххниннинни | нинининин | нинининии | нинининин | | SYSRESET | HHLLLLLLLL | LLLLLLLLL | LILLILLILL | LILLLLLLL | | /TPH | T.T.I.I.HHHHHH | нинининни | нинининини | нинининин | | HDSHAKE | ттинниннин | нинининни | нинининини | нинининин | | | ххинининн | нинининни | нинининин | нинининин | | CSO | LILLLLLLL | | | LLLLLLLLL | | SPEEDSEL | LLLLHHHHHHH | нинининин | нинининин | нинининин | | DIRDIV | | LHHLHHLHHL | HHLHHLHHLH | HINHIHHIM | | CK | XXXXXHHTHH | | HLLLHHHLLL | HHHLLLHHHL | | DIVI | XLLLLLHHHL | LLHHHLLLHH | | | | DIV2 | XLLLLLLLH | HHHHHLLLLL | LHHHHHHLLL | LLLHHHHHHL | | DIV3 | XLLLLLLLL | | HHHHHHHLLL | LLLLLLLLH | | DIV4 | XLLLLLLLL | LLLLLLLLL | LLLLLLHHH | нинининин | | Page: 2 | | |----------|------------| | | gg gg gg g | | Al | нинининин | | A2 | нинининин | | A3 | нинининин | | λ4 | нинининин | | A5 | нинининин | | λ6 | LLLLLLLLL | | E | нинининин | | AUXDECOD | нинининин | | SYSRESET | LLLLLLLLL | | /TPH | нинининин | | HDSHAKE | нинининин | | CSO | нинининин | | | LLLLLLLLL | | SPEEDSEL | | | DIRDIV | нинининин | | CK | THHTHHTHHT | | DIVI | LLHHHLLLHH | | DIV2 | LLLLLHHHHH | | DIV3 | нинининин | | DIV4 | нинининин | | | | # **Interrupt Controller** ### **Functional Description** One of the more widely used computer families is the Digital Equipment Corp.'s PDP-11 series. This family of computers uses the DEC unibus to communicate between cards. A specific protocol is required to interface a card to the unibus. This protocol is described in the available DEC literature. Since the unibus is an asynchronous bus, much of the interface circuitry consists of combinational logic to generate specific signals and flip-flops which are set and reset as flags. This tends to use a lot of SSI and MSI logic packages. Using Monolithic Memories' PAL devices, much of this logic can be condensed into a few packages. Figure 2 is the schematic diagram for an interrupt Controller to be used on the unibus. (p.6 – 30 of the 1976 DEC PDP-11 Peripherals Handbook.) Many cards communicate over the bus by taking control of the unibus with an interrupt request, and then do whatever they require before releasing control. As can be seen, this interrupt controller takes six special interface ICs, (380 and 8881 bus drivers and receivers) eight MSI, SSIIC, (7400, 7402 and 7474s) along with some transistors and discrete parts. This parts count can be considerably reduced by using PAL20RA10 and PAL20L10 devices. Figure 1 shows how the circuit with the PAL devices would look. The two PAL devices allow almost all of the 7400, 7402 and 7474 packages to be removed. (Almost a 4-1 saving in chip count.) In addition the preload pin (PRLD) on the 20RA10 allows the flip-flops to be easily set to a known state on power up, or when re-initializing. So the PAL devices reduce the logic package count from eight chips to three. This shows that by using PAL devices substantial space and circuit savings can be realized when interfacing to the unibus. In the schematic shown, there are three VLSI devices, three MSIs and two SSIs. Using a PAL20RA10 logic circuit, it is possible to replace three MSIs and one SSI device, thereby reducing the chip count by a factor of two. The ICs inside the enclosed loop were replaced. Figure 1. # **PAL Design Specification** PALZOLIO INTROI INTROI INTERUPT LOGIC MONOLITHIC MEMORIES INC., SANTA CLARA, CA INTRAH INTRAHEN MCLEARAH INTROHEN MCLEARBH BGINBH BGINAH BUSSSYNL BUSBBSYL STARTINTRAL GND STARTINTRAL FFRESET ENINTRA INTRONEHH INTRONEAH EN8881 SSYN NBGINBH FFIRESET ENINTRA NBGINAH VCC #### EQUATIONS | /NBGINAH | = BGINAH | ; FF1 CLK CONTROL<br>; BLOCK A | | |-------------|---------------------------------------------|----------------------------------|--| | /FF1RESET | = MCLEARAH+ENINTRA | ;SET FF1 CONTROL<br>; BLOCK A | | | /ENINTRA | = INTRAHEN*INTRAH | ;ENABLE INTERRUPT A | | | /NBGINBH | = BGINBH | ; FF3 CLOCK CONTROL<br>; BLOCK B | | | /SSYN | = BUSSSYNL*BUSBBSYL | ;SYNCHRONIZE FF2 & ; FF4 | | | /EN8881 | = STARTINTRAL*STARTINTRBL<br>;INTERRUPT BUS | | | | /INTRDONEAH | = BUSSSYNL+STARTINTRAL | ;SIGNAL INTERRUPT<br>; DONE | | | /ENINTRB | = INTRBH*INTRBHEN | ;ENABLE INTERRUPT B | | | /FF3RESET | = MCLEARBH+ENINTRB | ;SET FF3 CONTROL<br>; BLOCK B | | | /INTRDONEBH | = BUSSSYNL+STARTINTRBL | ;SIGNAL INTERRUPT<br>; DONE | | #### DESCRIPTION COMBINATORIAL LOGIC FOR PAL2ORALO INTERRUPT CONTROLLER (1ST PART OF THE TWO PALS SOLUTION: PAL2OLLO & PAL2ORALO) MONOLITHIC MEMORIES INC., SANTA CLARA, CA 7/19/84 NOTE: THIS PAL DESIGN SPEC WAS ASSEMBLED ON PALASM V1.7. TB01960 Figure 2. DEC PDP-11 unibus interrupt controller Control.pds Pattern Revision Dan Kinsella Author Company Monolithic Memories Inc., Santa Clara, CA 3/1/85 CHIP INTR\_CONTROL PAL20RA10 PL AINTR NC ABGIN FF1RESET SSYN BINTR NC FF3RESET BBGIN NC GND NC OUT4 OUT3 OUT2 OUT1 FF3 NFF4 FF4 NFF2 FF2 FF1 VCC EQUATIONS | FF1.SETF<br>FF1.CLKF | - /FF1=FF2<br>- /FF1RESET<br>- /ABGIN | ;block A | | |-----------------------------|-----------------------------------------|------------------|--| | FF2<br>FF2.SETF<br>FF2.CLKF | := FF1<br>= /AINTR<br>= ABGIN*FF2*/SSYN | ;Bus Busy Signal | | | /NFF2 | := FF1 | ;Bus sack signal | | :Master control :Bus busy signal :Bus sack signal ;bus req. block B NFF2.SETF = /AINTR = ABGIN\*NFF2\*/SSYN := /FF3\*FF4 = /FF3RESET = /BBGIN /FF3 FF3.SETF FF3.CLKF := FF4 FF4.SETF = /BINTR = BBGIN\*FF4\*/SSYN := FF3 /NFF4 NFF4.SETF NFF4.CLKF = /BINTR = BBGIN\*NFF4\*/SSYN /OUT1 = FF1+FF2 ;Bus request signal ;block A ;Bus request signal ;block B = FF4+FF3 /OUT2 ;Intr. signal for - AINTR /OUT3 ;bus req. block A ;Intr. signal for = BINTR /OUT4 SIMULATION TRACE\_ON FF1RESET FF3RESET AINTR BINTR SSYN ABGIN BBGIN FF1 FF3 NFF2 NFF4 OUT1 OUT2 OUT3 OUT4 SETF /FFIRESET /FF3RESET AINTR BINTR :Reset all regs SETF FF1RESET FF3RESET /AINTR /BINTR ;Clock FF1 and FF3 ABGIN BBGIN regs SETF /SSYN ;Clock NFF and NFF3 regs # **Simulation Results** Page: 1 gg g FF1RESET LHHH FF3RESET LHHH AINTR BINTR HLLL SSYN ABGIN XXXL BBGIN FF1 FF3 NFF2 XHHH XLLL NFF4 OUT1 YI.I.I. XHHH OUT2 OUT3 хннн LHHH LHHH # **Logic Tutorial** # **Table of Contents** | Table of Contents for Section 8 | 8-1<br>8-2 | |-------------------------------------------------------------------------------------------------|------------| | 1.0 Boolean Algebra | | | 1.1 The Language of Logic | 8-3 | | 1.2 AND, OR and NOT | 8-3 | | 1.3 Precedence | 8-4 | | 1.4 Associativity and Commutativity | 8-4 | | 1.5 Postulates and Theorems | 8-4 | | 1.5.1 Duality | 8-4 | | 1.5.2 Using Truth Tables | 8-5 | | 1.5.3 Complement of a Boolean Function | 8-5 | | | | | 1.6 Algebra Simplification | 8-5 | | 1.6.1 Sum-of-Products and Product-of-Sums | 8-5 | | 1.6.2 Canonical Forms | 8-5 | | 1.6.3 Conversion Between Canonical Forms | 8-6 | | 1.7 Exclusive-OR (XOR) and Equivalence (XNOR) | 8-6 | | 1.8 Boolean Operator Summary | 8-7 | | 2.0 Binary Systems | | | 2.1 Base Conversion | 8-8 | | 2.1.1 Base-2 to Base-10 Conversion | 8-8 | | 2.1.2 Base-10 to Base-2 Conversion | 8-8 | | 2.1.3 Base-2 to Base-8 or Base-16 | 8-8 | | 2.2 Simplicity of Binary Arithmetic | 8-8 | | 2.2.1 1's Complement | 8-8 | | | 8-8 | | | 8-9 | | 2.2.3 2's Complement | | | 2.2.4 Subtraction with 2's Complement | 8-9 | | 3.0 Karnaugh Maps | | | 3.1 Karnaugh Map Technique | 8-10 | | | 8-10 | | | 8-10 | | | 8-10 | | 그 그는 사람들은 가장에 가는 사람들이 사용하게 하면 가장 하는 것이 되는 것이 하는 생물에 가는 생각을 누워 되었다. 사람 | | | 4.0 Combinatorial Logic | | | | 8-11 | | | 8-11 | | | 8-12 | | | 8-13 | | | 8-14 | | 4.6 Magnitude Comparator | 8-16 | | | 8-17 | | 4.8 Unlocked Flip-Flops — Hazards | 8-17 | | 5.0 Sequential Logic | | | 그는 사람들은 경우를 보는 사람들이 모든 사람들이 모든 것으로 가장 그는 것이 되었다. 그는 그는 그는 그는 그는 그는 그를 보는 것이 없는 것이 없는 것이 없는 것이다. | 8-21 | | 5.1 Introduction | | | | 8-21 | | | 8-21 | | | 8-22 | | | 8-22 | | | 8-23 | | | 8-23 | | | 8-23 | | 5.4 Designing Synchronous Sequential Circuits | 8-23 | | 5.4.1 State Transition Tables | 8-24 | | | 8-24 | | | | | 5.4.3 Design Examples | 8-25 | ## 1. Boolean Algebra ## 1.1 The Language of Logic Although you may not be aware of it, you are already an expert at forming, simplifying and comprehending Boolean equations and expressions. Boolean algebra, in its most common application, is concerned with the truth or falsity of statements. Any time you describe what circumstances would make something true or false, you have made a Boolean equation. For example, suppose A is true only if B and C are true. These three letters may represent anything you like — A may be whether or not you may become president, B may be whether or not you are elected, and C may be whether or not you are a citizen of the U.S.A. You may become president only if you are elected and you are a citizen of the United States. If we wrote that statement in equation form, it might look like this: $$A = B*C$$ where the \* is a shorthand notation for the word 'AND'. A, B and C are all Boolean variables, since they represent some value which may be either true or false. You either are a citizen of the United States, or you are not — there is no in between. Examining the relationship between these three variables, we find that: - if you are elected and you are citizen then you may become president; - if you are elected but you are not a citizen then you cannot become president; - if you are not elected, but you are a citizen, you still can't become president, and; - if you are neither elected nor a citizen, then you definitely cannot become president. This same relationship, which may be expressed in terms of an English sentence, may also be represented by a table of all the possibilities, called a truth table. If we let "1" stand for true, and "0" stand for false, we can make the following table: | ٠, | the transfer of | | 18 m. 1963. 17 | |----|-----------------|---|----------------| | | В | C | A | | | 0 | 0 | 0 | | | 0 | 1 | 0 | | | 1 | 0 | 0 | | | 1 | 1 | 1 | Figure 1-1. The AND Operator The table above is a standard way of expressing logical relationships. Our truth table lists the possibilities one-by-one. If B and C are false, then A will be false. If B is true and C is false, then A will still be false. If B is false, and C is true then A will again be false. However, if B and C are both true, then A will be true. #### 1.2 AND, OR and NOT The fact is that every time you have an equation of the form: $$A = B*C$$ you will have a truth table in the form of Figure 1-1 because he table and the word 'AND' are just two ways of expressing he same relationship between two Boolean variables. Now let's look at the operator 'OR'. Suppose A is true if B or C is true. This equation can be written: $$A = B + C$$ Do not confuse the + with the addition sign of arithmetic; in Boolean algebra, it is shorthand notation for the word 'OR'. A truth table for this equation would be: | В | C | <b>A</b> | |-----|---|----------| | 0 | 0 | 0 | | 0 | 1 | 1 | | 3.1 | 0 | 1 | | 1 | 1 | 1 | Figure 1-2. The OR Operator This table expresses a different relationship between the variables than AND does; AND requires that both of its operands be true for the expression to be true. OR only requires that one of its operands be true for the expression to be true. From the table above, we can see that: - 1) if both B and C are false, then A is false: - 2) if B is false, and C is true, then A is true: - 3) if B is true and C is false, then A is true and: - 4) if both B and C are true, then A is true. Finally, let's look at the operator 'NOT'. If A equals NOT B, then the value of A is the inverse of B. This equation would be: $$A = /B$$ Again, the '/' should not be mistaken for the division sign of arithmetic. It is a shorthand notation for the Boolean operator, 'NOT'. The truth table for this equation is: | . В ⊹ | Α | |-------|-------------------| | 0 | , ε <b>1</b> , γ, | | 1 🖰 | 0 | Figure 1-3. The NOT Operator. which is to say that: - 1) if B is false, then A is true and: - 2) if B is true then A is false. The elementary operators are summarized in Figure 1-4. | 4 | OPERATOR | SYMBOL | |---|----------|--------| | | AND | | | | OR | + | | | NOT | / | Figure 1-4. Elementary Boolean Operators ## 1.3 Precedence In arithmetic, the multiplication sign is always evaluated before the addition sign. For example: $$3 + 4 \times 7$$ is 31, not 49. Similarly, the AND sign is always evaluated before the OR sign. Another way to say this is that AND has a higher precedence than OR. Of course, in arithmetic, the precedence of operators may be changed with parentheses. If you wish the expression: $$3 + 4 \times 7$$ to be evaluated as 49, then you should write it as: $$(3 + 4) \times 7$$ The parentheses enclose a subexpression that should be evaluated before the expression as a whole can be evaluated. Of the three Boolean operators we have seen so far, NOT has the highest precedence, then AND, then OR. ## 1.4 Associativity and Commutativity Both the AND and OR operators (and, in fact, all binary Boolean operators) have the property of associativity. The property of associativity says that in an expression with more than one operator of the same kind, it does not matter which you evaluate first. In terms of equations, this would be: $$B*(C*D) = (B*C)*D$$ or $B + (C + D) = (B + C) + D$ All binary Boolean operators are also commutative. This means that the order in which the operands appear is not important. In equations, that would be $$B*C = C*B$$ or $B+C=C+B$ #### 1.5 Postulates and Theorems In 1854, the mathematician and philosopher George Boole published his book, 'An Investigation of The Laws of Thought', in which he demonstrated how classical logic could be defined with algebraic terminology and operations. Then, in 1938, C. E. Shannon published his paper "A Symbolic Analysis of Relay and Switching Circuits", which demonstrated a Boolean algebra of two values called "switching algebra", which could be used to represent the properties of bistable electric switching circuits. A minimal set of formal postulates is needed in order to define this Boolean algebra. Here we will define Boolean algebra to be an algebra defined over the set B, where B = (False, True) and over the operators AND (\*), OR (+) and NOT (/), such that: - All operators are closed (which means that it is impossible to create a Boolean expression that has a value other than True or False), - 2) Postulates 1 through 4 in Figure 1-5 are true, and - NOT is an operator which, when applied to a Boolean variable x, creates its complement such that if x = True then /x = False, and if x = False then /x = True. Given this basic set of rules, it is possible to derive any of the theorems in Figure 1-5. For example: Theorem 1a: x + x = x $$x + x = (x + x)*True$$ by Postulate 1b $= (x + x)*(x + /x)$ by Postulate 2a $= x + (x*/x)$ by Postulate 4b $= x + False$ by Postulate 2b $= x$ by Postulate 1a #### 1.5.1 Duality One of the most important properties of Boolean algebra is the *duality principle*. This principle states that any algebraic expression that may be deduced from the postulates of Boolean algebra has a dual which is also true. The dual of an expression is obtained by replacing all Trues with Falses, all Falses with Trues, all ANDs with ORs, and all ORs with ANDs. For example: Theorem 2a: x + True = True has the dual: x\*False = False which is theorem 2b. All postulates and theorems listed in Figure 1-5 are listed as pairs of duals. Of course, any of these theorems could also be derived without using the duality principle. For example: Theorem 2b: x\*False = False x\*False = False + (x\*False) by Postulate 1a = (x\*/x) + (x\*False) by Postulate 2b = x\*/x + False by Postulate 4a = x\*/x + False by Postulate 1a = False + (x\*False) + False by Postulate 2b | Postulate 1 | (a) x + False = x<br>(b) x*True = x | |-------------|----------------------------------------------------------------------| | Postulate 2 | (a) x + /x = True<br>(b) x*/x = False | | Postulate 3 | (a) x + y = y + x<br>(b) x*y = y*x | | Postulate 4 | (a) $x*(y + z) = (x*y) + (x*z)$<br>(b) $x + (y*z) = (x + y)*(x + z)$ | | Theorem 1 | (a) x + x = x<br>(b) x*x = x | | Theorem 2 | (a) x + True = True<br>(b) x*False = False | | Theorem 3 | /(/x) = x | | Theorem 4 | (a) $x + (y + z) = (x + y) + z$<br>(b) $x*(y*z) = (x*y)*z$ | | Theorem 5 | (a)/(x + y) = /x*/y<br>(b)/(x*y) = /x + /y | | Theorem 6 | (a) $x + (x*y) = x$<br>(b) $x*(x + y) = x$ | | Theorem 7 | (a) $(x*y) + (x*/y) = x$<br>(b) $(x + y)*(x + /y) = x$ | | Theorem 8 | (a) $x + (/x*y) = x + y$<br>(b) $x*(/x + y) = x*y$ | | Theorem 9 | (x*y) + (/x*z) + (y*z) = (x*y) + (/x*z) | Figure 1-5. Postulates and Theorems of Boolean Algebra # **(3**) #### 1.5.2 Using Truth Tables Finally, theorems may be demonstrated with truth tables. A theorem always holds true if it holds true for all cases. Since two variables can only have two values each, there are only four possible cases, so it is reasonable to look at a theorem on a case-by-case basis. For example, we can prove Theorem 5a with the following truth table: | | x | у | /(x + y) | (/x+/y) | |---|-----|-----|----------|---------| | Ī | F | F | Т | Т | | I | F/º | T - | F | F | | I | Т | F | F | F | | | Т | Т | F | F | Figure 1-6 It can be seen from Figure 1-6 that, in every case, /(x + y) is equal to (/x\*/y). ## 1.5.3 Complement of a Boolean Function A Boolean expression is some mixture of Boolean variables and operators that has a value. For example: $$x + y*z*/a$$ is a Boolean expression. A *Boolean function* is a statement in which two expressions are equated. For example: $$a = b*c$$ /(c\*d) = /c + /d are Boolean functions. The difference is the presence of an equal sign. It is worth noting that 'equals', or equivalence, is also a Boolean function, since two expressions either are or are not equal. However, in this book we will attempt to present only true equations, so the Boolean value of an equal sign may be ignored in functions. So far, we have talked about a Boolean expression's value as True or False. More frequently, these values are written as 1 and 0, with 1 standing for True, and 0 standing for False. From here on, we will also adopt this standard. The complement of an expression may be written easily by placing the NOT operator in front of the enclosed expression: $$/(x + y*z*/a),$$ but it is also possible to complement a function. The *complement* of a function is obtained by complementing both sides of an equation. For example, given the equation: $$/a = b*c + 1$$ the complement would be: $$/(/a) = /(b*c + 1)$$ which could be simplified: a = /(b\*c + 1)by Theorem 3a = /(b\*c)\*/1by Theorem 5aa = /(b\*c)\*0def. of complementa = 0by Theorem 2b Note the differences between obtaining the complement of a function, and obtaining the dual of a function. The complement is obtained by complementing the entire expression on both sides of the equation, and manipulating it from there with the given postulates and theorems. The dual of a function is obtained by replacing all 1's with 0's, all 0's with 1's, all ANDs with ORs, and all ORs with ANDs. In fact, the easiest way in which to obtain the complement of a function is by taking the dual of the function and complementing each individual variable (called a *literal*). For example, the complement of: $$F = (x + /y)*[W*(x + z)]$$ can be found by 1) taking the dual: $$F^{D} = (x*/y) + [W + (x*z)]$$ 2) complementing each literal: $$/F = (/x*y) + [/W + (/x*/z)]$$ ## 1.6 Algebraic Simplification A *literal* is a complemented (/x) or uncomplemented (x) variable. A *term* is a subexpression, often enclosed in parentheses. The equation: $$F = (x + /y)*/x$$ has three literals and two terms. Simplifying a Boolean equation is an attempt to minimize the number of literals or the number of terms in an equation. Unfortunately, in many situations, one can only be minimized at the expense of the other, so it is important to decide from the outset whether you are minimizing literals or terms. Literals can be minimized by repeated applications of the postulates and theorems of Boolean algebra (Table 1-6), but there is no algorithm; it is a trial and error process, and the result may not be unique. For example, the equation: $$F = (x*/z) + [(x + y)*/z]$$ may be simplified through the following steps: $$F = (x*/z) + [(x + y)*/z]$$ = $(/z*x) + [/z*(x + y)]$ Postulate 3b = $/z*[x + (x + y)]$ Postulate 4a = $/z*[(x + x) + y]$ Theorem 4a = $/z*(x + y)$ Theorem 1a The equation is now simplified because there are no postulates or theorems which, when applied, will serve to reduce the number of items further. #### 1.6.1 Sum-of-Products and Product-of-Sums When an equation is in the form: $$F = (a*b) + (c*/a) + d$$ for example, it is said to be in *sum of products* form. This is because the equation is composed of a number of product terms (AND) that are summed (ORed) together. The subexpression resulting from two operands being ANDed together is referred to as a product because of the resemblance of the AND operator to the multiplication operator of arithmetic; the result of OR is referred to as a sum because of the resemblance of the OR operator to the addition operator of arithmetic. When an equation is in the form: $$F = (a + b)*(a + /c)$$ for example, it is said to be in *product of sums* form, because it is composed of a number of sum terms (OR) that are ANDed together. Both sum of products and product of sums forms are called *standard forms*. #### 1.6.2 Canonical Forms If an equation has three variables that are complemented or uncomplemented, then there are a limited number of ways in which these variables can be ANDed or ORed together. Referring to Figure 1-7, under the column 'Minterms', and the subcolumn 'Term', there are eight different ways in which three variables could be ANDed together. Each combination has been given a name: the letter 'm' and a number. For example, the expression: while the expression: | Minterms | | Maxterms | | | | | |-------------------|----------------------------------|---------------------------|----------------------------------|--|--|--| | Term | Name | Term | Name | | | | | x*/y*/z<br>x*/y*z | m <sub>0</sub> | x + y + z | M <sub>0</sub> | | | | | x*y*/z | m <sub>1</sub><br>m <sub>2</sub> | x + y + /z<br>x + /y + z | M <sub>1</sub><br>M <sub>2</sub> | | | | | x*y*z<br>x*/y*/z | m <sub>3</sub><br>m <sub>4</sub> | x + /y + /z<br>/x + y + z | M <sub>3</sub> | | | | | x*/y*z<br>x*y*/z | m <sub>5</sub><br>m <sub>6</sub> | /x + y + /z<br>x + /y + z | M <sub>5</sub> | | | | | x*y*z | m <sub>7</sub> | /x + /y + /z | M <sub>7</sub> | | | | Figure 1-7 Using these shorthand notations for expressions, we can refer to the equation: $$F = (/x*y*/z) + (x*/y*/z) + (x*/y*z)$$ as: $$F = m_2 + m_4 + m_5$$ which is much more compact. When an equation is expressed in terms of these named AND subexpressions, or *minterms* it is said to be in *sum-of-minterms* form. Similarly, there are eight ways in which three variables may be ORed together. Such an OR subexpression is called a *maxterm*. The equation: $$F = (x + y + z)*(x + /y + /z)*(/x + /y + /z)$$ could also be written as: $$F = M_0 * M_3 * M_7$$ since each OR subexpression has been given a name consisting of an 'M' and a number (see the column 'Maxterms' in Figure 1-7). An equation expressed in this way is said to be written in *product-of-maxterms* form. Both sum of minterms and product of maxterms forms are called *canonical forms*. In many equations, not every variable is represented in every term, but it is still possible to write them in canonical form. A little algebraic manipulation will produce the missing terms that are needed. For example, the equation: $$F = (x*y*z) + (/x*y)$$ is missing a 'z' in its second term. In order to write this equation in sum of minterms form, we must first take the following steps: $$F = (x*y*z) + (/x*y*1)$$ $$= (x*y*z) + [/x*y*(z + /z)]$$ $$= (x*y*z) + (/x*y*z) + (/x*y*/z)$$ Postulate 2a $$= (x*y*z) + (/x*y*z) + (/x*y*/z)$$ Postulate 4a $$= m_2 + m_3 + m_7$$ To create a missing variable in a maxterm, use the duals of the postulates used above. To create more than one missing variable, expand the equation as many times as is needed by following the steps above. ### 1.6.3 Conversion Between Canonical Forms Canonical forms do not only exist because they are more compact. With canonical forms, it is a trivial matter to invert an expression, or to convert between sum-of-product and product-of-sum representations. Given the equation: $$F = (/a*b*/c) + (a*/b*c) + (a* b*c)$$ = $m_2 + m_5 + m_7$ we can take its complement by forming an equation from all the minterms that are NOT present in the equation: /F = $$m_0$$ + $m_1$ + $m_3$ + $m_4$ + $m_6$ = $(/a*/b*/c)$ + $(/a*/b*c)$ + $(/a*b*c)$ + $(a*/b*/c)$ + $(a*b*/c)$ Finally, using the dual/complement method, we can take the complement again. Of course, by Theorem 3 (Figure 1-5), anything that is complemented twice returns to its original value: $$F = (a + b + c)*(a + b + /c)*(a + /b + /c)$$ $$*(/a + b + c)*(/a + b + /c)$$ We have now expressed function F, originally a sum of products, in product-of-sums form. Any Boolean equation can be written in either form. Thus a quick way of doing this conversion is to write a product-of-maxterm equation using the maxterm numbers which did not appear in the original equation. In our example, we used the numbers 2, 5 and 7 for the sum-of-minterms form. In our product-of-maxterms form, we would use the maxterms 0, 1, 3, 4 and 6. $$F = M_0 * M_1 * M_3 * M_4 * M_6$$ = (a + b + c) \* (a + b + /c) \* (a + /b + /c) \* (/a + b + c) \* (/a + /b + c) This works because each maxterm is the dual of the minterm that has the same number. Of course, any equation written in the canonical forms can likely be simplified. After converting from standard form to canonical form, then converting from one canonical form to another, you may wish to simplify your equation. # 1.7 Exclusive-OR (XOR) and Equivalence (XNOR) There are two other frequently used operators which are really just special combinations of the AND, OR, and NOT operators. The first is the Exclusive OR operator. Its symbol and truth table is shown in Figure 1-8. Note that the simple OR function is true even when both conditions are true, which is somewhat unlike our conversational use of the word 'OR'. The XOR function is more like our normal use of 'OR': one or the other condition is true, but not both. $\mathbf{E}$ The XOR function X :+: Y is equivalent to x\*/y + /x\*y. | A | В | A :+: B1 | |-----------------|---|---------------| | 0 | 0 | 0 | | 0 | 1 | 1 | | . j <b>i</b> (5 | 0 | (#4) 01 (A) 4 | | 1 | 1 | 0 | Figure 1-8. The XOR Operator The Equivalence (XNOR) operators, symbols, and truth table are shown in Figure 1-9. It is true only when both conditions are the same. Thus XNOR is the complement of XOR Here x : \*: y is equivalent to x \* y + /x \* /y. | , <b>A</b> | В | A :*: B | |------------|-----------------|---------| | 0 | 0 | 1 | | 0 | 1 | 0 | | 1 | 0 | 0 | | -1 | 568 <b>1</b> 37 | 1,54, | Figure 1-9. The XNOR Operator # 1-8 Boolean Operator Summary Figure 1-10. Logic Gates | X | Y | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | F13 | F14 | F15 | F16 | |---|---|----|----|----|----|----|----|-----|----|----|-----|-----|-----|-------|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | - 1 - | 1 | 1 | 1 | | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | | | 0 | * | | х | | Υ | :+: | + | | :*: | /Y | 77 | /X | | | 1 | Figure 1-11 Boolean Operators Section with the section of sect # 2. Binary Systems Binary numbers utilize a base 2 number system that consists of two digits: '0' and '1'. This number system is used in current digital computer systems because the outputs of most switching circuits can only be in one of two logical states. Also, when transistor circuits are only operating in one of two modes greater reliability can be obtained. #### 2.1 Base Conversion Normally, decimal (base 10) numbers are written using a positional notation. In other words, the value of the number is determined by multiplying each digit by an appropriate power of 10 which is dependent on its relative position to the decimal point. #### Example 2.1 $$714.02 = 7 \times 10^2 + 1 \times 10^1 + 4 \times 10^0 + 0 \times 10^{-1} + 2 \times 10^{-2}$$ #### 2.1.1 Base-2 to Base-10 Conversion Similarly, binary (base-2) numbers are also position-dependent relative to the binary point: each binary digit is multiplied by an appropriate power of 2 in order to obtain the decimal equivalent. The following example shows the conversion from a base-2 number to a base-10 number. #### Example 2.2 $$101.01_2 = 1 \times 2^2 + 0 \times 2^1 + 1 \times 2^0 + 0 \times 2^{-1} + 1 \times 2^{-2}$$ = 4 + 0 + 1 + 0 + 1/4 = 5.25<sub>10</sub> Notice that the binary point separates the positive and the negative powers of 2. This is similar to the case of the decimal point separating the positive and negative powers of 10. #### 2.1.2 Base-10 to Base-2 Conversion Converting a base-10 integer to a base-2 integer requires utilizing the division method. To explain, let N represent the base-10 integer. Divide N by 2, since base-2 is desired. As a result, there should be a quotient, $Q_0$ , and a remainder, $R_0$ . Then divide $Q_0$ by 2 again and continue this process until the rinal quotient equals zero. The desired binary digits are the remainders resulting from each division step; the least significant bit starts with $R_0$ . #### Example 2.3 Converts 61<sub>10</sub> to binary: | 61/2 = 30 | remainder = 1 LSB | |----------------|-------------------| | 30/2 = 15 | remainder = 0 | | 15/2 = 7 | remainder = 1 | | 7/2 = 3 | remainder = 1 | | 3/2 = 1 | remainder = 1 | | 1/2 = 0 | remainder = 1 MSB | | 6110 = 1111012 | | Converting decimal fractions to binary requires successive multiplications by 2. Let F be a decimal fraction. Multiply this number F by 2 and obtain an integer and a fraction result. Take the fraction and multiply once again by 2. Continue this process until the fraction becomes zero, or until a sufficient number of digits has been reached. The desired digits are the integer parts that were obtained at each multiplication step. The most significant digit is obtained first. #### Example 2.4 Convert 0.375<sub>10</sub> to binary $$0.375_{10} = 0.011$$ Note that if this procedure doesn't terminate, then the result must be a repeating fraction. #### 2.1.3 Base-2 to Base-8 or Base-16 To convert binary to *octal* (base-8) or vice versa is very simple and can be done by inspection. Each octal digit corresponds to three binary digits, since it can be in one of eight states (0 to 7). Therefore, the binary number should be divided into groups of three starting from the binary point. Each group on both sides of the binary point is replaced by an octal digit representation. #### Example 2.5 $$101110.011_2 = 101 \quad 110 \quad . \quad 011$$ $$= 5 \quad 6 \quad . \quad 3_8$$ Similarly, binary to hexadecimal (base-16) and vice versa can also be done easily. This time, instead of three, the binary number is broken up into groups of four. The reason is because a hexadecimal digit can assume one of sixteen states (0 to 9, A, B, C, D, E and F). Again starting from the binary point, each group is replaced by its hexadecimal equivalent. #### Example 2.6 $$11100101.0011_2 = 1110 \quad 0101 \quad . \quad 0011$$ $= \quad E \quad \quad 5 \quad . \quad 3 \quad _{16}$ # 2.2 Simplicity of Binary Arithmetic Due to the design of logic networks, it is much easier to do binary than decimal arithmetic in digital systems. Although binary arithmetic is implemented in about the same manner, the addition tables are much easier. Fortunately, numerical subtractions may be performed by addition operations between numbers. This property is of little use in the decimal system. However, much can be gained if used in the binary system. This is mainly due to the fact that in a binary system, complements of numbers are easily implemented, and the same hardware can be used for addition and subtraction operations. This allows for considerable savings in terms of system hardware design. ## 2.2.1 1's Complement Finding the 1's complement of a binary number is easily done by inverting each digit (0 or 1). #### Example 2.7 The 1's complement of: 01011.1101 = 10100.0010 #### 2.2.2 Subtraction with 1's Complement To subtract two positive binary numbers X and Y, (X-Y), the following procedures should be used: - 1. Take the 1's complement of Y and add it to X. - 2. Check results for overflow carry: - a. If there is an overflow carry, add it to the least significant digit of the result. - If there is no overflow carry, the result is negative. Then, complement this result and place a minus sign in front. #### Example 2.8 #### 2.2.3 2's Complement no overflow The most widely used numbering manipulation technique in current digital computers is the 2's complement method. This method is easily implemented with any decent computer instruction set. Using the same hardware for addition and subtraction in 2's complement makes system design simpler and can lead to savings in cost. 1100.10 → -0011.01 → answer Finding the 2's complement of a binary number requires the following: - Take the logical complement by inverting each digit of the binary number. - 2. Add 1 to the least significant digit. #### Example 2.9 The 2's complement of 001100.01 is This technique can also be done by visual inspection. Start with the least significant digit of the number and visually scan to the left. Leave all digits unchanged until the first '1' is encountered. Then invert all the remaining digits to the left of this first '1'. Note that the binary point has no effect on this procedure. #### 2.2.4 Subtraction with 2's Complement The steps for subtracting two binary numbers X and Y, (X-Y), are as follows: - 1. Add X to the 2's complement of Y. - 2. Check result for overflow carry: - a. If there is an overflow carry, then throw it out. The result now represents (X-Y). - If there is no overflow carry, the number is negative. Take the 2's complement of the result and place a negative sign in front of it. #### Example 2.10 Note that in computing systems which need to represent negative numbers, the MSB serves as a sign bit. When it is '1', the number is negative. # 3. Karnaugh Maps # 3.1 Karnaugh Map Technique There exists a technique that allows the logic designer to minimize Sum of Product terms by utilizing Karnaugh maps. The Karnaugh map (sometimes referred to as K-map) graphically displays the implicants (minterms) of any sum-of-products expression in a matrix. It is derived directly from the truth table of this expression. K-maps are very useful for minimizing three, four, five and even six variable functions, but it gets too complicated beyond six. For expressions with more than six variables, the numerical manipulation should be done on a computer that uses a method such as the Quine-McCluskey method. This technique will not be discussed here. #### 3.1.1 Karnaugh Map Reading Procedure Each minterm cell in the K-map has a value of '1' as determined by the truth table. Circle those single minterm cells that will combine with its adjacent cells to form larger groups of 1, 2, 4, 8, etc. If each single minterm cell is grouped individually, the map reading process should yield the original Sum of Product expression. However, if two minterm cells are grouped together, at least one variable is dropped. This is because the theorem $$X*Y + X*/Y = X$$ has been executed once. If a group of four adjacent minterm cells have been combined, then the theorem has been executed twice, and two variables are dropped. A group of eight adjacent cells result in three variables being dropped. Therefore, the main objective is to minimize the number of minterm cell groupings while maximizing the number of minterm cells in each grouping. By minimizing the number of cell groupings, the number of product terms is reduced. On the other hand, by maximizing the number of cells in each grouping, the number of literals in each product term is reduced. For any product term, the variables which are included in the term are those whose values in the labels of the grouped cells are constant. The constant values give the polarity of the variables. In example 3.1, product term 1 has cells with labels ABC = 010 and 110. B and C are constant here; B is 1 and C is 0, giving the product term B\*/C. #### 3.1.2 Karnaugh Map Matrix Labels In labeling the K-map matrix, the following rule should be followed: Top to bottom or left to right: | Two-variable | Three-variable | Four-variable | |--------------|----------------|------------------------------------| | 00 | 000 | Add a '0' MSB and use the | | 01 | 001 | three-variable chart for the first | | 11 | 011 | half. For the second half, add a | | 10 | 010 | '1' MSB and repeat the same | | | 110 | chart in reverse order. | | | 111 | | | | 101 | | | | 100 | | Notice that the number of variables shown above is referring to one axis only (X or Y). However, this technique may be used for any number of variables that may be desired on each axis. For any axis greater than one variable, the second-half is a mirror image of the first-half with the MSB equal to a '1'. This can be seen above when comparing the three-variable list to the two-variable list. ## 3.1.3 Karnaugh Map Examples Examples of three- and four-variable K-maps are shown below. The corresponding truth tables for the examples are also shown to illustrate the derivation of the K-maps. #### Example 3.1 Three-Variable K-map: | A | В | С | F | |-----|----|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 1 | 1 | | 0 | 1 | 0 | 1 | | . 0 | 1. | 1 | 1 | | 1 | 0 | 0 | 0 | | 1 | 0 | 1 | 1 | | 1 | 1 | 0 | 1 | | 1 | 1 | 1 | 0 | product term 1= B\*/C product term 2 = /B\*C product term 3 = /A\*C F = B\*/C + /B\*C + /A\*C Truth Table # Example 3.2 Four-Variable K-map: | Α | В | С | D | F | |---|---|-----|---|---| | 0 | 0 | 0 | 0 | 1 | | 0 | 0 | 0 | 1 | 1 | | 0 | 0 | 1 | 0 | 1 | | 0 | 0 | 1 | 1 | 1 | | 0 | 1 | 0 | 0 | 1 | | 0 | 1 | 0 | 1 | - | | 0 | 1 | 1 | 0 | 0 | | 0 | 1 | 1 | 1 | 0 | | 1 | 0 | 0 | 0 | 1 | | 1 | 0 | 0 | 1 | 1 | | 1 | 0 | 1 | 0 | 1 | | 1 | 0 | 1 | 1 | 0 | | 1 | 1 | 0 | 0 | 1 | | 1 | 1 | 0 | 1 | 1 | | 1 | 1 | . 1 | 0 | 0 | | 1 | 1 | 1 | 1 | 0 | Karnaugh Map product term 1 = /C product term 2 = /A\*/B product term 3 = /B\*C\*/D F = /C + /A\*/B + /B\*C\*/D **Truth Table** # 4. Combinatorial Logic # 4.1 Logic Design Introduction Logic design is a combination of analysis, synthesis, minimization and implementation of Boolean functions. Boolean functions must originally come from worded statements. This is a very important part of logic design because the worded statement can be ambiguous and imprecise, while the Boolean equation must be unambiguous and exact. The conversion of words to equations is called synthesis. Engineers must be careful when synthesizing a problem because many times the originator of a problem is not a technical person. It is the responsibility of the logic designer to review the synthesis of the problem with the originator to make sure the solution is suitable. # 4.2 Combinatorial Design Combinatorial logic is a network whose output is solely dependent upon its inputs. It has no feedback loops or memory elements. The first step in combinatorial design is to analyze the problem and then define it in an exact manner. This will make synthesizing a Boolean equation much easier. Synthesis usually takes several steps. Using truth tables and K-maps are common ways of specifying a problem and putting it in the minimal Boolean form. #### Example 4.1 A seven-segment decoder decodes a BCD number and turns on the appropriate segments of a seven-segment digit. Given the seven-segment digit in Figure 4-1, develop a minimal equation for each segment by using a truth table and K-maps. Figure 4-1. Seven-Segment Decoder Forming a truth table from Figure 4-1 is done by writing all '10' possible inputs down, then determining which segments should be activated for each input. For example, segment 'a' is activated whenever; 2, 3, 5, 7, 8, 9 or 0 is input to the lecoder. Once the table is formed, a K-map can be made for each segment. The K-maps are used to derive a Sum of 'roducts logic equation for each segment. (-maps are an excellent way of forming equations when three o six variables are involved in a problem. Either of the two tandard algebraic forms of the function (sum-of-products or roduct-of-sums) can be derived. A network of AND and OR lates is obtained directly from either form. | DE01141 | INPUTS | | | | | OUTPUTS | | | | | | | |---------|--------|---|---|---|---|---------|----|----|----|---|---|--| | DECIMAL | W | x | Y | z | а | b | С | d | е | f | 9 | | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | 1 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | | 2 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1. | 0 | 1 | | | 3 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | | 4 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | 5 | 0 | 1 | 0 | 1 | 1 | 0 | 11 | 1 | 0 | 1 | 1 | | | 6 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1. | 1 | 1 | 1 | | | 7 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | 8 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | 9 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | | $g = W + X \cdot / Y + / X \cdot Y + Y \cdot / Z$ Figure 4-2 | ROW | W A B C MINTERMS | | MINTERMS | MAXTERMS | | |-----|------------------|---|----------|---------------|-------------------| | 0 | 0 | 0 | 0 | /A*/B*/C = m0 | A + B + C = M0 | | 1 | 0 | 0 | 1 | /A*/B*C = m1 | A + B + /C = M1 | | 2 | 0 | 1 | 0 | /A*B*/C = m2 | A + /B + C = M2 | | 3 | 0 | 1 | 1 | /A*B*C = m3 | A + /B + /C = M3 | | 4 | 1 | 0 | 0 | A*/B*/C = m4 | /A + B + C = M4 | | - 5 | 1 | 0 | 1 | A*/B*C = m5 | /A + B + /C = M5 | | 6 | 1 | 1 | 0 | A*B*/C = m6 | /A + /B + C = M6 | | 7 | 1 | 1 | 1 | A*B*C = m7 | /A + /B + /C = M7 | Figure 4-3 Minterm and Maxterm Expansions for 3 Variables Since a minterm is a product term, an unminimized sum-ofproducts expression may also be written with minterms. Each maxterm is a sum of variables. It is derived by solving a K-map for the *0-terms* instead of the *1-terms*. Maxterms are used in a product-of-sums solution. #### Example 4.2 Rewriting the Sum of Products equations from example 4.1 in minterm form can be done by inspecting the truth table or K-map. $a = \Sigma m (0, 2, 3, 5, 7, 8, 9, 10, 11, 12, 13, 15)$ $b = \Sigma m (0, 1, 2, 3, 4, 7, 8, 9, 10, 11, 12, 15)$ $c = \sum m (0, 1, 3, 4, 5, 6, 7, 8, 9, 11, 12, 13, 14, 15)$ $d = \sum m (0, 2, 3, 5, 6, 8, 10, 11, 13)$ $e = \Sigma m (0, 2, 6, 8, 10, 14)$ $f = \Sigma m (0, 4, 5, 6, 8, 9, 10, 11, 12, 13, 14, 15)$ $g = \Sigma m$ (2, 3, 4, 5, 6, 8, 9, 10, 11, 12, 13, 14,15) #### Example 4.3 We can easily rework the first two K-maps from Example 4.1 to get a maxterm solution. /a = X\*/Z + /W\*/X\*/Y\*Z a = (/X + Z)\*(W + X + Y + /Z) a = πM (1, 4, 6, 12, 14) /b = X\*/Y + X\*/Z b = (/X + Y)\*(/X + Z) b = \( \pi \) M (5, 6, 13, 14) Given either camonical form, it is a simple matter of converting to the other form, or the inverse of either form. | | DESIRED FORM | | | | | | | | |---------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|--|--|--|--| | GIVEN FORM | Minterm expansion of F | Maxterm expansion of F | Inverted Minterm expansion of F | Inverted Maxterm expansion of F | | | | | | Mintern<br>expansion of F | | Maxterm numbers are those numbers not on the minterm list for F | List minterms not present in F | Maxterm numbers<br>are the same as<br>minterm numbers<br>of F | | | | | | Maxterm expansion of F | Minterm numbers<br>are those numbers<br>not on the maxterm<br>list for F | | Minterm numbers<br>are the same as<br>maxterm numbers<br>of F | List maxterms not present in F | | | | | Figure 4-4 Conversion of Forms Table ## 4.3 NAND Gates and NOR Gates A set of logic operators is said to be functionally complete if any Boolean function can be expressed in terms of this set of operations. The set {AND, OR, NOT} is functionally complete. The NAND and the NOR gates are each functionally complete by themselves. Therefore they are called *universal* gates. Conversion of AND and OR networks to NAND networks is carried out by starting with a minimal sum of products expression and then applying the theorem; F = /(/F). This equation can then be manipulated using DeMorgan's theorem. | | X | Y | Z | |-----|---|----|------| | i | 0 | 0 | 2017 | | . 1 | 0 | 15 | 1 | | Ì | 1 | 0 | 1 | | | 1 | 1 | .0 | | | X | Y | . Z | |-----|---|-----|-----| | | 0 | 0 | 1 | | 100 | 0 | 1 ″ | 0 | | | 1 | 0 | 0 | | | 1 | 1 | 0 | $Z = \frac{X}{Y} \sum_{\text{LD00020M}} Z$ Figure 4-5. Truth Tables #### Example 4.4 From the K-map in Figure 4-6, we can find equations for an AND-OR, NAND-NAND, OR-NAND and NOR-OR networks. Figure 4-6. Karnaugh Map | F = A*B + /A*/C*/D + /A*C*D | AND-OR | |---------------------------------------------|-----------| | = /[/(A*B + /A*/C*/D + /A*C*D)] | | | = /[/(A*B)*/(/A*/C*/D) + /(/A*C*D)] | NAND-NAND | | =/[/A + /B)*(A + C + D)*(A + /C + /D)] | OR-NAND | | =/(/A + /B) + /(A + C + D) + /(A + /C + /D) | NOR-OR | In order to get a network of NOR gates we must start with the minimum product-of-sums form of F. #### Example 4.5 From the same K-map, we can also find equations for OR-AND, NOR-NOR, AND-NOR and NAND-AND networks. OR-AND $$F = (/A + B)*(A + C + /D)*(A + /C + D) OR-AND = /[/(/A + B) + /(A + C + /D) + /(A + /C + D)] NOR-NOR = /(A*/B + /A*/C*D + /A*C*/D) AND-NOR = /(A*/B)*/(/A*/C*D)*/(/A*C*/D) NAND-AND$$ NAND-NAND and NOR-NOR networks are very common in industry because both the NAND and NOR gates are universal gates. Thus, these gates are made in great quantities, making them more available for designers. A NAND-NAND network is made from a Sum of Products (SOP) solution. The AND and OR gates of the SOP solution are replaced by NAND gates with all the interconnections staying the same. Variables that are input directly to the output gate must be inverted. A NOR-NOR network is made from a Product of Sums solution. The OR and AND gates are replaced by NOR gates with all interconnections staying the same. Any variables that are input directly to the output NOR gates must be inverted. An easy way of forming either a NAND network from a Sum of Products solution or a NOR network from a Product of Sums solution is to place two inversion bubbles in series between the two levels as demonstrated in Figure 4-7. Figure 4-7. Network Conversion ## 4.4 Multiplexers Multiplexers are circuits which select one of 2n input lines using n selector lines. For example, an eight-input multiplexer (often called a 'MUX') selects one of 23 input lines using three select lines. #### Example 4.6 Design an 8:1 multiplexer in SOP form by using a truth table. | SELECT | | | T MULTIPLEXER INPUTS | | | | | | | | OUTPUT | |--------|----|---|----------------------|----|----|----|----|----|----|----|-----------------| | A | В | С | DO | D1 | D2 | D3 | D4 | D5 | D6 | D7 | Υ | | 0 | 0 | 0 | 0 | Х | х | Х | Х | х | х | Х | 0 | | 0 | 0 | 0 | 1 | Х | Х | Х | Х | Х | Х | Х | 1 | | 0 | ,0 | 1 | Х | 0 | Х | Х | Х | Х | Х | X | 0 | | 0 | 0 | 1 | Х | 1 | Х | Х | Х | х | Х | Х | 1 | | 0 | 1 | 0 | Х | Х | 0 | Х | Х | Х | Х | Х | 0 | | 0 | 1 | 0 | X | Х | 1 | х | Х | X | Х | Х | 1 | | 0 | 1 | 1 | Х | Х | X | 0 | Х | х | Х | Х | 0 | | 0 | 1 | 1 | Х | Х | X | 1 | х | X | Х | Х | (* <b>1</b> % ) | | 1 | 0 | 0 | Х | Х | Х | Х | 0 | Х | Х | Х | 0 | | 1 | 0 | 0 | X. | Х | Х | Х | 1 | Х | X | Х | e 1 | | 1 | 0 | 1 | Х | Х | Х | Х | Х | 0 | Х | Х | 0 | | 1 | 0 | 1 | Х | Х | Х | Х | Х | 1 | X | Х | 1 | | 1 | 1 | 0 | Х | Х | х | Х | X | Х | 0 | X | 0 | | 1 | 1 | 0 | Х | X | Х | X | X | X | 1 | X | 1 | | 1 | 1 | 1 | х | Х | Х | Х | х | X | Х | 0 | 0 | | 1 | 1 | 1 | Х | Х | Х | X | Х | Х | Х | 1 | 1 | Figure 4-8. Truth Table for 8:1 Multiplexer As can be seen from the truth table A, B and C select one of the eight multiplexer inputs to appear on the output, Y. If A, B and C = 011, then Figure 4-9 shows that the D3 AND gate will be enabled while all the other AND gates will be disabled. This allows D3 to be 'ORed' with seven zeros and thus end up on the output Y. Figure 4-9. 8:1 Multiplexer Circuit #### Example 4.7 We will design a dual 8:1 mux in a PAL device. When selecting a PAL device, several things must be considered. Will the design need registers? How many inputs and outputs are there? Are the outputs active high or active low? For a dual 8:1 mux the select lines will be shared, but the eight data inputs to each mux are independent. Thus we need nineteen inputs and two outputs for the design. This narrows our choices down to one PAL device, the PAL20L2. The output of the PAL20L2 is active low but this causes no problems because an active high output will result by simply inverting all the data inputs. The Boolean equations are shown below; the complete logic diagram is on the next page. Multiplexers have been widely used as logic devices as well as selector circuits. A 4:1 mux can be used to realize any three-variable function. An 8:1 mux can realize any four-variable function. #### Example 4.8 Solve the K-map in Figure 4-10 and build the circuit with an 8:1 multiplexer. Figure 4-10. Eight One-Variable Karnaugh Maps A, B and C are used as control inputs to the multiplexer, this leaves D as the only real variable in the problem. The 16-square K-map can thus be broken up into eight one-variable K-maps. Each map is solved for one of the eight data inputs to the 8:1 multiplexer. The solution is shown in Figure 4-11. | | | С | В | Α | |--------------------|---------|---|---|---| | 8:1<br>MULTIPLEXER | IO = /D | 0 | 0 | 0 | | <u>D</u> 10 | l1 = 1 | 1 | 0 | 0 | | | l2 = /D | 0 | 1 | 0 | | 0 13 OUT 1 | 13 = 0 | 1 | 1 | 0 | | 1 — 15 | l4 = 1 | 0 | 0 | 1 | | <del>□</del> 17 | 15 = 1 | 1 | 0 | 1 | | S0 S1 S2 | 16 = 0 | 0 | 1 | 1 | | Åbc | 17 = /D | 1 | 1 | 1 | Figure 4-11 #### 4.5 Decoders On a multiplexer with n address lines, one of the $2^n$ inputs is selected to be output. On a decoder with n address lines, one of the $2^n$ output lines is forced either high or low, depending on the design of the decoder. Figure 4-12 shows a truth table for an active high 3-to-8 decoder. | SELECT LINES | | | OUTPUT LINES | | | | | | | | |--------------|---|-----|--------------|---|---|---|---|---|---|---| | A | В | ပ | f | g | h | i | ı | k | ı | m | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 1 / | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | 0 | 1 | a 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 14- | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Figure 4-12. Decoder Truth Table A decoder will have as many outputs as there are possible binary input combinations. It can be seen from Figure 4-12 that only one output can be equal to 1 at any time. The active output represents the minterm combination that was input to the decoder. It can also be noticed from Figure 4-12 that there is not a combination of inputs that will give all 0's on the outputs. Many designs actually need to be able to make all outputs inactive; this can be done simply by putting an enable line in all of the output AND gates. The logic design and block diagram for the 3-bit decoder in Figure 4-12 appears in Figure 4-13. # **Logic Diagram** Figure 4-13. (a) Logic Diagram for 3-to-8 Decoder (b) Block Diagram for 3-to-8 Decoder # 4.6 Magnitude Comparator A magnitude comparator is combinatorial circuit that compares two numbers, and puts out one of three signals: A > B, A = B or A < B. #### Example 4.9 We can design a 3-bit magnitude comparator in a PAL device. A > B = A2\*/B2 + A1+/B2+/B1 + A0+/B2+/B1+/B0 + A1+A0+/B2+/B0 + A2+A1+/B1 + A2+A1+A0+/B0 + A2+A0+/B1+/B0 Figure 4-14 B > A = /A2+B2 + /A2+/A1+B1 + /A2\*/A1\*/A0\*B0 + /A2\*/A0\*B1\*B0 + /A1+B2+B1 + /A0+B2+B1+B0 + /A1+/A0+B2+B0 Of course, A = B only if not A < B and not A > B (A = B) = /(B < A)\*/(B > A) Figure 4-14 (Continued) The six-variable K-maps are used to produce Sum of Product equations for A > B and B < A. These equations are then used to form the two-level logic diagram of the 3-bit magnitude comparator and the equation for A = B, as shown in Figure 4-15. Figure 4-15 The logic diagram of the 3-bit comparator shows that there are six inputs and three outputs in the circuit. Each output is derived from at most seven product terms. This design can fit into a portion of a PAL16P8, as shown on page 8-18. Note that 5 outputs remain, which can be used for some other functions if needed. #### 4.7 Adder A binary adder takes two binary inputs, adds them, and generates the binary sum. A full adder is the basic building block of any adding network. A full adder is a 1-bit adder with a carry-in and a carry-out. The truth table is shown in Figure 4-16. The logic design and block diagram appear in Figure 4-17. | A | В | C <sub>IN</sub> | Y | C <sub>OUT</sub> | |---|---|-----------------|---|------------------| | 0 | 0 | 0 | 0 | 0 | | 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 | 1 | Figure 4-16. Truth Table for Full Adder The truth table is used to form K-maps for the outputs Y and $C_{\rm in}$ . These simple K-maps are solved to obtain equations for Y and $C_{\rm in}$ . Figure 4-17. (a) Karnaugh Maps for the Full Adder, (b) Logic Diagram, (c) Block Diagram A parallel 4-bit adder can be designed using four full adders. Figure 4-18. Parallel 4-Bit Adder To implement this circuit in a PAL device, each carry-out is directly input to the next digit's carry-in. Nine inputs and eight outputs are needed. Three of the outputs (the first three carry-outs) are only needed so they can be fed back into the circuit as inputs. A PAL16L8 is the perfect PAL device for this design. The logic diagram is shown on page 8-19. # **Logic Diagram** ## **Logic Diagram** #### 4.8 Hazards Even though a digital network is designed correctly, it still may have erroneous outputs at times due to *hazards*. Hazards exist because physical circuits do not behave ideally. For example, a D-type flip-flop has two outputs; Q and /Q, which should always be complements of each other. In the real world Q may be switching from 1 to 0 and /Q from 0 to 1. Unless both Q and /Q switch at exactly the same time, Q will equal /Q for some finite amount of time. In some cases this could cause the network to malfunction. The change in the flip-flop output may not cause the steady-state output of the network to change, but the transient output may have had a spurious change due to the non-ideal flip-flop. If, for instance, the network's output was the set line of a latch, the latch would set due to the hazard. There are two types of hazards, static and dynamic. Static hazards occur when the steady-state output of a network is not supposed to change due to an input change, but a momentary change does occur as the inputs change. This is often referred to as a "glitch." Static hazards are qualified further as either static 1 hazards or static 0 hazards. Static 1 hazards exist when the steady-state output is 1, static 0 hazards exist when the steady-state output is 0. Figure 4-19. (a) Static 0 Hazard, (b) Static 1 Hazard Dynamic hazards occur when the steady-state output is supposed to change due to an input change. The hazard occurs when the transient output changes several times before settling down. Figure 4-20. Dynamic Hazard There are two classifications of hazards: function hazards and logic hazards. Function hazards can be present when more than one input variable changes. It is easy to see from the K-map in Figure 4-21 why function hazards exist. Figure 4-21. Karnaugh Map with Function Hazards A function static 1 hazard is present when the input variables A, B, C and D go from <0000> to <0101>. If both B and D changed simultaneously no temporary erroneous pulse would appear on the output; however in the real world either B or D would change first. The transient output would have gone to D as a result of being momentarily in state <0100> or <0001>. Looking at the K-map, it is easy to see function static hazards and function dynamic hazards. The easiest way to avoid function hazards is by restricting input changes to one variable at a time. This method is not always possible though, since the inputs may not be predictable. Logic hazards exist because of the way a function is realized. Logic hazards can exist even if input changes are restricted to one variable at a time. A K-map is a very good way of locating logic hazards. When trying to locate the static 0 and static 1 logic hazards on a K-map it is only necessary to map the 1-sets or the 0-sets. A 1-set is a product expression derived from a grouping of 1's on the K-map. If there are two adjacent input states that produce a 1 on the output, but are not covered by the same 1-term, a static logic hazard exists. Logic hazards may be eliminated by redesigning the circuit so adjacent input states that produce ones are covered by the same 1-term. Figure 4-22. (a) Karnaugh Map with Two Logic Hazards (b) Karnaugh Map with No Logic Hazards # 5. Sequential Logic #### 5.1 Introduction In the previous section, combinatorial circuits were discussed — circuits whose outputs are determined completely by their present inputs. Outputs of some networks depend not only on their present inputs but also on the sequence of their past inputs. These circuits are called *sequential* switching networks. Sequential networks must be able to remember the past sequence of their inputs in order to be able to produce new outputs. In order for a sequential circuit to remember the previous inputs, it must retain those values in some memory elements. The most basic memory element is called a *flip-flop*. Flip-flops are bistable devices with one or more inputs that affect their outputs. The term *bistable* means that the outputs are stable in either of two states. There are two types of flip-flops: unclocked and clocked. Unclocked flip-flops are often referred to as latches. Clocked flip-flops are often grouped into registers. # 5.2 Unclocked Flip-Flops – Latches ## 5.2.1 S-R Latch The circuit in Figure 5-1a is called a SET-RESET or an S-R latch. An S-R latch has two inputs which are used to control the state of the latch. The rules for this type of latch are: - If SET = RESET = 0, then the latch remains in the same state, and the output does not change. - A '1' on the SET input and a '0' on the RESET input will make the latch SET to '1'. - A '0' on the SET input and a '1' on the RESET input causes the latch to RESET to '0' state. - If SET = RESET = 1, then Q and /Q will be '0' at the same time, which is meaningless. When designing with an S-R latch, we should remember that SET = RESET = 1 is forbidden. The S-R latch circuit, state table, characteristic equation and waveforms are shown in figure 5-1. Latches can have more than two inputs. In Figure 5-2, we examine a latch circuit that has two SET terms instead of one. The logic diagram and the transition table are shown. In some applications using latches, it is desirable for the input data to be effective only when another signal — usually referred to as a control signal — is active. For these applications, the S-R latch could be modified as shown in Figure 5-3. It is apparent from Figure 5-3 that the values of SET and RESET are effective only when the control signal (C) is active. When C = 0, changes in the SET and RESET inputs do not have any effect on the output. Of course in the input of the latch does not affect the output immediately; there is a short delay for this change to appear at the output. This delay, shown in figure 5-3(b), is caused because of the propagation delays of the gates between inputs and outputs. Figure 5-1. S-R Latch (a) Logic Circuit (b) State Table (c) Characteristic Equation (d) Waveforms Figure 5-2. S-R Latch with two SET inputs (a) Logic diagram (b) State Table Figure 5-3. S-R Latch with Control (a) Logic Diagram (b) Waveforms #### 5.2.2 D-type Latch Other kinds of latches are used in sequential circuits. One of the most popular latches is called a *delay latch*, or D-type latch. An S-R latch is modified to a D-type latch by inserting an inverter between S and R, and calling the input "D" instead of "S". The D-type latch will take the value of its input and transfer it to the output. The advantage of the D-type latch over the S-R latch is that in the former only one input is needed and there is no forbidden state. The only disadvantage of the D-type latch is that it does not have a "no change" condition. This condition can be provided by inserting a control signal, C, as an input to the latch (Figure 5-4). This configuration is probably the most widely used one, with the control input commonly called the "Gate". Devices with active high gates and with active low gates are both commercially available. Figure 5-4. D-type Latch with Gate (a) Logic Circuit (b) State Table (c) Waveforms #### 5.2.3 J-K Latch Another useful latch is the J-K latch which is shown in Figure 5-5. This latch consists of an S-R latch with two AND gates in front of the inputs. This is most useful because J-K latches act like S-R latches, and it is permissible to apply '1' to both inputs simultaneously. The state table and characteristic equation for a J-K latch are also shown in Figure 5-5. | St | Rt | Qt | Q <sub>t + 1</sub> | | |----------|---------------|-----|--------------------|--------------| | 0 | 0 | 0 . | 0 | | | , 0 | 0 | 1 | . 1 | | | 0 | 1 8 | 0 | 0 | | | 0 | 1 | 1 | 0 | a selfactive | | 1 | 0 | 0 | eri. 1 | 4.6 | | 1 | 0 | 1 | 1 | (7.85.80°). | | <b>1</b> | , <b>1</b> ., | 0 | <b></b> | ( | | 1 | 1 | 1 | 0 | | | | | (b) | | | Figure 5-5. J-K Latch (a) Logic Diagram (b) State Table and Characteristic Equation #### 5.2.4 T-type Latch Another type of latch is a *triggered latch*, or T-type latch, which has only one input called T. Whenever T is high, the latch changes state. A T-type latch is realized by connecting both J and K to one input, T. (a) | Ţ | Q | Q <sub>t+1</sub> | ] ~ 101 | |---|---|------------------|------------------------------------------| | 0 | 0 | 0 | | | 0 | 1 | 1 | | | 1 | 0 | 1 | <u> 'U'</u> | | 1 | 4 | 0 | Q <sub>t+1</sub> = /T+Q + T<br>= T :+: Q | Figure 5-6. T-type Latch (a) Logic Diagram (b) State Table and Characteristic Equation # 5.3 Clocked Flip-Flops - Registers In the previous section, different types of latches were discussed. Clocked flip-flops of the same types are available (S-R, J-K, D and T), and the state equations are the same, except that the output change in clocked flip-flops occurs on the clock edge. In general, clocked flip-flops are more common than unclocked flip-flops, so the word "clocked" is often left out. Thus a D-type flip-flop is a clocked element, whereas a D-type latch is unclocked. Note, however, that this is common usage, not a definition. Figure 5-7 illustrates the difference between a D-type latch and a D-type flip-flop. Figure 5-7. Comparison of a D-type latch and a positive edgetriggered D-type flip-flop #### 5.3.1 Characteristic Equations The characteristic equations for various flip-flops are summarized as follows: $$\begin{array}{lll} \mathbf{Q}_{t+1} = \mathbf{S} + /\mathbf{R} * \mathbf{Q}_t & \mathbf{S} \text{-R flip-flop} \\ \mathbf{Q}_{t+1} = \mathbf{J} * / \mathbf{Q}_t + /\mathbf{K} * \mathbf{Q}_t & \mathbf{J} \text{-K flip-flop} \\ \mathbf{Q}_{t+1} = \mathbf{T} + \mathbf{Q}_t & \mathbf{T} \text{-type flip-flop} \\ \mathbf{Q}_{t+1} = \mathbf{D} & \mathbf{D} \text{-type flip-flop} \end{array}$$ In the above equations $Q_{t+1}$ is the next state and $Q_t$ is the present state. We can convert one flip-flop to another by inserting gates between the inputs and the actual flip-flop. A group of clocked flip-flops forms a register. A register is a digital device that is used to hold several bits of information. A register may be a combination of flip-flops and gates. The gates control how and when the data from the flip-flops is transferred. # **5.4 Designing Synchronous Sequential Circuits** In this section, we will familiarize ourselves with the analysis and synthesis of synchronous sequential circuits. Analysis will be covered first, since it will make the understanding of synthesis easier. The present states of a sequential circuit depend not only on the present inputs, but also on the past states. A sequential circuit is constructed of flip-flops and gates. The gates form the combinatorial part of a sequential circuit; the flip-flops provide the memory of past states. A general block diagram of a sequential circuit is shown in Figure 5-8. There are two basic types of sequential circuit: synchronous and asynchronous. Synchronous circuits are controlled by a common clock; these types of circuits are the easiest to design. Asynchronous circuits have independently clocked flip-flops whose clock rates may not have any relationships to each other. Such circuits may be faster than sychronous circuits, but are much harder to design. Figure 5-8. Sequential Circuit Block Diagram The input combinatorial logic section receives external inputs and feeds information to the flip-flops. The flip-flops have a feedback path back to the input combinatorial circuit. At the rising edge of each clock pulse the information from the input combinatorial circuit is read into the flip-flops and the new outputs are generated through the output combinatorial circuit. The outputs do not change until the next clock edge. Figure 5-9, shows an example of a sequential circuit. Figure 5-9. Example of a Sequential Circuit This circuit consists of two J-K flip-flops, an inverter, an AND gate and an XOR gate. It has an external input, X, and an external output, Z. #### 5.4.1 State Transition Tables The states of a sequential circuit are determined by its inputs, the outputs and states of the flip-flops. In order to examine these states, we should determine the input equations to the flip-flops. From Figure 5-9 we have: $$J_A = X :+: B$$ $J_B = X*/A$ $Z = A$ $K_A = /X$ $K_B = X$ The characteristic equation for a J-K flip-flop gives: $$A_{t+1} = J_A * / Q + / K_A * Q$$ $$= (X :+: B) * / A + X * A$$ $$= (X * / B + / X * B) * / A + X * A$$ $$= / A * / B * X + / A * B * / X + A * X$$ $$B_{t+1} = J_B*/Q + /K_B*Q$$ = $/A*/B*X + B*/X$ These are called the *state equations*. The corresponding K-maps are: Using these maps, the *state transition tables* for Figure 5-9 can be derived. There are only four different combinations that A and B can have. The next state values are derived using these four possible combinations. The present state is the state of the flip-flop before the clock pulse; the next state is the state of flip-flop after the clock pulse has been applied. The present output, Z, is the output of the sequential circuit after the clock pulse. As mentioned before, the circuit can have four states: AB = 00, 01, 11 and 10. At this point, we try to cover transitions for one input state. Suppose the circuit is in the 00 state. If an X = 0 input is applied, the next state will be 00. If an X = 1 is applied, the next state will be 11. The output for both cases is Z = 0. | PRESENT<br>STATE | | STATE<br>B <sub>t+1</sub> | PRESENT<br>OUTPUT | |------------------|-------|---------------------------|-------------------| | АВ | X = 0 | X = 1 | Z | | 00 | 00 | 11 | 0 | | 01 | 11 | 00 | 0 | | 11 🔻 🛠 | 01 | 10 | 1 | | 10 | 00 | 10 | 1 | Figure 5-10. State Transition Table for Figure 5-9. #### 5.4.2 State Tables and State Diagrams We can assign names to the four possible states: $S_0 = 00$ , $S_1 = 01$ , $S_2 = 11$ and $S_3 = 10$ . Using these assignments the state transition table can be modified to the *state table* shown in Figure 5-11. | PRESENT | NEXT | STATE | PRESENT | | |---------|-------|-------|-------------------|--| | STATE | X = 0 | X = 1 | OUTPUT Z | | | S0 | S0 | S2 | 0 | | | S1 | S2 | S0 | 0 | | | S2 | S1 | S3 | ggiroff interview | | | S3 | S0 | S3 | 1 | | Figure 5-11. State Table for Figure 5-9 A state diagram can be derived using the state table. A state diagram shows transitions between states. Each state is represented by a circle, and the transitions between states are shown by arrows. The condition under which a transition occurs is represented by X/Z. Applying an input, X, a transition from one state to the other takes place, and an output Z will be produced. The state diagram for the state table in Figure 5-11 is shown in Figure 5-12. Figure 5-12. State Diagram for Figure 5-9 We have gone through a complete analysis procedure for the previous example. This process can be summarized as follows: - 1. Using a given network, determine the input equations. - Derive the next state equations, using the flip-flop characteristic equations: $\begin{array}{lll} Q_{t+1} &= D & & D\text{-type flip-flop} \\ Q_{t+1} &= T :+: Q & T\text{-type flip-flop} \\ Q_{t+1} &= J*/Q + /K*Q & J\text{-}K flip-flop} \\ Q_{t+1} &= S + /R*Q & S\text{-}R flip-flop} \end{array}$ - 3. Derive the corresponding K-maps and transition tables. - 4. Assign state names and make the state table. - 5. From the state table, draw the state diagram. The synthesis of a sequential circuit uses the same steps, but in reverse order. A flow chart of the procedure is shown in Figure 5-13. Figure 5-13. Flow Chart of Sequential Circuit Synthesis #### 5.4.3 Design Examples Let's look at the procedure for designing sequential circuits in more detail by analyzing some design problems. The design steps will follow the flow diagram in Figure 5-13. ### Example 5.1 We will design a clocked sequential circuit which receives an input, X, and will produce an output Z=1 after it has received an input sequence of 0010 or 100. #### Solution: The first step is to make a state diagram. The state diagram will start in a state designated by S0. If X=0 is input while in state S0, it could be the start for the 0010 sequence, so we move to state S1. If a 1 is receive, the circuit will go to state S4, which could be the start for the 100 sequence. When in the S1 state, one of two inputs could be received: X=0 or X=1. If X=0, then the circuit could still follow the 0010 sequence, because so far it has received the 00 sequence; this takes us to state S2. If X=1, then the input sequence would be 01 so far, which cannot follow the 0010 any more, but could be a start for the 100 sequence. Therefore under this condition the circuit would have a transition from state S1 to S4. While in the S4 state, if an X = 1 is received, it would stay in the same state, because this of 11 could start a new 100 pattern. If X = 0 is received, the 100 pattern could continue, because 10 follows the 100 pattern. When in the S2 state, if an X=0 is received, it will stay in the S2 state; if X=1, then it will have a transition from the S2 to the S3 state. While in the S3 state, we will have a transition to state S4 if X=1, because the input sequence would be 0011, which cannot follow the 0010 sequence any more, but the 1 at the end could be a beginning for the 100 sequence. If X=0 is received then the 0010 sequence is complete and an output Z=1 is generated. At the same time in the 0010 sequence, the 10 at the end could be the start of the 100 sequence. Therefore we move from the S3 to the S5 state. While in the S5 state an X=1 will transfer the circuit from S5 to S4, and an X=0 will cause a transition from S5 to S6. Under this condition a Z=1 is generated for the output, because the 100 sequence for the inputs has occurred. From the S6 state we will have a transition from S6 to S2 if X = 0, and a transition to S3 if X = 1. A state diagram of this design is shown in Figure 5-14a. By analyzing the state diagram, a state table is generated (Figure 5-14b). A careful look at the state table will show that the S2 and the S6 states are equivalent, because under X=0 they both have a transition to state S2 with Z=0, and under X=1 they would transfer to S3 with Z=0. So the state table can be reduced to Figure 5-14c. After summarizing the state table, there will be a total of six states left, so at least three variables will be needed for the state assignments ( $2^3=8$ ). In this case only six assignments will be used. The state variables are designated by A, B and C. The state assignments are illustrated in Figure 5-14d. | PRESENT | NEXT | STATE | PRESENT OUTPUT | | | |---------|-------|-------|----------------|-------|--| | STATE | X = 0 | X = 1 | X = 0 | X = 1 | | | S0 | S1 | S4 | 0 | 0 | | | S1 | S2 | S4 | 0 | 0 | | | S2 | S2 | S3 | 0 | 0 | | | S3 | S5 | S4 | 1 | 0 | | | S4 | S5 | S4 | 0 | 0 | | | S5 | S6 | S4 | 1 1 | 0 | | | S6 | S2 | S3 | 0 | 0 | | (b) | NEXT | STATE | PRESENT OUTPUT | | | |-------|---------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | X = 0 | X = 1 | X = 0 | X = 1 | | | S1 | S4 | 0 | 0 | | | S2 | S4 | 0 | 0 | | | S2 | S3 | 0 | 0 | | | S5 | S4 | 1 | 0 | | | S5 | S4 | 0 | 0 | | | S2 | S4 | 1 | 0 | | | | X = 0 S1 S2 S2 S5 S5 | S1 S4 S2 S4 S2 S3 S5 S4 S5 S4 | X = 0 X = 1 X = 0 S1 S4 0 S2 S4 0 S2 S3 0 S5 S4 1 S5 S4 0 | | Figure 5-14. Example 5.1 (a) State Diagram (b) State Transition Table (c) Reduced State Diagram (d) Reduced State Transition Table From the assignment table, we derive the K-maps for each state. In this design the circuit is realized by J-K flip-flops, therefore two K-maps are needed for each state variable (shown in Figure 5-15). These can be derived from a K-map of the transition, and the J and K characteristics in figure 5-15(a). | $Q_t \rightarrow Q_{t+1}$ | J | K | |-----------------------------------------|------------------|------------------| | 0 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>1<br>X<br>X | X<br>X<br>1<br>0 | | (a) | | | | _ | C, X | i gd | | | i de de | |------|------|------|----|----|----------| | A, B | \_ | 00 | 01 | 11 | 10 | | | 00 | 0 | 1 | 1 | 0 | | | 01 | 0 | 0 | 1 | 1 | | | 11 | X | x | x | x | | | 10 | 1 | 1 | 1. | 0 | | | - | | | | TB004108 | | c, x | 11/11 | 1847 | | | |-------------|-------|------|----|----------| | A, B | 00 | 01 | 11 | 10 | | 00 | 0 | 0 | 0 | 1 | | 01 | 1 | 1 | 0 | 0 | | 11 | x | X | x | x | | 10 | 0 | 0 | 0 | 1 | | - 1 m - 1 m | | | | TB004208 | Figure 5-15. Karnaugh Maps for Example 5.1 $J_{c} = B*X + /B*/C*/X$ $K_{c} = /B + X$ (d) Z = A\*C\*/X + B\*C\*/X(e) Figure 5-15 (Continued) The state equations are derived from the K-maps. Using the state equations, the logic diagram in Figure 5-16 is obtained. The state equations are summarized as follows. $$J_A = /B*X + B*C$$ $J_B = C*/X$ $J_C = B*X + /B*/C*/X$ $K_A = /C*/X$ $K_B = C$ $K_C = /B + X$ Figure 5-16. Circuit Diagram for Example 5.1 #### Example 5.2 We will derive the state diagram, state transition table, and state equations of a sequential circuit which adds five to a binary number in the range of 0000 to 1010 (decimal 0 to 10). The inputs and outputs will be serial with the least significant bit arriving first. This design will be realized with J-K flip-flops. Solution: In Figure 5-17a, all the possible combinations for the input and the output are shown. The sequence will start from state A. At time $t_0$ (when the first input is received), if X=0, then we look at the map for all possible combinations and notice that at $t_0$ whenever X=0, the output is a 1. Thus, if the present state is A, under X=0 the output is Z=1. On the other hand, if X=1 the map shows that Z will be a 0. At time $t_1$ , if X=0 and the sequence of the inputs has been 00 then the output would be a 01. So in this transition Z=0. Likewise, the remaining states of the state diagram can be derived by inspection of the table in Figure 5-17b. Note that the states have been labeled arbitrarily and that we have not yet determined how the states will be implemented. The state table is determined from the state diagram. Inspecting the state table shows that some of the states are equivalent. States K, J, I, and H have the same next state under X=0 and X=1, and produce the same outputs; therefore K=J=I=H, and they can be replaced by the H state. This allows us to reduce the state table to the table shown in Figure 5-18b. There are now a total of nine states used, so four state variables will be needed. The state variables are called A, B, C and D. A complete state transition table is shown in Figure 5-18c. The K-maps are drawn from the state table. The state equations are derived using the K-maps. | $J_A = B*/C*D*X$ | | K <sub>A</sub> = 1 | | |-----------------------|------------|--------------------|---------------| | $J_B = C + D \cdot X$ | | $K_B = C + D$ | | | $J_C = B*/X + D*/X$ | + /D*X | $K_C = B + /C$ | ) | | $J_D = /A*/B*/X + B$ | */C | $K_D = B*/X +$ | - C*/X + /C*X | | Z = /A*/B*C + /B* | /D*/ X + / | C*/D*/X + 0 | C*D | | INPUT<br>X | | | | | PUT<br>Z | | | |----------------|----------------|----------------|----------------|----------------|----------------|----|----------------| | t <sub>3</sub> | t <sub>2</sub> | t <sub>1</sub> | t <sub>o</sub> | t <sub>3</sub> | t <sub>2</sub> | t, | t <sub>o</sub> | | 0 | 0 | 0 | 0 | 0 . | 1 | 0 | 1 | | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | | 0 | 1 | 1 | 1 | 1. | 1 | 0 | 0 | | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | Figure 5-17. Example 5.2 (a) Truth Table (b) State Diagram | DDE05NT 07475 | NEXT | STATE | Z | | | |----------------|-------|-------|-------|-------|--| | PRESENT STATE | X = 0 | X = 1 | X = 0 | X = 1 | | | Α | В | С | 1 | 0 | | | В | D | E | 0 | 1 | | | С | F | | 11 | | | | D | G | н | 1 | 1 | | | E | 1 | J | 1 | 0 | | | <b>F</b> . (4) | . K | L | 0 | 0 | | | G | Α | Α | | | | | Н., | Α | Α | 1 | 1 | | | | Α | Α | 1 | 1 | | | J | Α | Α | 1 | 1 | | | κ | Α | Α | 1 | 1 | | | L. L. | Α | | 1 | | | | | NEXT | STATE | Z | | | |---------------|-------|-------|-------|-------|--| | PRESENT STATE | X = 0 | X = 1 | X = 0 | X = 1 | | | Α | В | С | 1 | 0 | | | В | D | Ε | 0 | 1 | | | С | F | | 1 | - | | | D | G | Н | . 1 . | 1 | | | E | Н | Н | 1 | 0 | | | F. P. S. | Н | L | 0 | 0 | | | G | Α | Α | 0 | 0 | | | Н | Α | Α | 1 | 1 | | | L S | Α | - | 1 | _ | | | PRESENT STATE | NEXT | STATE | Z | | |---------------|-------|-------|-------|-------| | ABCD | X = 0 | X = 1 | X = 0 | X = 1 | | 0000 | 0001 | 0010 | 1 | 0 | | 0001 | 0011 | 0100 | 0 | 1 | | 0010 | 0101 | _ | 1 | | | 0011 | 0110 | 0111 | 1 | 1 | | 0100 | 0111 | 0111 | 1 | 0 | | 0101 | 0111 | 1000 | 0 | 0 | | 0110 | 0000 | 0000 | 0 | 0 | | 0111 | 0000 | 0000 | 1.1 | 1 | | 1000 | 0000 | | 1 | | Figure 5-18. Example 5.2 (a) State Transition Table (b) Reduced State Table (c) Reduced Transition Table NAME OF STREET #### 5.5 Counters Counters are among the most commonly used sequential circuits. In the following sections, they are covered in detail. A register that goes through a predetermined state sequence upon receiving an input pulse is called a counter. Counters are one of the simplest sequential circuits, and are found in almost all equipment containing digital logic. The sequence of states followed determines the different types of counters (BCD, binary, etc). The binary counter is one of the simplest counters. An n-bit binary counter is a register with n flip-flops and associated combinatorial logic that follows the sequence from 0 to $2^{n-1}$ . #### Example 5.3 We will look at the design of a 3-bit up/down binary counter. There are three outputs from the binary counter: DA, DB and DC. The input to the counter is X; the counter will increment if X = 1, and decrement if X = 0. We will use D flip-flops for this design. #### Solution: This circuit will have eight different states, because the 3-bit counter cycles through $2^3$ states. The states are called q0, q1, q2, q3, q4, q5, q6 and q7. If X=1 each state will have a transition to its next higher state. For example, q0 will go to q1, q1 will go to q2, and so on. If X=0 then each state will change to its previous state. For example, q7 will go to q6, q5 to q4, and so on. The state diagram of this design is shown in Figure 5-22a. State transition tables, derived from the state diagram, are shown in Figure 5-22b. The K-maps and the state variables are shown in Figure 5-22c. The state equations are derived from the K-maps. The equations are summarized as follows: $$D_A$$ : = /A\*/B\*/C\*/X + /A\*B\*C\*X + A\*B\*/C + A\*/B\*X + A\*C\*/X $D_B$ : = /B\*/C\*/X + /B\*C\*X + B\*/C\*X + B\*C\*/X $D_C$ : = /C Z = /A\*/B\*C + /B\*/D\*/X + /C\*/D\*/X + C\*DFigure 5-19. Karnaugh Maps for Example 5.2 | PRESENT | NEXT STATE | | | | |------------|------------|-------|--|--| | STATE | x = 0 | X = 1 | | | | q0 | q7 | q1 | | | | q1 | q0 | q2 | | | | q2 | q1 | q3 | | | | <b>q</b> 3 | q2 | q4 | | | | q4 | q3 | q5 | | | | q5 | q4 | q6 | | | | q6 | q5 | q7 | | | | <b>q</b> 7 | q6 | q0 | | | | PRESENT | NEXT STATE | | | | | |---------|------------|-------|--|--|--| | STATE | X = 0 | X = 1 | | | | | 000 | 111 | 001 | | | | | 001 | 000 | 010 | | | | | 010 | 001 | 011 | | | | | 0.11 | 010 | 100 | | | | | 100 | 011 | 101 | | | | | 101 | 100 | 110 | | | | | 110 | 101. | 111 | | | | | 111 | 110 | 000 | | | | D<sub>A</sub>: = /A\*/B\*/C\*/X + /A\*B\*C\*X + A\*B\*/C + A\*/B\*X + A\*C\*/X Figure 5-20. 3-Bit Up/Down Counter (a) State Diagram (b) State Transition Tables (c) Karnaugh Maps We can easily implement this counter using a PAL device. The PAL device for this design will require at least three flip-flops. Since there is no PAL device available that has only three flip-flops, the best PAL device will be the PAL16R4, because it has four flip-flops and contains the AND-OR gates needed to realize the combinatorial circuit of the counter. The schematic of the 3-bit up/down counter using the PAL16R4 is shown on page 8-31. Note that there are plenty of unused inputs and outputs for other functions if desired. Design of a binary counter can be complicated by adding new features to it. Counters can be made to count up or down, load new values in, or clear the present state of the counter and reset to 0's. As we try to design bigger counters, using the state tables and K-maps becomes more difficult. In the design of the 3-bit counter, K-maps were used. If we try to design a counter bigger than this, summarizing the equations will be a very tedious process. Therefore, we try to find a general solution for solving the counter design problem. Let's try to write the equation for the most significant bit (MSB) of an n-bit binary counter $(Q_n)$ . First we look at the case where the counter is counting up. The new value of $\mathbf{Q}_n$ will depend on the carry-in from bit $\mathbf{Q}_{n-1}$ into $\mathbf{Q}_n$ . If all less significant bits (LSBs) are high when we count up, we will have a carry-in from $\mathbf{Q}_{n-1}$ into $\mathbf{Q}_n$ . $$C_{IN} := Q_{n-1} * Q_{n-2} * ... Q1 * Q0 * UP$$ Now let's look at the following table: | UP | Qn | CARRY-IN NEW Q <sub>n</sub> | |----|----|-----------------------------------------| | Н | L | | | Н | L | H A A A A A A A A A A A A A A A A A A A | | Н | Н | L | | Н | Н | a. H Landa and Color | Figure 5-21. Carry-in Table Examining the above table, it is easily concluded that: $$Q_n := Q_n :+: carry-into Q_n$$ $$Q_n := Q_n :+: (Q_{n-1} * Q_{n-2} * ... Q0 * UP)$$ Now that we have calculated the equation for the count-up case, let's look at the count-down case. Borrow-out from $\mathbf{Q}_n$ to $\mathbf{Q}_{n-1}$ will be high if all the LSBs are low and we are counting down. $$B_{OUT} := /Q_n - 1*/Q_n - 2*.../Q0*/UP$$ Let's look at the following table: | UP | Qn | BORROW OUT | NEW Q <sub>n</sub> | |----|----|------------|--------------------| | L | L | 4 | L | | L | L | Н | Н | | L | Н | L L | Н | | L | н | H | L | Figure 5-22. Borrow-out Table # Logic Diagram So: $$Q_n := Q_n :+: Borrow-out Q_n$$ $$Q_n := Q_n :+: (/Q_{n-1}*/Q_{n-2}*.../Q_1*/Q_0*/UP)$$ Therefore: $$\begin{split} \mathbf{Q}_{\mathbf{n}} := \mathbf{Q}_{\mathbf{n}} : + : & (\mathbf{Q}_{\mathbf{n}-1} \star \mathbf{Q}_{\mathbf{n}-2} \star ... \mathbf{Q}_{1} \star \mathbf{Q}_{0} \star \mathbf{Q}_{0} \star \mathsf{UP}) \\ & + \mathbf{Q}_{\mathbf{n}} : + : & (\mathbf{/Q}_{\mathbf{n}-1} \star \mathbf{/} \ \mathbf{Q}_{\mathbf{n}-2} \star ... \mathbf{/Q}_{1} \star \mathbf{/Q}_{0} / \star \mathsf{UP}) \end{split}$$ Another way to look at a counter is to formulate the following statement about the n<sup>th</sup> bit of the counter: On should hold UNLESS all lower order bits are HI and we are counting UP. The "UNLESS" operation is implemented by an XOR gate. Thus this statement translates directly into $$Qn := Qn :+: (Q_{n-1} * Q_{n-2} * ... Q_1 * Q_0 * UP)$$ This is, of course, the same equation we obtained by looking at the truth table. The expression for a down-counter can be found the same way. This formulation makes it easy to combine these two expressions into a single equation for an up/down counter: Qn should hold UNLESS: All lower order bits are HI and counting UP OR all lower order bits are LO and NOT counting UP. This translates to $$\begin{array}{ll} Qn := Qn :+: (Q_{n-1} * Q_{n-2} * ... * Q_1 * Q_0 * UP) & \text{Eq. 5.1} \\ & + (Q_{n-1} * / Q_{n-2} * ... * / Q_{1 * 1} Q_0 * / UP) & \end{array}$$ ### Example 5.4 Using the solution discussed above, let's try to design an n-bit counter that can count up, count down, RESET and LOAD new values into the counter. RESET overrides LOAD, count and HOLD. LOAD overrides count. RESET sets all of the Qs to 0. #### Solution: The above operations are summarized below. | RE-<br>SET | LD | HOLD | UP | D | Q | OPERATION | |------------|-----|------|----|---|-----------|-------------| | Н | Х | Х | Х | Х | X | Set all LOW | | L | ÷Ľ. | Х | X | D | D | Load D | | L | Н | Н | Х | Х | Q | Hold Q | | L | Н | L | L | Х | Q plus 1 | Increment | | L | Н | L | Н | Х | Q minus 1 | Decrement | We will try to generate a general equation that can be used for any bit in the counter. If we take the $n^{th}$ bit, we have $D_n$ as input and $Q_n$ as output. There are five operations that can happen for any given bit: LOAD, HOLD, RESET, count up or count down. If RESET is HI, then all other operations are overridden. Overriding the other operations is sufficient to provide a LO into the flip-flop. So every product term will contain /RESET. We LOAD the new value in the counter's register if RESET is OFF (/RESET = H). Since $Q_n$ is replaced by $D_n$ if (/RESET = H, LOAD = H), the expression that will allow loading the new value will be /RESET\*LOAD\*/ $D_n$ . In order to be able to HOLD the $Q_n$ value, we should have the following conditions: (RESET = L, LOAD = L, HOLD = H). So the expression for holding the old value is: There are two more functions for the counter; count up and count down. These two functions have been calculated in Eq. 5.1. Using this equation and the calculation for the HOLD and LOAD cases, the final equation for the nth bit is: $$Q_n = /RESET*LOAD*D_n$$ Eq. 5.2 + /RESET\*/LOAD\*/Qn :+: /RESET\*/LOAD\*HOLD\*UP\*Q0\*Q1\*... Qn-1 + /RESET\*/LOAD\*HOLD\*/UP\*/Q0\*/Q1\*.../Q<sub>n-1</sub> Using the above general equation, any large counter can be designed. | 1 | PAL® Device Introduction | | |-----|----------------------------------|--| | 2 | PAL®/HAL® Device Specifications | | | 3 | PAL Device Programmer Ref. Guide | | | 4 | HAL/ZHAL™ Devices | | | 5 | Logic Cell Array™ | | | 6 | PALASM® Software Syntax | | | 7 | PAL Device Applications | | | (3) | Logic Tutorial | | | 9 | PLE™ Devices | | | 10 | PLE Circuit Applications | | | | Article Reprints | | | 12 | General Information | | | 13 | Package Drawings | | | 14 | Representatives and Distributors | | ## PLETM Devices # **Table of Contents** | Contents for Section 9 | <br> | 9-2 | |--------------------------------------|------|-----| | PLE to PROM Cross Reference Guide | <br> | 9-3 | | Selection Guide | <br> | 9- | | PLE means Programmable Logic Element | <br> | 9- | | Registered PLE | <br> | 9- | | PLEASM <sup>TM</sup> | <br> | 9- | | Logic Symbols | | | | Specifications | | 9-1 | | PLE Family Block Diagrams | <br> | 9-1 | | PLE Programmer Reference Chart | | 9-2 | # **PLE to PROM Cross Reference** | TEMP.<br>RANGE | PLE<br>NUMBER | INPUTS | OUTPUTS | OUTPUT<br>TYPE | MEMORY<br>SIZE | PROM<br>NUMBER | PACKAGE | |----------------|---------------|--------|---------|----------------|----------------|----------------|--------------------------| | | PLE5P8C | 5 | 8 | Three-State | 32 x 8 | 63S081 | 16N,J,(20),(NL) | | | PLE5P8AC | 5 | 8 | Three-State | 32 x 8 | 63S081A | 16N,J,(20),(NL) | | | PLE5P16C | 5 | 16 | Three-State | 32 x 16 | none | 24NS,JS,(28),(NL) | | | PLE6P16C | 6 | 16 | Two-State | 64 x 16 | none | 24NS,JS,(28),(NL) | | | PLE8P4C | 8 | 4 | Three-State | 256 x 4 | 63S141A | 16N,J,(20),(NL) | | | PLE8P8C | 8 | 8 | Three-State | 256 x 8 | 63S281A | 20N,J,NL | | | PLE9P4C | 9 | 4 | Three-State | 512 x 4 | 63S241A | 16N,J,(20),(NL) | | | PLE9P8C | 9 | 8 | Three-State | 512 x 8 | 63S481A | 20N,J,NL | | | PLE10P4C | 10 | 4 | Three-State | 1024 x 4 | 63S441A | 18N,J,(20),(NL) | | Com. | PLE10P8C | 10 | 8 | Three-State | 1024 x 8 | 63S881A | 24N,J,NS,JS,(28),(NL) | | JOIII. | PLE11P4C | 11 | 4 | Three-State | 2048 x 4 | 63S841A | 18N,J,(20),(NL) | | | PLE11P8C | 11 | 8 | Three-State | 2048 x 8 | 63S1681A | 24N,J,NS,JS,(28),(NL) | | | PLE12P4C | 12 | 4 | Three-State | 4096 x 4 | 63S1641A | 20N,J,NL | | | PLE12P8C | 12 | 8 | Three-State | 4096 x 8 | 63S3281A | 24N,J,(28),(NL) | | | PLE9R8C | 9 | 8 | Register | 512 x 8 | 63RA481A | 24NS,JS,(28),(NL) | | | PLE10R8C | 10 | 8 | Register | 1024 x 8 | 63RS881A | 24NS,JS,(28),(NL) | | | PLE11RA8C | 11 | 8 | Register | 2048 x 8 | 63RA1681A | 24NS,JS,(28),(NL) | | | PLE11RS8C | 11 | 8 | Register | 2048 x 8 | 63RS1681A | 24NS,JS,(28),(NL) | | | PLE5P8M | 5 | 8 | Three-State | 32 x 8 | 53S081 | 16J,W,(20),(L) | | | PLE8P4M | 8 | 4 | Three-State | 256 x 4 | 53S141A | 16J,W,(20),(L) | | | PLE8P8M | 8 | 8 | Three-State | 256 x 8 | 53S281A | 20J,W,L | | | PLE9P4M | 9 | 4 | Three-State | 512 x 4 | 53S241A | 16J,W,(20),(L) | | | PLE9P8M | 9 | 8 | Three-State | 512 x 8 | 53S481A | 20J,F,L | | | PLE10P4M | 10 | 4 | Three-State | 1024 x 4 | 53S441A | 18J,W,(20),(L) | | | PLE10P8M | 10 | 8 | Three-State | 1024 x 8 | 53S881A | 24JS,J,W,(28),(L) | | Mil. | PLE11P4M | 11 | 4 | Three-State | 2048 x 4 | 53S841A | 18J,W,(28),(L),(20),(L)* | | | PLE11P8M | 11 | 8 | Three-State | 2048 x 8 | 53S1681A | 24JS,J,W,(28),(L) | | | PLE12P4M | 12 | 4 | Three-State | 4096 x 4 | 53S1641A | 20J | | | PLE12P8M | 12 | 8 | Three-State | 4096 x 8 | 53S3281A | 24J,W,(28),(L) | | | PLE9R8M | 9 | . 8 | Register | 512 x 8 | 53RA481A | 24JS,W,(28),(L) | | | PLE10R8M | 10 | 8 | Register | 1024 x 8 | 53RS881A | 24JS,J,W,(28),(L) | | | PLE11RA8M | 11 | 8 | Register | 2048 x 8 | 53RA1681A | 24JS,W,(28),(L) | | | PLE11RS8M | 11 | 8 | Register | 2048 x 8 | 53RS1681A | 24JS,W,(28),(L) | <sup>\*</sup>The PLE11P4M is available in a 20- or 28-pin Leadless Chip Carrier # Programmable Logic Element PLE™ Circuit Facility #### Features/Benefits - Programmable replacement for conventional TTL logic - Reduces IC inventories and simplifies their control - Expedites and simplifies prototyping and board layout - Saves space with 0.3-inch SKINNYDIP® packages (except PLE12P8) - Programmed on standard PROM programmers - Test and simulation made simple with PLEASM<sup>TM</sup> software - Low-current PNP inputs - Three-state outputs - Reliable TiW fuses guarantee > 98% programming yeld #### **PLE Circuit Selection Guide** | PART<br>NUMBER | INPUTS | OUTPUTS | PRODUCT<br>TERMS | OUTPUT<br>REGISTERS | t <sub>PD</sub> (ns)<br>MAX* | |----------------|--------|---------|------------------|------------------------------------------------|------------------------------| | PLE5P8 | 5 | 8 | 32 | 7 (A. 1944) (A. 1944)<br>1 (A. 1944) (A. 1944) | 25 | | PLE5P8A | 5 | 8 | 32 | | 15 | | PLE5P16 | 5 | 16 | 32 | | 18 | | PLE6P16 | 6 | 16 | 64 | | 20 | | PLE8P4 | . 8 | 4 | 256 | | 30 | | PLE8P8 | 8 | 8 | 256 | | 28 | | PLE9P4 | 9 | 4 | 512 | 2 | 35 | | PLE9P8 | 9 | 8 | 512 | | 30 | | PLE10P4 | 10 | 4 | 1024 | | 35 | | PLE10P8 | 10 | 8 | 1024 | | 30 | | PLE11P4 | 1,1 | 4 | 2048 | | 35 | | PLE11P8 | 11 | 8 | 2048 | | 35 | | PLE12P4 | 12 | 4 | 4096 | | 35 | | PLE12P8 | 12 | 8 | 4096 | | 35 | | PLE9R8 | 9 | 8 | 512 | 8 | 15 | | PLE10R8 | 10 | 8 | 1024 | 8 | 15 | | PLE11RA8 | 11 | 8 | 2048 | 8 | 15 | | PLE11RS8 | 11 | 8 | 2048 | 8 | 15 | \*Clock to output time for registered outputs. Note: Commercial limits specified. Monolithic MM Memories # PLE Means Programmable Logic Element Joining the world of IdeaLogic<sup>TM</sup> is a new generation of High-speed PROMs which the designer can use as *Programmable Logic Elements*. The combination of PLE circuits as logic elements with PAL devices can greatly enhance system speed while providing almost unlimited design freedom. Basically, PLE circuits are ideal when a large number of product terms is required. On the other hand, a PAL device is best suited for situations when many inputs are needed. The PLE circuit transfer function is the familiar sum of products. Like the PAL device, the PLE circuit has a single array of fusible links. Unlike the PAL device, the PLE circuits have a programmable OR array driven by a fixed AND array (the PAL device is a programmed AND array driving a fixed OR array). #### PRODUCT TERM AND INPUT LINES | | PLE | PAL | |---------------|------------|---------| | Product Terms | 32 to 4096 | 1 to 16 | | Input Lines | 5 to 12 | 6 to 64 | The PLE family features common electrical parameters and programming algorithms, low-current PNP inputs, full Schottky clamping and three-state outputs. The entire PLE family is programmed on conventional PROM programmers with the appropriate personality cards and socket adapters. #### **Registered PLE Circuits** The registered PLE circuits have on-chip "D" type registers, versatile output enable control through synchronous and asynchronous enable inputs, and flexible start-up sequencing through programmable initialization. Data is transferred into the output registers on the rising edge of the clock. Provided that the asynchronous (E) and synchronous (ES) enables are Low, the data will appear at the outputs. Prior to the positive clock edge, register data are not affected by changes in addressing or synchronous enable inputs. Data control is made flexible with synchronous and asynchronous enable inputs. Outputs may be set to the high-impedance state at any time by setting $\overline{\rm E}$ to a High or if $\overline{\rm ES}$ is High when the rising clock edge occurs. When $\rm V_{CC}$ power is first applied the synchronous enable flip-flop will be in the set condition causing the outputs to be in the high-impedance state. A flexible initialization feature allows start-up and time-out sequencing with 1:16 programmable words to be loaded into the output registers. With the synchronous INITIALIZE (IS) pin Low, one of the 16 initialize words, addressed through pins 5, 6, 7 and 8 will be set in the output registers independent of all other input pins. The unprogrammed state of IS words are Low, presenting a CLEAR with IS pin Low. With all IS column words (A3-AO) programmed to the same pattern, the IS function will be independent of both row and column addressing and may be used as a single pin control. With all IS words programmed High a PRESET function is performed. The PLE9R8 has asynchronous PRESET and CLEAR functions. With the chip enabled, a Low on the $\overline{PR}$ input will cause all outputs to be set to the High state. When the $\overline{CLR}$ input is set Low the output registers are reset and all outputs will be set to the Low state. The $\overline{PR}$ and $\overline{CLR}$ functions are common to all output registers and independent of all other data input states. | | PLE Fixed Prog TS, Registered Ou Fusible Polarity PLA Prog Prog TS, OC, Fusible Plant Prog Fixed TS, Registered Fe | | OUTPUT OPTIONS | |-----|--------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------| | PLE | Fixed | Prog | TS, Registered Outputs,<br>Fusible Polarity | | PLA | Prog | Prog | TS, OC, Fusible Polarity | | PAL | Prog | Fixed | TS, Registered Feedback I/O<br>Fusible Polarity | #### Programmable Logic Element PLE™ Circuit Family #### PLEASM<sup>TM</sup> Software #### Software that makes programmable logic easy. Monolithic Memories has developed a software tool to assist in designing and programming PROMs as PLE circuits. This package called "PLEASM" (PLE Assembler) is available for several computers including the VAX/VMS and IBM PC/DOS. PLEASM software converts design equations (Boolean and arithmetic) into truth tables and formats compatible with PROM programmers. A simulator is also provided to test a design using a Function Table before actually programming the PLE circuit. PLEASM software may be requested through the Monolithic Memories IdeaLogic Exchange. #### PLE (PROM) PAL Device NOTE: • = hardwired connection X = programmable connection #### **Logic Symbols** PLE11P8 PLE10P8 PLE12P4 PLE11P4 4 5 6 7 8 8 9 AND OR AND LOGIC AND OR ARRAY AND OR LOGIC 7 LOGIC OR ARRAY LOGIC ARRAY ARRAY v CD01590N CD01560M PLE10R8 PLE12P8 PLE9R8 ഥ 4 5 6 7 8 9 3 4 5 6 • AND OR LOGIC ARRAY • D. Tii ## 9 ## **Logic Symbols** ## Programmable Logic Element PLE™ Circuit Family #### **Absolute Maximum Ratings** | | | | 6.44 | Operating | Programming | |--------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------|-------------| | Supply voltage Vcc | | Supplementary of the supplemen | 20.05 40% 0.27 30 | 0.5V to 7V | 12V | | Input voltage | 1984<br>2 A T ( | Barry . | | 1.5V to 7V | 7V | | Off-state output voltage | | | | | 12V | | Storage temperature | | | | | | | Operating Condi | | | | | | | SYMBOL | | СО | MMERC | IAL , | ı | | | | |-----------------|--------------------------------|------|-------|-------|-----|-----|-----|------| | SYMBOL | PARAMETER | MIN | NOM | MAX | MIN | NOM | MAX | UNIT | | V <sub>CC</sub> | Supply Voltage | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V | | T <sub>A</sub> | Operating free-air temperature | 0 | 25 | 75 | -55 | 25 | 125 | °C | ## Electrical Characteristics Over Operating Conditions | SYMBOL | PARAMETER | TEST | CONDITIONS | | MIN | TYP† | MAX | UNIT | |-----------------|---------------------------------|------------------------------------------|----------------------------------|------------|-----|------|-------|------| | V <sub>IL</sub> | Low-level input voltage | Guaranteed logica | l low voltage for a | II inputs | | | 0.8 | V | | V <sub>IH</sub> | High-level input voltage | Guaranteed logica | l high voltage for | all inputs | 2 | | | V | | V <sub>IC</sub> | Input clamp voltage | V <sub>CC</sub> = MIN | I <sub>I</sub> = -18mA | | | | -1.5 | V | | I <sub>IL</sub> | Low-level input current | V <sub>CC</sub> = MAX | V <sub>1</sub> = 0.4V | | | | -0.25 | mA | | I <sub>IH</sub> | High-level input current | V <sub>CC</sub> = MAX | V <sub>I</sub> = V <sub>CC</sub> | | | 100 | 40 | μΑ | | V <sub>OL</sub> | Low-level output voltage | V <sub>CC</sub> = MIN | I <sub>OL</sub> = 16mA | Com | | | 0.45 | V | | •OL | Low lovel calput voltage | VCC WIIIV | IOL TOTAL | Mil | | | 0.5 | | | V <sub>OH</sub> | High-level output voltage | V <sub>CC</sub> = MIN | Com I <sub>OH</sub> = -3. | 2mA | 2.4 | | | v | | ТОН | I light to to to dupte to large | 1.00 | Mil I <sub>OH</sub> = -2mA | | ] | | | | | lozL | Off-state output current | V <sub>CC</sub> = MAX | $V_{O} = 0.4V$ $V_{O} = 2.4V$ | | | | -40 | μΑ | | lozh | | 1.00 | | | | | 40 | | | los | Output short-circuit current* | V <sub>CC</sub> = 5V | V <sub>O</sub> = 0V | | -20 | | -90 | mA | | | | | 5P8 | | | 90 | 125 | | | | | | 5P8A | | | 90 | 125 | | | | | | 5P16 | | 2 | 140 | 180 | | | | | | 6P16 | | | 150 | 190 | l | | | | | 8P4 | | - : | 80 | 130 | | | | | | 8P8 | | | 90 | 140 | | | | | V = MAY | 9P4 | • | . 2 | 80 | 130 | | | | | V <sub>CC</sub> = MAX<br>All inputs | 9P8 | | | 104 | 155 | | | | | grounded;<br>all outputs open | 10P4 | | | 95 | 140 | | | loc | Supply current | dii odipulo opon | 10P8 | | | 92 | 160 | m/ | | | | | 11P4 | | | 110 | 150 | | | | | | 11P8 | | | 135 | 185 | | | | | | 12P4 | | | 130 | 175 | | | | | | 12P8 | | | 150 | 190 | | | | | | 9R8 | | | 130 | 180 | | | | | V <sub>CC</sub> = MAX<br>All inputs TTL; | 10R8 | | | 130 | 180 | | | | | all outputs open | 11RA8 | | | 140 | 185 | | | | | | 11RS8 | | | 140 | 185 | | $<sup>\</sup>dagger$ Typicals at 5.0V V<sub>CC</sub> and 25°C T<sub>A</sub>. \* Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second. ## Programmable Logic Element PLE™ Circuit Family ## Switching Characteristics Over Commercial Operating Conditions | DEVICE TYPE | | t <sub>PD</sub> (ns)<br>PROPAGATION DELAY<br>MAX | t <sub>PZX</sub> AND t <sub>PXZ</sub> (ns)<br>INPUT TO OUTPUT<br>ENABLE/DISABLE TIME<br>MAX | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------| | 5P8AC | | 15 | 20 | | 5P8C | | 25 | 20 | | 5P16C | and the second s | 18 | 15 | | 6P16C | | 20 | 15 | | 8P4C | en e | 30 | 20 | | 8P8C | | 28 | 25 | | 9P4C | | 35 | 20 | | 9P8C | | 30 | 25 | | 10P4C | orași de feit de la compania del compania de la compania de la compania del compania de la del compania de la compania de la compania del c | 35 35 | 25 | | 10P8C | the district of the second | 30 | 25 | | 11P4C | (48. TAK) | 35 | 25 | | 11P8C | *1.01 - TV1 - 10 | 35 | 25 | | 12P4C | | 35 | 25 | | 12P8C | | 35 | 30 | #### Switching Characteristics Over Military Operating Conditions | DEVICE TYPE | t <sub>PD</sub> (ns)<br>PROPAGATION DELAY<br>MAX | t <sub>PZX</sub> AND t <sub>PXZ</sub> (ns)<br>INPUT TO OUTPUT<br>ENABLE/DISABLE TIME<br>MAX | |-------------|--------------------------------------------------|---------------------------------------------------------------------------------------------| | 5P8M | | or 30 miles | | 8P4M | 40 | 30 | | 8P8M | 40 | 30 | | 9P4M | 45 | 30 | | 9P8M | 40 | 30 | | 10P4M | 50 | 30 | | 10P8M | 45 | 30 | | 11P4M | 50 | 30 | | 11P8M | 50 | 30 | | 12P4M | 50 | 30 | | 12P8M | 40 | 35 | ## **Operating Conditions** | ovupoi | PARAMETER | MILITARY | | | COMMERCIAL | | | | |----------------------------------|-----------------------------------------------------------|----------|------|-----|------------|------|-----|------| | SYMBOL | PARAMETER | MIN | TYP* | MAX | MIN | TYP* | MAX | UNIT | | t <sub>w</sub> | Width of clock (High or Low) | 20 | 10 | | 20 | 10 | | ns | | t <sub>prw</sub> | Width of preset or clear<br>(LOW) to Output (High or Low) | 20 | 10 | | 20 | 10 | | ns | | t <sub>orr</sub> | Recovery from preset or clear<br>(LOW) to clock HIGH | 25 | 11 | | 20 | 11 | | ns | | t <sub>su</sub> | Setup time from input to clock | 35 | 22 | | 30 | 22 | | ns | | t <sub>s</sub> ( <del>ES</del> ) | Setup time from ES to clock | 15 | 7 | | 10 | 7 | | ns | | t <sub>h</sub> | Hold time from input to clock | 0 | -5 | | 0 | -5 | | ns | | t <sub>h</sub> (ES) | Hold time from ES to clock | 5 | -3 | 2.4 | 5 | -3 | | ns | #### Switching Characteristics Over Operating Conditions and using Standard Test Load | OVIIDOI | | ٨ | ALITAR | Υ | co | | | | |------------------------|------------------------------|---|--------|-----|-----------|------|-----|------| | SYMBOL | PARAMETER | | TYP* | MAX | MIN | TYP* | MAX | UNIT | | t <sub>CLK</sub> | Clock to output delay | | 11 | 20 | | 11 | 15 | ns | | t <sub>PR</sub> | Preset to output delay | | 15 | 25 | | 15 | 25 | ns | | t <sub>CLR</sub> | Clear to output delay | | 18 | 35 | 41,444 | 18 | 25 | ns | | t <sub>PZX</sub> (CLK) | Clock to output enable time | | 14 | 30 | | 14 | 25 | ns | | t <sub>PXZ</sub> (CLK) | Clock to output disable time | | 14 | 30 | i and a N | 14 | 25 | ns | | t <sub>PZX</sub> | Input to output enable time | | 10 | 25 | | 10 | 20 | ns | | t <sub>PXZ</sub> | Input to output disable time | | 10 | 25 | | 10 | 20 | ns | <sup>\*</sup> Typicals at 5.0V Voc and 25°C Ta #### **Definition of Waveforms** NOTES: - 1. Input pulse amplitude 0V to 3.0V. - 2. Input rise and fall times 2-5ns from 0.8V to 2.0V. - 3. Input access measured at the 1.5V level. - Switch S<sub>1</sub> is closed. C<sub>L</sub> = 30pF and outputs measured at 1.5V level for all tests except t<sub>PXZ</sub> and t<sub>PZX</sub>. t<sub>PZX</sub> and t<sub>PZX(CLK)</sub> are measured at the 1.5V output level with C<sub>L</sub> = 30pF. S<sub>1</sub> is open for high impedance to "1" test and closed for high impedance to "0" test. to Vest. TeX2 and IpX2/CLK) are tested with C<sub>L</sub> = 5pF. S<sub>1</sub> is open for "1" to high impedance test, measured at V<sub>OH</sub> - 0.5V output level; S<sub>1</sub> is closed for "0" to high impedance test measured at V<sub>OL</sub> + 0.5V output level. property and the second to #### **Operating Conditions** | OVALDOL | | MILITARY | | | COMMERCIAL | | | | |---------------------|-----------------------------------------------|----------|------|-----|------------|------|--|------| | SYMBOL | PARAMETER | MIN | TYP* | MAX | MIN | TYP* | | UNIT | | t <sub>w</sub> | Width of clock (High or Low) | 20 | 10 | | 20 | 10 | | ns | | t <sub>su</sub> | Setup time from input to clock (10R8) | 40 | 25 | | 30 | 25 | | ns | | t <sub>su</sub> | Setup time from input to clock (11RA8, 11RS8) | 40 | 28 | 7 1 | 35 | 28 | | ns | | t <sub>s</sub> (ES) | Setup time from ES to clock (except 11RA8) | 15 | . 8 | | 15 | 8 | | ns | | t <sub>s</sub> (ĪS) | Setup time from IS to clock | 30 | 20 | | 25 | 20 | | ns | | t <sub>h</sub> | Hold time input to clock | 0 | -5 | | 0 | -5 | | ns | | t <sub>h</sub> (ES) | Hold time (ES) (except 11RA8) | 5 | -3 | | 5 | -3 | | ns | | t <sub>h</sub> (IS) | Hold time (IS) | 0 | 5 | | 0 | -5 | | ns | #### Switching Characteristics Over Operating Conditions and using Standard Test Load | OVMDOL | PARAMETER | | WILITAR | Υ | co | in visi | | | |------------------------|---------------------------------------------|--|---------|-----|------|---------|-----|------| | SYMBOL | PARAMETER | | TYP* | MAX | MIN | TYP* | MAX | UNIT | | t <sub>CLK</sub> | Clock to output delay | | 10 | 20 | | 10 | 15 | ns | | t <sub>PZX</sub> (CLK) | Clock to output enable time (except 11RA8) | | 18 | 30 | | 18 | 25 | ns | | t <sub>PXZ</sub> (CLK) | Clock to output disable time (except 11RA8) | | 17 | 30 | . 7. | 17 | 25 | ns | | t <sub>PZX</sub> | Input to output enable time (except 11RS8) | | 17 | 30 | | 17 | 25 | ns | | t <sub>PXZ</sub> | Input to output disable time (except 11RS8) | | 17 | 30 | | 17 | 25 | ns | <sup>\*</sup> Typicals at 5.0V V<sub>CC</sub> and 25°C T<sub>A</sub>. #### **Definition of Waveforms** NOTES: - 1. Input pulse amplitude 0V to 3.0V. - 2. Input rise and fall times 2-5ns from 0.8V to 2.0V. - 3. Input access measured at the 1.5V level. - Switch S<sub>1</sub> is closed. C<sub>L</sub> = 30pF and outputs measured at 1.5V level for all tests except t<sub>PZX</sub> and t<sub>PZX</sub>. t<sub>PZX</sub> and t<sub>PZX(CLK)</sub> are measured at the 1.5V output level with C<sub>L</sub> = 30pF. S<sub>1</sub> is open for high impedance to "1" test and closed for high impedance to "0" test. $t_{PXZ}$ and $t_{PXZ(CLK)}$ are tested with $C_L = 5pF.S_1$ is open for "1" to high impedance test, measured at $V_{OH} - 0.5V$ output level; $S_1$ is closed for "0" to high impedance test measured at $V_{OL} + 0.5V$ output level. #### Switching Test Load #### **Definition of Timing Diagram** #### **Definition of Waveforms** NOTES: Apply to electrical and switching characteristics. Typical at 5.0V V<sub>CC</sub> and 25°C T<sub>A</sub>. Measurements are absolute voltages with respect to the ground pin on the device and includes all overshoots due to system and/or tester noise. In all PLE devices unused inputs must be tied to either ground or V<sub>CC</sub>. The series resistor required for unused inputs on standard TTL is NOT required for PLE devices, thus using less parts. \*Not more than one output should be shorted at a time and duration of the short-circuit should not exceed one second. For commercial operating range R<sub>1</sub> = 200Ω, R<sub>2</sub> = 390 $\Omega$ . For military operating range R<sub>1</sub> = 300 $\Omega$ , R<sub>2</sub> = 600 $\Omega$ . - 1. Input pulse amplitude 0V to 3.0V. - 2. Input rise and fall times 2-5ns from 0.8 to 2.0V. - 3. Input access measured at the 1.5V level. - Data delay is tested with switch S<sub>1</sub> closed. C<sub>L</sub> = 30pF and measured at 1.5V output level. t<sub>PZX</sub> is measured at the 1.5V output level with C<sub>L</sub> = 30pF. S<sub>1</sub> is open for high-impedance to "1" test and closed for high-impedance to "0" test. t<sub>PXX</sub> is measured C<sub>L</sub> = 5pF. S<sub>1</sub> is open for "1" to high-impedance test, measured at V<sub>OH</sub> - 0.5V output level; S<sub>1</sub> is closed for "0" to high-impedance test measured at V<sub>OL</sub> + 0.5V output level. #### **Block Diagrams** ## 9 #### **Block Diagrams** 02 02 ds #### **Block Diagrams** #### PLE12P8 |13 | |02 12 O3 ## Œ #### **Block Diagrams** ## **Monolithic Memories PLE Programmer Reference Chart** | SOURCE<br>AND<br>LOCATION | Data I/O Corp.<br>10525 Willows Rd.<br>N.E.<br>P.O. Box 97046<br>Redmond<br>WA 98073-9746 | Kontron<br>Electronics Inc.<br>1230 Charleston<br>Rd.<br>Mountain View<br>CA 94039-7230 | Stag<br>Microsystems Inc.<br>528-5 Weddell Dr.<br>Sunnyvale<br>CA 94089 | Digelec Inc.<br>1602 Lawrence<br>Ave.<br>Suite 113<br>Ocean<br>NJ 07712 | Varix Corp.<br>1210 E. Campbel<br>Rd.<br>Suite 100<br>Richardson<br>TX 75081 | |-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------| | Programmer Model 19/29A/29B Model 22 | | Model MMP-80S | Model PPX<br>Model PPZ | UP803 | OMNI | | MMI Generic<br>Bipolar PLE<br>Personality<br>Module | UniPak Rev 10<br>UniPak II Rev 07<br>(Not all PLE<br>devices<br>are supported by<br>earlier<br>UniPak revisions) | MOD16 | Zm 2000 | FAM Mod. No. 12 | | | Socket Adapter<br>and Device Co | | | | | | | PLE5P8/<br>PLE5P8A | F18 P02<br>Model 22A-<br>Adapter 351A-064 | SA3 | AM110-2<br>Code 21 | DA No. 2 Pinout<br>1A<br>Switch Pos. O-6 | 63S081 | | PLE8P4 | F18 P01<br>Model 22A-<br>Adapter 351A-064 | SA4-2 | AM130-2<br>Code 21 | DA No. 1 Pinout<br>1B<br>Switch Pos. 0-6 | 63S141 | | PLE9P4 | F18 P03<br>Model 22A-<br>Adapter 351A-064 | SA4-1 | AM130-3<br>Code 21 | DA No. 1 Pinout<br>1D<br>Switch Pos. 2-14 | 63S241 | | PLE8P8 | F18 P08<br>Model 22A-<br>Adapter 351A-064 | SA6-1 | Code 21 | | 63S281 | | PLE10P4 | F18 P05<br>Model 22A-<br>Adapter 351A-064 | SA4 | AM140-2<br>Code 21 | DA No. 3 Pinout<br>1E<br>Switch Pos. 0-6 | 63S441 | | PLE9P8 | F18 P08<br>Model 22A-<br>Adapter 351A-064 | SA6 | Code 21 | | 63S481 | | PLE9R8 | FEC P65<br>Model 22A-<br>Adapter 351A-074 | SA31-2 | Code 21 | Pinout 1H<br>Switch Pos. 5-14 | 63RA481 | | PLE11P4 | F18 P06<br>Model 22A-<br>Adapter 351A-064 | SA4-4 | AM140-3<br>Code 21 | DA No. 3 Pinout<br>1L<br>Switch 5-14 | 63S841 | | PLE10R8 | F18 P86<br>Model 22A-<br>Adapter 351A-074<br>(300 mil pkg) | † | Code 21 | DA No. 64†<br>Switch Pos. 0-12 | 63RS881 | | PLE12P4 | F18 P53<br>Model 22A-<br>Adapter 351A-064 | SA20 | AM120-6<br>Code 21 | DA No. 70<br>Switch Pos. 4-12 | 63S1641 | | PLE11RA8<br>PLE11RS8 | F18 PA3 | † / | Code 21 | DA No. 64 | 63RA1681<br>63RS1681 | | PLE11P8 | F18P21 | SA5-4 | AM100-5<br>Code 21 | DA No.7 | 63S1681 | | PLE12P8 | F18P63 | + | Code 21 | DA No. 64 Pinout<br>47<br>Switch Pos. 0-4 | 63S3281 | <sup>†</sup> Contact manufacturer for availability and programming information. #### **PLE Circuit Applications** #### **Table of Contents** | PLE Circuit Applications Table of Contents for Section 10 | 10-1<br>10-2 | |----------------------------------------------------------------------------------------------|----------------| | Random Logic Replacement | 10-3 | | Basic Gates | 10-4 | | Memory Address Decoder | 10-6 | | 6-Bit True/Complement and Clear/Set Logic Functions | 10-10 | | Expandable 3-to-8 Demultiplexer | 10-12 | | Dual 2:1 Multiplexer | 10-14 | | Quad 2:1 Multiplexer with Polarity Control | 10-15 | | Hexadecimal to Seven Segment Decoder | 10-17 | | 5-Bit Binary to BCD Converter | 10-20 | | 4-Bit BCD to Gray Code Converter | 10-22 | | 4-Bit Gray Code to BCD Converter | 10-23 | | | 10-24 | | 8-Bit Priority Encoder 4-Bit Magnitude Comparator | 10-26 | | 6-Bit Magnitude Comparator | 10-27 | | 4-Bit Magnitude Comparator with Polarity Control | 10-28 | | 8-Bit Barrel Shifter | 10-30 | | 4-Bit Right Shifter with Programmable Output Polarity | 10-33 | | 8-Bit Two's Complement Conversion | 10-36 | | A Portion of Timing Generator for PAL Array Programming | 10-38 | | Timing Generator for PAL Security Fuse Programming | 10-41 | | Fast Arithmetic Look-up | 10-44 | | 4-Bit Multiplier Look-up Table | 10-45 | | ARC Tangent Look-up Table | 10-46 | | Hypotenuse of a Right Triangle Look-up Table | 10-48 | | Perimeter of a Circle Look-up Table | 10-51 | | Period of Oscillation for a Mathematical Pendulum Look-up Table | 10-54 | | Arithmetic Logic Unit | 10-57 | | Wallace Tree Compression | 40.50 | | | 10-58 | | Seven 1-Bit Integer Row Partial Products Adder Five 2-Bit Integer Row Partial Products Adder | 10-60<br>10-61 | | Four 3-Bit Integer Row Partial Products Adder | 10-62 | | Three 4-Bit Integer Row Partial Products Adder | 10-62 | | Residue Arithmetic Using PLE Devices | 10-64 | | Distributed Arithmetic Using PLE Devices | 10-70 | | Registered PLE Devices in Pipelined Arithmetic | 10-72 | #### **Random Logic Replacement** PROMs, as logic elements, have been providing solutions as replacements of random logic. This is the concept of PROM as a Programmable Logic Element (PLE) device. The usages of PLE devices include simple multiplexer/demultiplexer/encoder/decoder, control signal generators, data communications support like CRC, and arithmetic elements like ALUs, multipliers, sine and inverse look-up tables, and applications in signal processing. The advantages of PLE devices over SSI/MSI logic devices are the flexibility of design and the fast turnaround time which non-programmable devices cannot offer. For example, if a decoder is used to select between memory pages and I/O ports, once a design is done, it will be fixed — it is not easy to find a part to be put just in the same place without modification of PC board layout in case the designer wants to expand the memory or to increase the I/O. For a PLE device, what is needed is to program another PLE device and place it in the same socket where the old part was placed. In addition, it can allow designers to define their logic functions in a component. The AND-OR planar structure of the PLE circuit array lends itself naturally to being viewed as a two-level logic circuit. The fixed AND plane contains all possible combinations of the literals of its inputs. Each combination (product term) is fuse-connected to each output in the programmable OR plane. A common PLE device application in the control path is to customize logic functions. An n input exclusive OR function is quite commonly required in comparator and adder circuits. It contains $2^{n-1}$ product terms, which becomes quite large for large values of n. Therefore, it is very convenient to implement large XOR functions in PLE devices. The PLE logic circuit implementation of a 4-input XOR is shown below. Although it seems that XOR functions may be replaced by SSIs, in most applications, the XOR functions will not be alone by themselves, PLE circuits can provide the flexibility of adding in additional functions without using additional packages. In the data path, a PLE device can be used to implement complex functions such as a Pseudo Random Number (PRN) Generator. Random number sequences are useful in encoding and decoding of information in signal processing and communications systems. They are used for data encryption, image quantization, waveform synchronization, and white noise generation, etc. There are many techniques for generating PRN sequences. The most common technique, however, is to use 'n' stages of linear shift registers with feedback through a logic function. The function f is an arbitrary function chosen for a specific application. A most general linear function is an 'm' input XOR $(m \le n)$ . There are a number of examples in the following session which shows how a PLE device can be used to replace SSI/MSI logic devices using PLEASM software. TB01070M PLE5P8 P5000 BASIC GATES MMI SANTA CLARA, CALIFORNIA .ADD IO I1 I2 I3 I4 .DAT 01 02 03 04 05 06 07 08 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 10/03/83 Ol = 10 02 = /I0 ; INVERTER O3 = I0 \* I1 \* I2 \* I3 \* I4 ; AND GATE 04 = 10 + 11 + 12 + 13 + 14; OR GATE 05 = /10 + /11 + /12 + /13 + /14; NAND GATE O6 = /I0 \* /I1 \* /I2 \* /I3 \* /I4 ; NOR GATE O7 = I0 :+: I1 :+: I2 :+: I3 :+: I4 ; EXCLUSIVE OR GATE O8 = I0 :\*: I1 :\*: I2 :\*: I3 :\*: I4 ; EXCLUSIVE NOR GATE ## 10 #### FUNCTION TABLE IO I1 I2 I3 I4 O1 O2 O3 O4 O5 O6 O7 O8 | ; INPUT | | OUI | PUTS | FRC | M BAS | SIC G | ATES | | 사람들은 사람들이 되었다.<br>1987년 - 1985년 - 1987년 | |---------|-----|-----|------|-----|-------|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------| | ;01234 | BUF | INV | AND | OR | NAND | NOR | XOR | XNOR | COMMENTS | | LLLLL | L | Н | L | L | н | H | L | L | ALL ZEROS | | нинин | H | L | Ħ | H | L | L | H | H | ALL ONES | | HLHLH | H | L | L | H | H | L | H | H | ODD CHECKERBOARD | | LHLHL | L | H | L | H | H | L. | L | L | EVEN CHECKERBOARD | #### DESCRIPTION THIS EXAMPLE ILLUSTRATES THE USE OF PLE DEVICES TO IMPLEMENT THE BASIC GATES: BUFFER, INVERTER, AND GATE, OR GATE, NAND GATE, NOR GATE, EXCLUSIVE OR GATE, AND EXCLUSIVE NOR GATE. NOTE ALSO THAT THREE-STATE OUTPUTS ARE PROVIDED WITH ONE ACTIVE LOW OUTPUT ENABLE CONTROL (/E). PLEASM SOFTWARE GENERATES THE PROM TRUTH TABLE FROM THE LOGIC EQUATIONS AND SIMULATES THE FUNCTION TABLE IN THE LOGIC EQUATIONS. PLE8P8 P5001 MEMORY ADDRESS DECODE PLE CIRCUIT DESIGN SPECIFICATION ULRIK MUELLER 05/01/84 MEMORY ADDRESS DECODER MMI SANTA CLARA, CALIFORNIA .ADD All Al2 Al3 Al4 Al5 /MREQ .DAT /CE1 /CE2 /CE3 /CE4 /CE5 /CE6 /CE7 /CE8 CE1 = /A11\*/A12\*/A13\*/A14\*/A15\* MREQ ; SELECTS ADDRESS RANGE OK-2K CE2 = All\*/Al2\*/Al3\*/Al4\*/Al5\* MREO ; SELECTS ADDRESS RANGE 2K-4K CE3 = /Al1\* Al2\*/Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 4K-6K CE4 = All\* Al2\*/Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 6K-8K CE5 = /Al1\*/Al2\* Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 8K-10K CE6 = All\*/Al2\* Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 10K-12K CE7 = /All\* Al2\* Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 12K-14K CE8 = All\* Al2\* Al3\*/Al4\*/Al5\* MREQ ; SELECTS ADDRESS RANGE 14K-16K #### FUNCTION TABLE All Al2 Al3 Al4 Al5 /MREQ /CE1 /CE2 /CE3 /CE4 /CE5 /CE6 /CE7 /CE8 | ; | ADD LINES | | | | | |---|-----------|-------|-----------------|------------------------------|---| | ; | 11111 | ( | CHIP ENABLES | | | | ; | 12345 | /MREQ | 12345678 | COMMENTS | | | | LLLLL | L | <b>L</b> НННННН | SELECT ADDRESS RANGE 0-2K | - | | | HLLLL | L | нгиннин | SELECT ADDRESS RANGE 2K-4K | | | | LHLLL | L | ннінннн | SELECT ADDRESS RANGE 4K-6K | | | | HHLLL | L | нннгинни | SELECT ADDRESS RANGE 6K-8K | | | | LLHLL | L | ниницини | SELECT ADDRESS RANGE 8K-10K | | | | HLHLL | L | ннинцин | SELECT ADDRESS RANGE 10K-12K | | | | LHHLL | L | нининици | SELECT ADDRESS RANGE 12K-14K | | | | HHHLL | L | нининны | SELECT ADDRESS RANGE 14K-16K | | | | XXXXX | H | нининин | NO MEMORY SELECT (/MREO=H) | | | _ | | | | | | #### DESCRIPTION THIS PLESPS PROVIDES A SINGLE CHIP ADDRESS DECODER FOR USE WITH MANY POPULAR 8-BIT MICROPROCESSORS SUCH AS THE Z80 AND 8080. THE FIVE MSB ADDRESS LINES (All-Al5) AND THE MEMORY REQUEST LINE (/MREQ) FROM THE Z80 MICROPROCESSOR ARE DECODED TO PRODUCE EIGHT ACTIVE LOW CHIP ENABLES (/CE1-/CE8) TO SELECT A RANGE OF 2K BYTES FROM A BANK OF EIGHT 2Kx8 STATIC RAMS. THIS BANK OF STATIC RAMS WILL OCCUPY THE LOWEST 16K BYTES OF ADDRESS SPACE LEAVING THE UPPER 48K BYTE SPACE AVAILABLE FOR OTHER MEMORIES AND I/O. THE PLESPS HAS THREE ADDITIONAL INPUTS WHICH CAN BE RESERVED FOR FUTURE SYSTEM EXPANSION. PLE8P4 P5029 6809 ADDRESS DECODER MMI SANTA CLARA, CALIFORNIA .ADD A8 A9 A10 A11 A12 A13 A14 A15 .DAT /DRAM /IO /SRAM /PROM PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 10/13/84 DRAM = /A8\* Al2\* Al3\*/Al4\* Al5 ; SELECTS ADDRESS RANGE 0000-BEFF + /A9\* Al2\* Al3\*/Al4\* Al5 + /Al0\* Al2\* Al3\*/Al4\* Al5 + /All\* Al2\* Al3\*/Al4\* Al5 + /Al2\* /Al4 + /Al3\*/Al4 IO = A8 \* A9 \* A10 \* A11 \* A12 \* A13 \* /A14 \* A15 ; SELECTS ADDRESS RANGE BF00-BFFF /A15 SRAM = /Al3\* Al4\* Al5 ; SELECTS ADDRESS RANGE CO00-DFFF PROM = Al3\* Al4\* Al5 ; SELECTS ADDRESS RANGE E000-FFFF #### FUNCTION TABLE A8 A9 A10 A11 A12 A13 A14 A15 /DRAM /IO /SRAM /PROM ; ADDRESS LINES: 11 1111 | ; | 8901 | 2345 | /DRAM | /10 | /SRAM | /PROM | COMMEN | TS | | |---|------|------|-------|-----|-------|-------|------------|------------|-----------| | | LLLL | LLLL | L | н | н | н | <br>00хх н | EX SELECTS | DRAMS | | | LLLL | HHLH | L | H | H | H | BOXX H | EX SELECTS | DRAMS | | | нннн | HHLH | H | L | H | H | BFXX H | EX SELECTS | I/O PORTS | | | LLLL | LLHH | H | H | L | H | COXX H | EX SELECTS | SRAM | | | LLLL | HLHH | H | H | L | H | DOXX H | EX SELECTS | SRAM | | | LLLL | LHHH | H | H | H | L | E0XX H | EX SELECTS | PROM | | | нннн | нннн | H | H | H | L | FFXX H | EX SELECTS | PROM | #### DESCRIPTION THIS PLESP4 PROVIDES A SINGLE CHIP ADDRESS DECODER FOR USE WITH MANY POPULAR 8-BIT MICROPROCESSORS SUCH AS THE MOTOROLA 6809. THIS PLE DEVICE DECODES THE EIGHT MSB ADDRESS LINES (A8-A15) FROM THE MICROPROCESSOR TO PROVIDE FOUR ACTIVE LOW CHIP ENABLES (/DRAM, /IO, /SRAM, AND /PROM). THE 64K MEMORY MAP OF THE SYSTEM IS DIVIDED UP INTO FOUR SECTIONS: DRAM, IO PORTS, SRAM, AND PROM. EACH OF THESE FOUR SECTIONS CAN CONTAIN ONE OR MORE BLOCKS OF MEMORY. EACH OF THESE BLOCKS CAN START AND STOP ON ANY 256 BIT BOUNDARY ## **Block Diagram** #### **System Diagram** #### **Memory Map** PLE8P8 P5002 PLE CIRCUIT DESIGN SPECIFICATION JOEL ROSENBERG 10/26/83 6-BIT TRUE/COMPLEMENT AND CLEAR/SET LOGIC FUNCTIONS MMI SANTA CLARA, CALIFORNIA - .ADD I1 I2 D1 D2 D3 D4 D5 D6 - .DAT Y1 Y2 Y3 Y4 Y5 Y6 - Y1 = /I1\*/I2\*/D1 ; OUTPUT /D1 (INVERT) + /I1\* I2\* D1 ; OUTPUT D1 (TRUE) - + I1\*/I2 ; CLEAR Y1 - Y2 = /I1\*/I2\*/D2; OUTPUT /D2 (INVERT) - + /I1\* I2\* D2 ; OUTPUT D2 (TRUE) - + I1\*/I2 ; CLEAR Y2 - Y3 = /I1\*/I2\*/D3 ; OUTPUT /D3 (INVERT) - + /I1\* I2\* D3 ; OUTPUT D3 (TRUE) - + I1\*/I2 ; CLEAR Y3 - Y4 = /I1\*/I2\*/D4; OUTPUT /D4 (INVERT) - + /Il\* I2\* D4 ; OUTPUT D4 (TRUE) - + I1\*/I2 ; CLEAR Y4 - Y5 = /I1\*/I2\*/D5; OUTPUT /D5 (INVERT) - + /I1\* I2\* D5 ; OUTPUT D5 (TRUE) - + I1\*/I2 ; CLEAR Y5 - Y6 = /I1\*/I2\*/D6 ; OUTPUT /D6 (INVERT) - + /Il\* I2\* D6 ; OUTPUT D6 (TRUE) - + I1\*/I2 ; CLEAR Y6 #### FUNCTION TABLE Il I2 Dl D2 D3 D4 D5 D6 Y1 Y2 Y3 Y4 Y5 Y6 | ; CONTROL<br>; LINES | INPUT D<br>123456 | OUTPUT Y<br>123456 | COMMENTS | |----------------------|-------------------|--------------------|-----------------| | LL | LHLHLH | HLHLHL | INVERT FUNCTION | | LH | LHLHLH | LHLHLH | TRUE FUNCTION | | HL | XXXXXX | нинин | CLEAR FUNCTION | | HH | XXXXXX | LLLLLL | SET FUNCTION | TB01130M #### **DESCRIPTION** THIS PLEAPS IS A 6-BIT TRUE/COMPLEMENT AND CLEAR/SET LOGIC FUNCTIONS. THE CONTROL LINES (II AND I2) SELECT ONE OF FOUR LOGIC FUNCTIONS FOR THE 6-BIT INPUT DATA (D1-D6) AND THE 6-BIT OUTPUT FUNCTION (Y1-Y6). WHEN II IS FALSE (I1=LOW) THE FUNCTION IS INVERT IF I2 IS FALSE (I2=LOW) OR TRUE IF I2 IS TRUE (I2=HIGH). WHEN II IS TRUE (I1=HIGH) THE FUNCTION IS CLEAR IF I2 IS FALSE (I2=LOW) OR SET IF I2 IS TRUE (I2=HIGH). THE PLE8P8 ALSO FEATURES THREE-STATE OUTPUTS WITH TWO ACTIVE LOW OUTPUT ENABLE CONTROLS (/El AND /E2). | 11 : | 12 D1-D6 Y1-Y6 | FUNCTION | |------|----------------|----------| | L | L D /D | INVERT | | L I | a D D | TRUE | | H 1 | L X H | CLEAR | | H I | T X L | SET | ## 6-BIT TRUE/COMPLEMENT ZERO/ONE LOGIC FUNCTIONS Monolithic MM Memories ``` PLE5P8 PLE CIRCUIT DESIGN SPECIFICATION P5003 FRANK LEE 04/15/84 EXPANDABLE 3-TO-8 DEMULTIPLEXER MMI SANTA CLARA, CALIFORNIA .ADD SO S1 S2 DI PO .DAT YO Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y0 = PO * DI * /S2 * /S1 * /S0 ; ACTIVE HIGH, SELECT 0 + /PO * DI ; ACTIVE LOW, DI INACTIVE ; ACTIVE LOW, SELECT 4-7 + /PO S2 + /PO ; ACTIVE LOW, SELECT 2,3,6,7 + /PO S0 ; ACTIVE LOW, SELECT 1,3,5,7 Y1 = P0 * DI * /S2 * /S1 * S0 ; ACTIVE HIGH, SELECT 1 + /PO * DI ; ACTIVE LOW, DI INACTIVE + /PO * S2 ; ACTIVE LOW, SELECT 4,5,6,7 * S1 + /PO ; ACTIVE LOW, SELECT 2,3,6,7 + /PO * /S0 : ACTIVE LOW, SELECT 0.2.4.6 Y2 = PO * DI * /S2 * S1 * /S0 ; ACTIVE HIGH, SELECT 2 + /PO * DI ; ACTIVE LOW, DI INACTIVE + /PO S2 ; ACTIVE LOW, SELECT 4-7 + /PO * /Sl ; ACTIVE LOW, SELECT 0,1,4,5 + /PO S0 ; ACTIVE LOW, SELECT 1,3,5,7 Y3 = PO * DI * /S2 * S1 * S0 ; ACTIVE HIGH, SELECT 3 + /PO * DI ; ACTIVE LOW, DI INACTIVE + /PO * S2 ; ACTIVE LOW, SELECT 4-7 * /Sl + /PO ; ACTIVE LOW, SELECT 0,1,4,5 + /PO * /S0 / ; ACTIVE LOW, SELECT 0.2.4.6 Y4 = PO * DI * S2 * /S1 * /S0 ; ACTIVE HIGH, SELECT 4 + /PO * DI ; ACTIVE LOW, DI INACTIVE + /PO * /S2 ; ACTIVE LOW, SELECT 0-3 + /PO ; ACTIVE LOW, SELECT 2,3,6,7 + /PO S0 ; ACTIVE LOW, SELECT 1,3,5,7 ; ACTIVE HIGH, SELECT 5 Y5 = PO * DI * S2 * /S1 * S0 + /PO * DI ; ACTIVE LOW, DI INACTIVE + /PO * /S2 ; ACTIVE LOW, SELECT 0-3 * Sl + /PO ; ACTIVE LOW, SELECT 2,3,6,7 + /PO * /S0 ; ACTIVE LOW, SELECT 0,2,4,6 Y6 = PO * DI * S2 * S1 * /S0 ; ACTIVE HIGH, SELECT 6 + /PO * DI ; ACTIVE LOW, DI INACTIVE * /S2 + /PO ; ACTIVE LOW, SELECT 0-3 + /PO ; ACTIVE LOW, SELECT 0,1,4,5 + /PO SO ; ACTIVE LOW, SELECT 1,3,5,7 ``` TROUTER ; ACTIVE HIGH, SELECT 7 ; ACTIVE LOW, DI INACTIVE ; ACTIVE LOW, SELECT 0,1,4,5 ; ACTIVE LOW, SELECT 0,2,4,6 ; ACTIVE LOW, SELECT 0-3 Y7 = PO \* + /PO + /PO + /PO + /PO \* DI DI \* S2 \* S1 \* S0 \* /Sl \* /S0 \* /S2 #### FUNCTION TABLE #### PO DI S2 S1 S0 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 | ; | | SSS | YYYYYYY | | |------|----|-----|-----------------|-----------------| | ; PO | DI | 210 | 76543210 | COMMENTS | | H | L | xxx | LLLLLLL | DATA INPUT = 0 | | H | H | LLL | LLLLLLH | SELECT OUTPUT 0 | | H | H | LLH | LLLLLHL | SELECT OUTPUT 1 | | H | H | LHL | LLLLHLL | SELECT OUTPUT 2 | | H | H | LHH | LLLLHLLL | SELECT OUTPUT 3 | | H | H | HLL | LLLHLLLL | SELECT OUTPUT 4 | | H | H | HLH | LLHLLLL | SELECT OUTPUT 5 | | H | H | HHL | LHLLLLL | SELECT OUTPUT 6 | | H | H | ннн | HLLLLLL | SELECT OUTPUT 7 | | L | H | XXX | ннннннн | DATA INPUT = 0 | | L | L | LLL | ннннннь | SELECT OUTPUT 0 | | L | L | LLH | ннининги | SELECT OUTPUT 1 | | L | L | LHL | ннингин | SELECT OUTPUT 2 | | L | L | LHH | ннннгнн | SELECT OUTPUT 3 | | L | L | HLL | нннгннн | SELECT OUTPUT 4 | | L | L | HLH | <b>ННГНННН</b> | SELECT OUTPUT 5 | | L | L | HHL | нгиннин | SELECT OUTPUT 6 | | L | L | ннн | <b>Г</b> НННННН | SELECT OUTPUT 7 | | | | | | | # 3-TO-8 DEMULTIPLEXER PLE5P8 **EXPANDABLE** #### DESCRIPTION THIS PLESP8 IMPLEMENTS AN EXPANDABLE 3-TO-8 DEMULTIPLEXER. THE DEVICE DEMULTIPLEXES THREE SELECT INPUT SIGNALS (S2-S0) INTO EIGHT OUTPUTS (Y7-Y0) USING THE INPUT DI WITH POLARITY SELECT PO. SINCE THE DEVICE HAS THREE-STATE OUTPUTS, IT CAN BE EXPANDED USING THE ACTIVE LOW ENABLE PIN (/E). #### PIN ASSIGNMENTS: - HIGH INDICATES OUTPUT IS ACTIVE HIGH. LOW INDICATES OUTPUT IS 1. PO - DATA INPUT (DEMULTIPLEXING INPUT). ACTIVE LOW IF PO IS LOW. 2. DI - SELECT PINS. S2 IS THE MOST SIGNIFICANT BIT. ACTIVE HIGH 3. S2-S0 REGARDLESS OF PO. - OUTPUTS. CAN BE ACTIVE HIGH OR ACTIVE LOW DEPENDING ON PO. 4. Y7-Y0 ACTIVE LOW IF PO IS LOW. #### OPERATIONS TABLE: | PO | DI | S2-S0 | Y7-Y0 | OPERAT | NOI | | |--------|--------|--------|-------------|--------|------------------|-----| | | н | x | н | OUTPU | rs HIGH | | | H | H | S | DEMUX | | ACTIVE | | | L<br>H | L<br>L | S<br>X | /DEMUX<br>L | | ACTIVE<br>IS LOW | LOW | PLE10P4 P5004 PLE CIRCUIT DESIGN SPECIFICATION ULRIK MUELLER 04/01/83 DUAL 2:1 MULTIPLEXER MMI SANTA CLARA, CALIFORNIA .ADD SX SY Al Bl Cl Dl A2 B2 C2 D2 .DAT X1 Y1 X2 Y2 | X1 | | /SX* | | ; SEI | ECT | INPUT | Al | |-----------|---|------|----|-------|-----|-------|----| | | + | SX* | Bl | ; SEI | ECT | INPUT | Bl | | | | | | | | | | | Yl | | /SY* | | ; SEI | ECT | INPUT | Cl | | | + | SY* | Dl | ; SEI | ECT | INPUT | Dl | | <b>X2</b> | = | /SX* | A2 | ; SEI | ECT | INPUT | A2 | | | + | SX* | B2 | ; SEI | ECT | INPUT | B2 | | Y2 | = | /SY* | C2 | ; SEI | ECT | INPUT | C2 | | | + | SY* | D2 | | | INPUT | | #### DESCRIPTION THIS IS AN EXAMPLE OF TWO INDEPENDENT 2-TO-1 MULTIPLEXERS USING A PLE10P4. THE DEVICE WILL SWITCH BETWEEN TWO PAIRS OF 2-BIT INPUTS (A, B AND C, D), AS DETERMINED BY THE TWO SELECT LINES (SX, SY), FOR OUTPUT THROUGH TWO PAIRS OF 2-BIT OUTPUTS (X AND Y). THREE-STATE OUTPUTS ARE ALSO PROVIDED WITH TWO ACTIVE LOW ENABLE PINS (/El AND /E2). THE FUNCTIONS OF THE DEVICE ARE SUMMARIZED IN THE TABLE BELOW: | | | ect<br>es | | IN | PUT | A, | В | IN | PUT | С, | D | | | C | UT: | PUT | x, | Y | | | | |---|---|-----------|--|----|--------|----|----|----|-----|----|-------|-------|------|---|-----|-----------|----|----|------------|--------|---| | | 3 | S | | | A<br>2 | | | | | | | <br> | | | | | | | FUNCTIO | MC | | | | | L | | Al | A2 | x | x | Cl | C2 | x | <br>X | <br>! | | | Al | Cl | A2 | C2 | <br>SELECT | <br>А, | | | I | | H | | Al | A2 | X | X | X | X | Dl | D2 | | | | Al | Dl | A2 | D2 | SELECT | A, | D | | I | Ŧ | L | | X | X | Bl | B2 | Cl | C2 | X | X | | Ľ'n, | | Bl | <b>B2</b> | Cl | C2 | SELECT | В, | С | | 1 | E | H | | X | X | Bl | B2 | X | X | Dl | D2 | | | | B1 | Dl | B2 | D2 | SELECT | В, | D | #### DUAL 2:1 MULTIPLEXER #### Random Logic ``` PLE10P4 P5005 ``` #### PLE CIRCUIT DESIGN SPECIFICATION S. HORIKO 04/29/84 QUAD 2:1 MULTIPLEXER WITH POLARITY CONTROL MMI JAPAN .ADD SEL POL AO Al A2 A3 B0 B1 B2 B3 .DAT Y0 Y1 Y2 Y3 ``` Y0 = /SEL*/POL*/A0 ; SELECT INPUT /A0 (COMP) + /SEL* POL* A0 ; SELECT INPUT A0 (TRUE) + SEL*/POL*/BO ; SELECT INPUT /BO (COMP) + SEL* POL* BO ; SELECT INPUT BO (TRUE) Yl = /SEL*/POL*/Al ; SELECT INPUT /Al (COMP) ; SELECT INPUT Al (TRUE) + /SEL* POL* Al + SEL*/POL*/Bl ; SELECT INPUT /Bl (COMP) + SEL* POL* Bl ; SELECT INPUT Bl (TRUE) Y2 = /SEL*/POL*/A2 ; SELECT INPUT /A2 (COMP) + /SEL* POL* A2 ; SELECT INPUT A2 (TRUE) ; SELECT INPUT /B2 (COMP) + SEL*/POL*/B2 + SEL* POL* B2 ; SELECT INPUT B2 (TRUE) Y3 = /SEL*/POL*/A3 ; SELECT INPUT /A3 (COMP) ; SELECT INPUT A3 (TRUE) + /SEL* POL* A3 + SEL*/POL*/B3 + SEL* POL* B3 ; SELECT INPUT /B3 (COMP) ; SELECT INPUT B3 (TRUE) ``` #### FUNCTION TABLE SEL POL AO Al A2 A3 B0 Bl B2 B3 Y0 Yl Y2 Y3 | ; SEL | ECT | AAAA | BBBB | YYYY | | | | | |-------|-----|------|------|------|----------|------|-------|-------| | ; SEL | POL | 0123 | 0123 | 0123 | COMMENTS | 5 | | | | L | L | LLLL | XXXX | нинн | SELECT ( | COMP | INPUT | /A=00 | | L | L | LHLH | XXXX | HLHL | SELECT ( | COMP | INPUT | /A=05 | | L | L | HLHL | XXXX | LHLH | SELECT ( | COMP | INPUT | /A=10 | | L | L | нннн | XXXX | LLLL | SELECT ( | COMP | INPUT | /A=15 | | L | Ħ | LLLL | XXXX | LLLL | SELECT ! | PRUE | INPUT | A=00 | | L | H | LHLH | XXXX | LHLH | SELECT S | TRUE | INPUT | A=05 | | L | Ħ | HLHL | XXXX | HLHL | SELECT : | TRUE | INPUT | A=10 | | L | H | нннн | XXXX | нннн | SELECT : | TRUE | INPUT | A=15 | | H | L | XXXX | LLLL | нннн | SELECT ( | COMP | INPUT | /B=00 | | H | L | XXXX | LHLH | HLHL | SELECT ( | COMP | INPUT | /B=05 | | Ħ | L | XXXX | HLHL | LHLH | SELECT ( | COMP | INPUT | /B=10 | | H | L | XXXX | нннн | LLLL | SELECT ( | COMP | INPUT | /B=15 | | Ħ | Ħ | XXXX | LLLL | LLLL | SELECT ? | TRUE | INPUT | B=00 | | H | Ħ | XXXX | HLHL | HLHL | SELECT ! | TRUE | INPUT | B=05 | | H | H | XXXX | LHLH | LHLH | SELECT 1 | PRUE | INPUT | B=10 | | Ħ | H | XXXX | нннн | нини | SELECT T | TRUE | INPUT | B=15 | #### **DESCRIPTION** THIS IS AN EXAMPLE OF A QUAD 2:1 MULTIPLEXER WITH POLARITY CONTROL IMPLEMENTED IN A PLE10P4. THE DEVICE SELECTS BETWEEN TWO 4-BIT INPUTS (A1-A4 AND B1-B4) WHICH ARE DIRECTED TO ONE 4-BIT OUTPUT (Y1-Y4) AS DETERMINED BY ONE INPUT SELECT LINE (SEL) AND POLARITY CONTROL (POL). WHEN POLARITY IS TRUE (POL=HIGH), THE TRUE OF THE INPUT SIGNAL IS SELECTED. WHEN POLARITY IS FALSE (POL=LOW), THE COMPLEMENT OF THE INPUT SIGNAL IS SELECTED. THE PLE10P4 ALSO FEATURES THREE-STATE OUTPUTS WITH TWO ACTIVE LOW ENABLE PINS (/E1 AND /E2). THE FUNCTION IS SUMMARIZED BELOW: | SEL | POL | Al-A4 | B1-B4 | Y1-Y4 | |-----|-----|-------|-------|-------| | L | H | A | х | A | | L | L | A | X | /A | | H | H | X | В | В | | H | L | X | В | /B | ## QUAD 2:1 MULTIPLEXER WITH POLARITY CONTROL TB01190N ``` 10 ``` ``` PLE CIRCUIT DESIGN SPECIFICATION PLE5P8 P5006 ULRIK MUELLER 04/29/84 HEXADECIMAL TO SEVEN SEGMENT DECODER MMI SANTA CLARA, CALIFORNIA ADD A B C D LT .DAT /OA /OB /OC /OD /OE /OF /OG /DP B* /D B* C ; SEGMENT A OA = + + /A* /C*/D + A* C*/D + /A* D /B*/C* D LT ; IF LT=H MAKE BLANK TEST ON SEGMENT A /C*/D ; SEGMENT B + A* B* /D OB = + /A*/B* /D + A*/B* D + /A* /C + LT ; IF LT=H MAKE BLANK TEST ON SEGMENT B /C* D ; SEGMENT C C*/D /D /B* /D ; IF LT=H MAKE BLANK TEST ON SEGMENT C ; SEGMENT D OD = /A*/B*/C + /B* D + A*/B* C + A* B*/C + /A* B* C + /A* B* /D ; IF LT=H MAKE BLANK TEST ON SEGMENT D OE = /A* /C ; SEGMENT E C* D + + /A* B + A* B* LT ; IF LT=H MAKE BLANK TEST ON SEGMENT E ; SEGMENT F OF = /A*/B /B* C*/D /C* D B* + /A* B* C LT ; IF LT=H MAKE BLANK TEST ON SEGMENT F OG = B*/C ; SEGMENT G + /A* B /C* D D /B* C*/D LT ; IF LT=H MAKE BLANK TEST ON SEGMENT G ; TURNS DP ON ONLY WHEN LT=H DP = LT ``` TR01200M #### DESCRIPTION THIS EXAMPLE ILLUSTRATES THE USE OF A PLE5P8 AS A HEXADECIMAL TO SEVEN SEGMENT DECODER. THE DEVICE DECODES A 4-BIT BINARY INPUT (D,C,B,A) INTO THE SEVEN SEGMENT OUTPUTS NEEDED TO DRIVE AN LED DISPLAY. NOTE THAT THIS DESIGN IS AN IMPROVEMENT FROM THE 74LS47 SINCE ALL 16 HEXADECIMAL DIGITS (0-F) CAN BE DISPLAYED. A LAMP TEST IS PROVIDED TO ILLUMINATE ALL SEVEN SEGMENTS AND THE DECIMAL POINT (IF DP IS CONNECTED) BY BRINGING LAMP TEST HIGH (LT=HIGH) REGARDLESS OF THE OTHER BINARY INPUTS. THREE-STATE OUTPUTS ARE ALSO PROVIDED WITH ONE ACTIVE LOW ENABLE PIN (/E). | INPUT | 1 | | | IN | PU | T | | 1 | SEGMENT | ! | OUT | PUT | | |-------|---|----|--------|-------|-------|------|--------|----|---------|---|-------------|-------|---------------------------------------------------------------------------| | DIGIT | ! | LT | D | С | В | 3 2 | A | ! | ON | ! | DIS | PLAY | SEGMENT | | 0 | | | <br>T. | <br>L | <br>T | · | <br>r. | | ABCDEF | | 777 | <br>0 | IDENTIFICATION | | 1 | | L | . = | L | | . 1 | - | | BC | • | | 1 | 는 마시 | | 2 | i | L | | L | | | | ់់ | ABDEG | i | | 2 | | | 3 | | L | | L | | | | • | ABCDG | i | | 3 | 그는 그는 그리고 하는 것이 되는 그를 다면 부모네. | | 4 | | L | 1.5 | H | | | | • | BCDFG | ÷ | | 4 | | | 5 | i | L | | Н | | . 1 | | | ACDFG | i | | 5 | | | 6 | i | L | | H | | | | i | ACDEFG | i | | 6 | | | 7 | i | L | _ | Н | | | - | i | ABC | i | | 7 | 크림, [연구인 전 기계 기계 기계 ] - 10.56 [ 11 기기 기계 | | 8 | i | L | | L | | | | i | ABCDEFG | i | | 8 | 보고를 즐겁게 된다면 있다면 없는데 보고 하셨다면 보다. | | 9 | | L | | L | | | | 1 | ABCFG | i | | 9 | | | À | | L | | L | | | | i | ABCEFG | i | | A | and an ilia ayaa ba <b>llaanii lagaanii ayaa</b> | | В | i | L | Н | | | | | | CDEFG | i | | b | D | | č | 1 | L | | Н | | 7 | | | ADEF | 1 | | c | | | Ď | i | L | - 177 | н | | | HT . | - | BCDEG | 1 | | đ | | | E | 1 | L | Н | н | - | ٠,,, | | | ADEFG | 1 | A Section 1 | E | | | F | 1 | L | H | Н | F | 7 | | | AEFG | 1 | | F | OUADA OTED OFT | | X | 1 | H | | X | | | X | 1 | ABCDEFG | 1 | | 8 * | CHARACTER SET | | | | | | | | | | | | | | | 0 123456789A6C4EF | <sup>\*</sup> BLANK TEST OF DISPLAY ## HEXADECIMAL TO SEVEN-SEGMENT DECODER #### HEXADECIMAL TO SEVEN-SEGMENT DECODER PLE5P8 P5007 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 02/03/82 5-BIT BINARY TO BCD CONVERTER MMI SANTA CLARA, CALIFORNIA - .ADD BIO BIL BI2 BI3 BI4 - .DAT B00 B01 B02 B03 B10 B11 B12 B13 B00 = BI0 B01 = /BI4\*/BI3\* - + /BI4\* BI3\* BI2\*/BI1 - + BI4\* BI3\*/BI2\* BI1 - + BI4\*/BI3\*/BI2\*/BI1 - /BI3\* BI2\* BI1 B02 = /BI4\*/BI3\* BI2 - + /BI4\* BI2\* BI1 - + BI4\* BI3\*/BI2 - + BI4\*/BI3\*/BI2\*/BI1 B03 = /BI4\* BI3\*/BI2\*/BI1 - + BI4\* BI3\* BI2\*/BI1 - + BI4\*/BI3\*/BI2\* BI1 B10 = /BI4\* BI3\* BI1 - + /BI4\* BI3\* BI2 - BI3\* BI2\* BI1 - + BI4\*/BI3\*/BI2 B11 = BI4\* BI3 + BI4\* BI2 B12 = BI4\*/BI4 B13 = BI4\*/BI4 ; CONVERT FIRST BIT OF 0 DECIMAL (LSB) ; CONVERT SECOND BIT OF 0 DECIMAL ; CONVERT THIRD BIT OF 0 DECIMAL ; CONVERT FOURTH BIT OF 0 DECIMAL ; CONVERT FIRST BIT OF 1 DECIMAL ; CONVERT SECOND BIT OF 1 DECIMAL ; CONVERT THIRD BIT OF 1 DECIMAL ; CONVERT FOURTH BIT OF 1 DECIMAL (MSB) **5-BIT BINARY** TO BCD **CONVERTER** ### FUNCTION TABLE BI4 BI3 BI2 BI1 BI0 B13 B12 B11 B10 B03 B02 B01 B00 | ; ADDRESS | DA | TA | | |-----------|-------|-------|-----------------| | ;BINARY | BCD 1 | BCD 0 | DESCRIPTION | | ;43 210 | 3210 | 3210 | (DECIMAL VALUE) | | LL LLL | LLLL | LLLL | 0,000 | | LL LLH | LLLL | LLLH | 1 | | LL LHH | LLLL | LLHH | 3 | | LL LHL | LLLL | LLHL | 2 | | LL HHL | LLLL | LHHL | 6 | | LL HHH | LLLL | LHHH | 7 | | LL HLH | LLLL | LHLH | 5 | | LL HLL | LLLL | LHLL | 4 | | ; | | | | | LH LLL | LLLL | HLLL | | | LH LLH | LLLL | HLLH | 9 | | LH LHH | LLLH | LLLH | 1 1 | | LH LHL | LLLH | LLLL | 1 0 | | LH HHL | LLLH | LHLL | 1 4 | | LH HHH | LLLH | LHLH | 1.5 | | LH HLH | LLLH | LLHH | 1 3 | | LH HLL | LLLH | LLHL | 1 2 | | • | | | | | HL LLL | LLLH | LHHL | 1 6 | | HL LLH | LLLH | LHHH | 1 7 | | HL LHH | LLLH | HLLH | 1 9 | | HL LHL | LLLH | HLLL | 18 | | HL HHL | LLHL | LLHL | 2.2 | | нь нин | LLHL | LLHH | 2 3 | | HL HLH | LLHL | LLLH | 2 1 | | HL HLL | LLHL | LLLL | 2 0 | | , | | | 되어 되어 뭐죠 그렇게 먹다 | | HH LLL | LLHL | LHLL | 2 4 | | HH LLH | LLHL | LHLH | 2 5 | | HH LHH | LLHL | LHHH | 2 7 | | HH LHL | LLHL | LHHL | 2 6 | | нн ннг | LLHH | LLLL | 3 0 | | нн нин | LLHH | LLLH | 3 1 | | HH HLH | LLHL | HLLH | 29 | | HH HLL | LLHL | HLLL | 2 8 | | | | | | ### DESCRIPTION THIS 5-BIT BINARY TO 2-DIGIT BCD CONVERTER IS IMPLEMENTED IN A PLE5P8 LOGIC CIRCUIT. THE DEVICE ACCEPTS A 5-BIT BINARY INPUT (BI) AND CONVERTS THIS INTO TWO 4-BIT BINARY CODED DECIMAL (BCD) OUTPUTS (B1 AND B0). THREE-STATE OUTPUTS ARE ALSO PROVIDED WITH ONE ACTIVE LOW ENABLE PIN (/E). 1001250m # Random Logic PLE5 P8 P5008 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 10/16/81 4-BIT BCD TO GRAY CODE CONVERTER MMI SANTA CLARA, CALIFORNIA .ADD B0 B1 B2 B3 .DAT GO G1 G2 G3 G0 = B0 :+: B1 ; CONVERT GO (LSB) G1 = B1 :+: B2 ; CONVERT G1 G2 = B2 :+: B3 ; CONVERT G2 G3 = B3 ; CONVERT G3 (MSB) ### DESCRIPTION THIS PLESP8 WILL CONVERT A 4-BIT BCD INPUT (B3-B0) INTO A 4-BIT GRAY CODE REPRESENTATION (G3-G0) FOR OUTPUT. # 4-BIT BCD TO GRAY CODE CONVERTER TB01240 # PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 03/16/84 4-BIT GRAY CODE TO BCD CONVERTER MMI SANTA CLARA, CALIFORNIA .ADD GO G1 G2 G3 .DAT BO B1 B2 B3 B0 = G0 :+: G1 :+: G2 :+: G3 ; CONVERT BO (LSB) Bl = Gl :+: G2 :+: G3 ; CONVERT B1 B2 = G2 :+: G3 ; CONVERT B2 B3 = G3 ; CONVERT B3 (MSB) ### DESCRIPTION THIS PLE5P8 WILL CONVERT A 4-BIT GRAY CODE INPUT (G3-G0) INTO A 4-BIT BINARY REPRESENTATION (B3-B0) FOR OUTPUT. # 4-BIT GRAY CODE TO BCD CONVERTER TB01250M # Random Logic ``` PLE8P4 PLE CIRCUIT DESIGN SPECIFICATION P5010 FRANK LEE/ULRIK MUELLER 05/14/84 8-BIT PRIORITY ENCODER MMI SANTA CLARA, CALIFORNIA .ADD IO I1 I2 I3 I4 I5 I6 I7 .DAT SO S1 S2 EN ; I7-I0 = 1XXXXXXX S0 = I7 ; 17-I0 = X01XXXXX + /I6* I5 ; 17-10 = X0X01XXX + /16*/14* 13 + /16*/14*/12* 11 ; 17-10 = X0X0X01X ; 17-10 = 1XXXXXXX S1 = I7 ; 17-10 = X1XXXXXX + 16 ; 17-10 = XX001XXX + /15*/14* 13 ; 17-10 = XX00X1XX + /15*/14* 12 S2 = I7 ; 17-10 = 1XXXXXX + 16 ; 17-10 = X1XXXXXX + 15 ; 17-10 = XX1XXXX + I4 ; ALL LOWS ENABLE NEXT PRIORITY ENCODER EN = /10*/11*/12*/13*/14*/15*/16*/17 ``` #### FUNCTION TABLE 17 16 15 14 13 12 11 10 EN S2 S1 S0 7 1 7 17 1 30 P 0 1 10 P | ; | | ·I | P | JТ | L | IN. | ES: | | -01 | JTPU | JT | 3- | | | | | | | | | | |---|---|----|---|----|---|-----|-----|---|-------|------|----|----|---|------|-----|------|-----|------|-----------------|-------|-----| | ; | I | I | I | I | I | I | 1 | I | E | S | s | S | | | | | | | | | | | ; | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | <br>N | 2 | 1 | 0 | | | CON | M | ENT | | (1)<br> | | | | | Н | x | X | X | X | X | X | x | <br>L | Н | Н | н | | 31.2 | 17 | = | HI | GH | 117 | | | | | L | H | X | X | X | Х | Х | X | L | H | H | L | | eld" | 16 | = | HI | GH | | | | | | L | L | H | X | X | Х | X | X | L | H | L | H | | | 15 | = | HI | GH | * | | | | | L | L | L | H | X | X | X | X | L | H | L | L | | | 14 | = | HI | GH : | 70 . •<br>4 / 2 | | | | | L | L | L | L | H | X | X | X | L | L | H | H | | | 13 | = | HI | GH | | | | | | L | L | L | L | L | Н | X | X | L | L | H | L | | | 12 | = | HI | GH | | | | | | L | L | L | L | L | L | H | X | L | L | L | H | | | 11 | = | HI | GH | | | | | | L | L | L | L | L | L | L | H | L | L | L | L | | ug: | IO | = | HI | GH | | | | | | L | L | L | L | L | L | L | L | H | L | L | L | 1 | | 17 | - I( | ) = | LOW | THEN | CARRY | OUT | | | | | | | | | | | <br> | | | | | | | | | | | | | TB01260M THIS 8-BIT PRIORITY ENCODER SCANS FOR THE FIRST HIGH INPUT LINE (17-10) FROM I7 (WHICH HAS THE HIGHEST PRIORITY) TO 10 (WHICH HAS THE LOWEST PRIORITY). IT WILL GENERATE A BINARY ENCODED OUTPUT (S2-S0) WHICH WILL POINT TO THE HIGHEST PRIORITY INPUT WHICH IS AT A HIGH STATE. IF NO INPUT LINES ARE HIGH (17-10=LOW), THEN THE BINARY ENCODED OUTPUTS WILL BE ZERO (S2-S0=LOW) AND THE ENABLE OUTPUT WILL BE HIGH (EN=HIGH) INDICATING A CARRY OUT TO THE NEXT PRIORITY ENCODER. THE OUTPUT ENABLE WILL BE LOW (EN=LOW) IF ANY OF THE INPUT LINES ARE HIGH. THE PLE8P4 ALSO HAS THREE-STATE OUTPUTS WITH TWO ACTIVE-LOW OUTPUT ENABLE CONTROL PINS (/El AND /E2). PLE8 P4 P5011 PLE CIRCUIT DESIGN SPECIFICATION ULRIK MUELLER 04/01/83 4-BIT MAGNITUDE COMPARATOR MMI SANTA CLARA, CALIFORNIA .ADD AO Al A2 A3 B0 Bl B2 B3 .DAT EO NE LT GT EQ = A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* A0:\*:B0 ; A = B NE = A3:+:B3 + A2:+:B2 + A1:+:B1 + A0:+:B0 ; A NOT = B LT = /A3 \* B3 ; A3 LT B3 + A3:\*:B3 \* /A2 \* B2 ; A2 LT B2 + A3:\*:B3 \* A2:\*:B2 \* /A1 \* B1 ; A1 LT B1 + A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* /A0 \* B0 ; A0 LT B0 GT = A3 \*/B3 ; A3 GT B3 + A3:\*:B3 \* A2 \*/B2 ; A2 GT B2 + A3:\*:B3 \* A2:\*:B2 \* A1 \*/B1 ; A1 GT B1 + A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* A0 \*/B0 ; A0 GT B0 ### DESCRIPTION THIS PLESP4 COMPARES TWO 4-BIT NUMBERS (A3-A0 AND B3-B0) TO ESTABLISH IF THEY ARE EQUAL (A = B THEN EQ=H), NOT EQUAL (A NOT = B THEN NE=H), LESS THAN (A LT B THEN LT=H), OR GREATER THAN (A GT B THEN GT=H) AND REPORTS THE COMPARISON STATUS ON THE OUTPUTS (EQ, NE, LT, GT) AS ILLUSTRATED IN THE OPERATIONS TABLE BELOW. THE PLE8P4 ALSO FEATURES THREE-STATE OUTPUTS WITH TWO ACTIVE-LOW OUTPUT ENABLE CONTROL PINS (/El AND /E2). | INPUT NUMBERS C<br>A3-A0 B3-B0 | | RISON STATUS<br>NE LT GT | OPERATION | | |--------------------------------|---|--------------------------|-----------|----------------| | A = B | H | L L L | COMPARE A | EQUAL TO B | | A NOT = B | L | н х х | COMPARE A | NOT EQUAL TO B | | A LT B | L | H H L | COMPARE A | LESS THAN B | | A GT B | L | H L H | COMPARE A | GREATER THAN B | # 4-BIT MAGNITUDE COMPARATOR TB01280 PLE CIRCUIT DESIGN SPECIFICATION ### PLE12P4 P5012 VINCENT COLI 10/16/83 6-BIT MAGNITUDE COMPARATOR MMI SANTA CLARA, CALIFORNIA .ADD A0 A1 A2 A3 A4 A5 B0 B1 B2 B3 B4 B5 .DAT EQ NE LT GT EO = A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* A0:\*:B0 ; A = B NE = A5:+:B5 + A4:+:B4 + A3:+:B3 + A2:+:B2 + A1:+:B1 + A0:+:B0 ; A NOT= B ; A5 LT B5 LT = /A5 \* B5+ A5:\*:B5 \* /A4 \* B4 ; A4 LT B4 ; A3 LT B3 A5:\*:B5 \* A4:\*:B4 \* /A3 \* B3 A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* /A2 \* B2 ; A2 LT B2 A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2:\*:B2 \* /A1 \* B1 ; A1 LT B1 + A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* /A0 \* B0 ; A0 LT B0 GT = A5 \*/B5; A5 GT B5 + A5:\*:B5 \* A4 \*/B4 ; A4 GT B4 + A5:\*:B5 \* A4:\*:B4 \* A3 \*/B3 ; A3 GT B3 + A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2 \*/B2 + A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2:\*:B2 \* A1 \*/B1 ; A2 GT B2 ; Al GT Bl A5:\*:B5 \* A4:\*:B4 \* A3:\*:B3 \* A2:\*:B2 \* A1:\*:B1 \* A0 \*/B0 ; A0 GT B0 ### DESCRIPTION THIS PLE12P4 COMPARES TWO 6-BIT NUMBERS (A5-A0 AND B5-B0) TO ESTABLISH IF THEY ARE EQUAL (A = B THEN EQ=H), NOT EQUAL (A NOT = B THEN NE=H), LESS THAN (A LT B THEN LT=H), OR GREATER THAN (A GT B THEN GT=H) AND REPORTS THE COMPARISON STATUS ON THE OUTPUTS (EQ, NE, LT, GT) AS ILLUSTRATED IN THE OPERATIONS TABLE BELOW. THE PLE12P4 ALSO FEATURES THREE-STATE OUTPUTS WITH TWO ACTIVE-LOW OUTPUT ENABLE CONTROL PINS (/El AND /E2). | 5- <i>P</i> | 70 | B5 | 5-B0 | EQ | NE | LT | GT | | OPERATION | e Di | T MAGNITUDE | |-------------|-----|----|-----------------------------|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------|--------------------------|--------|----------------| | A | = | | В | H | L | L | L | | COMPARE A EQUAL TO B | | OMPARATOR | | A | NOT | - | В | L | Ħ | X | X | | COMPARE A NOT EQUAL TO B | | PLE12P4 | | A | LT | | В | L | Ħ | H | L | | COMPARE A LESS THAN B | | | | A | GT | | В | L | H | L | Ħ | | COMPARE A GREATER THAN B | B2 1 | | | | | | | | | | | | | B1 2 | 19 | | | | | | | | | | | | | <b>⊣- ⊑</b> են | | | | | | | | | | Г | —_Eo ) | B0 3 | | | | | | | , 6, | | | | | | A5 4 | 17 | | | | | TWO<br>6-BIT | 1~~ | | 6-BIT | | + | —NE | A4 5 | AND OR GATE | | | | | INPUT | 1 | | AGNITU | | | COMPARISON<br>STATUS | | GATE 5 | | | | | NUMBERS | ° ( B_€ | → `` | | | | | A3 6 | ARRAY 15 | | | | | | | <u> </u> | 1775 5859 | . 71 | | <u>gт</u> ] | A2 7 | <b>→</b> 14 | | | | | | | | e de la composición dela composición de la dela composición de la compos | | $ \wedge $ | | A1 [8 | | | | | | and the part of the surface | | | | | ᆔ | | | 一片后 | | | | | | | | | Ī | E1 E2 | | A0 L9 | 12 | | | | | | | | | | | | GND 10 | | ``` PLE CIRCUIT DESIGN SPECIFICATION PLE9P4 COLI/MUELLER 09/09/84 P5011A 4-BIT MAGNITUDE COMPARATOR WITH POLARITY CONTROL MMI SANTA CLARA, CALIFORNIA .ADD AO Al A2 A3 B0 Bl B2 B3 POL .DAT EQ NE LT GT EO = A3:*:B3* POL * A2:*:B2* POL * A1:*:B1* POL * A0:*:B0* POL ; A EQ B + A3:+:B3*/POL * A2:+:B2*/POL * A1:+:B1*/POL * A0:+:B0*/POL ; A /EQ B NE = A3:+:B3* POL + A2:+:B2* POL + A1:+:B1* POL + A0:+:B0* POL ; A NE B + A3:*:B3*/POL + A2:*:B2*/POL + A1:*:B1*/POL + A0:*:B0*/POL ; A /NE.B LT = /A3 * B3* POL ; A3 LT B3 ; A2 LT B2 + A3:*:B3* POL * /A2 * B2* POL + A3:*:B3* POL * A2:*:B2* POL * /A1 * B1* POL ; Al LT Bl + A3:*:B3* POL * A2:*:B2* POL * A1:*:B1* POL * /A0 * B0* POL ; A0 LT B0 + A3 */B3*/POL ; A3 /LT B3 ; A2 /LT B2 + A3:*:B3*/POL * A2 */B2*/POL + A3:*:B3*/POL * A2:*:B2*/POL * A1 */B1*/POL ; Al /LT Bl + A3:*:B3*/POL * A2:*:B2*/POL * A1:*:B1*/POL * A0 */B0*/POL ; A0 /LT B0 + A3:*:B3*/POL + A2:*:B2*/POL + A1:*:B1*/POL + A0:*:B0*/POL ; A /LT B ; A3 GT B3 GT = A3 */B3* POL ; A2 GT B2 + A3:*:B3* POL * A2 */B2* POL ; Al GT Bl + A3:*:B3* POL * A2:*:B2* POL * A1 */B1* POL ``` + /A3 \* B3\*/POL + A3:\*:B3\*/POL \* /A2 \* B2\*/POL + A3:\*:B3\*/POL \* A2:\*:B2\*/POL \* /Al \* Bl\*/POL THIS PLE9P4 COMPARES TWO 4-BIT NUMBERS (A3-A0 AND B3-B0) TO ESTABLISH IF THEY ARE EQUAL (A EQ B), NOT EQUAL (A NE B), LESS THAN (A LT B), OR GREATER THAN (A GT B). THE COMPARISON STATUS IS REPORTED WITH ACTIVE-HIGH POLARITY (EQ, NE, LT, GT) WHEN THE POLARITY CONTROL INPUT IS TRUE (POL=H) AND WITH ACTIVE-LOW POLARITY (/EQ, /NE, /LT, /GT) WHEN THE POLARITY CONTROL INPUT IS FALSE (POL=L). + A3:\*:B3\*/POL \* A2:\*:B2\*/POL \* A1:\*:B1\*/POL \* /A0 \* B0\*/POL ; A0 /GT B0 + A3:\*:B3\*/POL + A2:\*:B2\*/POL + A1:\*:B1\*/POL + A0:\*:B0\*/POL ; A /GT B + A3:\*:B3\* POL \* A2:\*:B2\* POL \* A1:\*:B1\* POL \* A0 \*/B0\* POL ; A0 GT B0 ; A3 /GT B3 ; A2 /GT B2 ; Al /GT Bl THE PLESP4 ALSO FEATURES THREE-STATE OUTPUTS WITH ONE ACTIVE-LOW OUTPUT ENABLE CONTROL PIN (/E). ### OPERATIONS TABLE: | INPUT<br>A3-A0 | | MBERS<br>B3-B0 | POLARITY<br>POL * | COMPA<br>EQ | RISC<br>NE | N ST | ATUS<br>GT | | OPERATION | |----------------|----|----------------|-------------------|-------------|------------|------|------------|-----|--------------------------| | A 1 | EO | В | н | н | L | L | L | | COMPARE A EQUAL TO B | | A 1 | _ | В | H | L | H | X | X | 100 | COMPARE A NOT EQUAL TO B | | A I | LT | В | Ħ | L | H | H | L | | COMPARE A LESS THAN B | | A C | GT | В | H | L | H | L | Н | | COMPARE A GREATER THAN B | <sup>\*</sup> COMPARISON STATUS WILL BE ACTIVE-LOW (I.E., /EQ, /NE, /LT, /GT) WHEN POL=L. # 4-Bit Magnitude Comparator with Polarity Control # **Block Diagram** PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 06/12/84 TB01310M ``` P5013 8-BIT BARREL SHIFTER MMI SANTA CLARA, CALIFORNIA .ADD DO D1 D2 D3 D4 D5 D6 D7 S0 S1 S2 .DAT 00 01 02 03 04 05 06 07 00 = /S0*/S1*/S2* D0 ; SHIFT 0 PLACES + S0*/S1*/S2* D1 ; SHIFT 1 PLACES + /S0* S1*/S2* D2 ; SHIFT 2 PLACES + S0* S1*/S2* D3 ; SHIFT 3 PLACES + /S0*/S1* S2* D4 ; SHIFT 4 PLACES + S0*/S1* S2* D5 ; SHIFT 5 PLACES ; SHIFT 6 PLACES + /S0* S1* S2* D6 + S0* S1* S2* D7 ; SHIFT 7 PLACES 01 = /S0*/S1*/S2* D1 ; SHIFT 0 PLACES ; SHIFT 1 PLACES + S0*/S1*/S2* D2 + /S0* S1*/S2* D3 ; SHIFT 2 PLACES + S0* S1*/S2* D4 ; SHIFT 3 PLACES + /S0*/S1* S2* D5 ; SHIFT 4 PLACES + S0*/S1* S2* D6 ; SHIFT 5 PLACES ; SHIFT 6 PLACES + /S0* S1* S2* D7 + S0* S1* S2* D0 ; SHIFT 7 PLACES O2 = /S0*/S1*/S2* D2 ; SHIFT 0 PLACES ; SHIFT 1 PLACES + S0*/S1*/S2* D3 + /S0* S1*/S2* D4 ; SHIFT 2 PLACES + S0* S1*/S2* D5 ; SHIFT 3 PLACES + /S0*/S1* S2* D6 ; SHIFT 4 PLACES + S0*/S1* S2* D7 ; SHIFT 5 PLACES + /S0* S1* S2* D0 ; SHIFT 6 PLACES + S0* S1* S2* D1 ; SHIFT 7 PLACES O3 = /S0*/S1*/S2* D3 ; SHIFT 0 PLACES + S0*/S1*/S2* D4 ; SHIFT 1 PLACES + /S0* S1*/S2* D5 ; SHIFT 2 PLACES + S0* S1*/S2* D6 ; SHIFT 3 PLACES + /S0*/S1* S2* D7 ; SHIFT 4 PLACES + S0*/S1* S2* D0 ; SHIFT 5 PLACES + /S0* S1* S2* D1 ; SHIFT 6 PLACES + S0* S1* S2* D2 : SHIFT 7 PLACES 04 = /S0*/S1*/S2* D4 ; SHIFT 0 PLACES + S0*/S1*/S2* D5 ; SHIFT 1 PLACES + /S0* S1*/S2* D6 ; SHIFT 2 PLACES + S0* S1*/S2* D7 ; SHIFT 3 PLACES + /S0*/S1* S2* D0 ; SHIFT 4 PLACES + S0*/S1* S2* D1 ; SHIFT 5 PLACES + /S0* S1* S2* D2 ; SHIFT 6 PLACES + S0* S1* S2* D3 ; SHIFT 7 PLACES ``` PLE11P8 # 10 #### **DESCRIPTION** THE 8-BIT BARREL SHIFTER, IMPLEMENTED IN A PLE11P8, ROTATES EIGHT BITS OF DATA (D7-D0) A NUMBER OF LOCATIONS INTO THE OUTPUTS (O7-O0) AS SPECIFIED BY THE 3-BIT BINARY ENCODED SHIFT CONTROL LINE (S2-S0). THE THREE-STATE OUTPUTS ARE IN A HIGH-Z STATE WHEN ANY ONE OF THE TWO OUTPUT ENABLE PINS (/E1 OR /E1) ARE HIGH. A POSSIBLE UPGRADE VERSION OF THIS DESIGN IMPLEMENTED IN A PLE12P8 COULD INCLUDE A DIRECTION CONTROL LINE. THIS CONTROL LINE PERMITS THE 8-BIT BARREL SHIFTER TO ROTATE DATA IN EITHER DIRECTION (LEFT OR RIGHT). ### **8-BIT BARREL SHIFTER** тв Propieta de la composition de Santa (de Casa Casa Casa Salada). La composition de la composition de la composition de la composition de la composition de la composition de la La composition de la composition de la composition de la composition de la composition de la composition de la ``` O5 = /S0*/S1*/S2* D5 ; SHIFT 0 PLACES + S0*/S1*/S2* D6 ; SHIFT 1 PLACES + /S0* S1*/S2* D7 ; SHIFT 2 PLACES + S0* S1*/S2* D0 ; SHIFT 3 PLACES + /S0*/S1* S2* D1 ; SHIFT 4 PLACES ; SHIFT 5 PLACES + S0*/S1* S2* D2 + /S0* S1* S2* D3 ; SHIFT 6 PLACES + S0* S1* S2* D4 ; SHIFT 7 PLACES O6 = /S0*/S1*/S2* D6 ; SHIFT 0 PLACES + S0*/S1*/S2* D7 ; SHIFT 1 PLACES + /S0* S1*/S2* D0 ; SHIFT 2 PLACES + S0* S1*/S2* D1 ; SHIFT 3 PLACES + /S0*/S1* S2* D2 ; SHIFT 4 PLACES + S0*/S1* S2* D3 ; SHIFT 5 PLACES + /S0* S1* S2* D4 ; SHIFT 6 PLACES + S0* S1* S2* D5 ; SHIFT 7 PLACES 07 = /S0*/S1*/S2* D7 ; SHIFT 0 PLACES ; SHIFT 1 PLACES + S0*/S1*/S2* D0 + /S0* S1*/S2* D1 ; SHIFT 2 PLACES ; SHIFT 3 PLACES + S0* S1*/S2* D2 + /S0*/S1* S2* D3 ; SHIFT 4 PLACES + S0*/S1* S2* D4 ; SHIFT 5 PLACES + /S0* S1* S2* D5 ; SHIFT 6 PLACES + S0* S1* S2* D6 ; SHIFT 7 PLACES ``` ### FUNCTION TABLE S2 S1 S0 D7 D6 D5 D4 D3 D2 D1 D0 O7 O6 O5 O4 O3 O2 O1 O0 | ; SHIFT<br>; SSS<br>; 210 | INPUT DATA<br>DDDDDDDDD<br>76543210 | OUTPUT DATA<br>OOOOOOOO<br>76543210 | COMMENTS | |---------------------------|-------------------------------------|-------------------------------------|--------------------------------| | LLL | HLLLLLLL | HLLLLLL | BARREL SHIFT ONE HIGH 0 PLACES | | LLH | HLLLLLL | LHLLLLL | BARREL SHIFT ONE HIGH 1 PLACES | | LHL | HLLLLLL | LLHLLLL | BARREL SHIFT ONE HIGH 2 PLACES | | LHH | HLLLLLLL | LLLHLLLL | BARREL SHIFT ONE HIGH 3 PLACES | | HLL | HLLLLLLL | LLLLHLLL | BARREL SHIFT ONE HIGH 4 PLACES | | HLH | HLLLLLL | LLLLHLL | BARREL SHIFT ONE HIGH 5 PLACES | | HHL | HLLLLLL | LLLLLHL | BARREL SHIFT ONE HIGH 6 PLACES | | ннн | HLLLLLLL | LLLLLLH | BARREL SHIFT ONE HIGH 7 PLACES | | LLL | <b>L</b> HHHHHHH | LННННННН | BARREL SHIFT ONE LOW 0 PLACES | | LLH | <b>L</b> НННННН | нінннін | BARREL SHIFT ONE LOW 1 PLACES | | LHL | <b>L</b> НННННН | ннгиннин | BARREL SHIFT ONE LOW 2 PLACES | | LHH | <b>Г</b> НННННН | нннгинн | BARREL SHIFT ONE LOW 3 PLACES | | HLL | <b>L</b> HННННН | ниницини | BARREL SHIFT ONE LOW 4 PLACES | | HLH | <b>L</b> НННННН | нинингин | BARREL SHIFT ONE LOW 5 PLACES | | HHL | <b>L</b> НННННН | нининги | BARREL SHIFT ONE LOW 6 PLACES | | ННН | <b>L</b> НННННН | нининны | BARREL SHIFT ONE LOW 7 PLACES | PLE CIRCUIT DESIGN SPECIFICATION CHRIS JAY 05/30/84 ``` .ADD SO S1 INV DO D1 D2 D3 D4 D5 D6 /EN .DAT 00 01 02 03 00 = D0*/S0*/S1*/INV* EN ; SELECT INPUT DO + /D0*/S0*/S1* INV* EN ; SELECT INPUT /DO ; SELECT INPUT D1 + D1* S0*/S1*/INV* EN ; SELECT INPUT /Dl + /D1* S0*/S1* INV* EN + D2*/S0* S1*/INV* EN ; SELECT INPUT D2 + /D2*/S0* S1* INV* EN ; SELECT INPUT /D2 + D3* S0* S1*/INV* EN ; SELECT INPUT D3 + /D3* S0* S1* INV* EN ; SELECT INPUT /D3 O1 = D1*/S0*/S1*/INV* EN ; SELECT INPUT D1 ; SELECT INPUT /Dl + /D1*/S0*/S1* INV* EN + D2* S0*/S1*/INV* EN ; SELECT INPUT D2 + /D2* S0*/S1* INV* EN ; SELECT INPUT /D2 + D3*/S0* S1*/INV* EN ; SELECT INPUT D3 + /D3*/S0* S1* INV* EN ; SELECT INPUT /D3 + D4* S0* S1*/INV* EN ; SELECT INPUT D4 + /D4* S0* S1* INV* EN ; SELECT INPUT /D4 O2 = D2*/S0*/S1*/INV* EN ; SELECT INPUT D2 + /D2*/S0*/S1* INV* EN ; SELECT INPUT /D2 + D3* S0*/S1*/INV* EN ; SELECT INPUT D3 + /D3* S0*/S1* INV* EN ; SELECT INPUT /D3 + D4*/S0* S1*/INV* EN ; SELECT INPUT D4 + /D4*/S0* S1* INV* EN ; SELECT INPUT /D4 + D5* S0* S1*/INV* EN ; SELECT INPUT D5 + /D5* S0* S1* INV* EN ; SELECT INPUT /D5 O3 = D3*/S0*/S1*/INV* EN ; SELECT INPUT D3 ``` + D5\*/S0\* S1\*/INV\* EN ; SELECT INPUT D5 4-BIT RIGHT SHIFTER WITH PROGRAMMABLE OUTPUT POLARITY PLE11P4 P5014 MMI LTD., FARNBOROUGH, U.K. + /D3\*/S0\*/S1\* INV\* EN + D4\* S0\*/S1\*/INV\* EN + /D4\* S0\*/S1\* INV\* EN + /D5\*/S0\* S1\* INV\* EN + D6\* S0\* S1\*/INV\* EN + /D6\* S0\* S1\* INV\* EN 10 ; SELECT INPUT /D3 ; SELECT INPUT D4 ; SELECT INPUT /D5 ; SELECT INPUT D6 ; SELECT INPUT /D6 ; SELECT INPUT /D4 # Random Logic ### FUNCTION TABLE /EN S1 S0 INV D6 D5 D4 D3 D2 D1 D0 O3 O2 O1 O0 | ;-C | CNO: | ro | L- | | | | | | | | | | | | | 그 아이 이렇게 되었다면 보다 하는 사람들이라고 이렇게 아내다. | . P | |-----|------|----|----|----|-----|-----|---|---|--------------|-----------|----|----|-----|----|----|-------------------------------------|-----| | ;/ | | | I | -1 | [N] | PU' | r | D | AT? | <b>\-</b> | Ot | JT | PU' | rs | | 이 그는 그 회사를 잃었다면 하는 사람들이 되었다. | | | ; E | S | S | N | D | D | D | D | D | D | D | 0 | 0 | 0 | 0 | | | | | ; N | 1 | 0 | V | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 | | COMMENTS | | | Н | x | x | x | x | x | x | x | x | - <b>-</b> - | <br>х | L | L | L | L | | TEST ENABLE, OUTPUTS GO LOW | | | L | L | L | L | L | L | L | H | H | H | H | H | H | H | H | | SHIFT COUNT = 0, TRUE POLARITY | | | L | L | H | L | L | L | L | H | H | H | H | L | H | H | ·H | | SHIFT COUNT = 1, TRUE POLARITY | | | L | H | L | L | L | L | L | H | H | H | H | L | L | H | H | | SHIFT COUNT = 2, TRUE POLARITY | | | L | H | H | L | L | L | L | H | H | H | H | L | L | L | H | | SHIFT COUNT = 3, TRUE POLARITY | | | L | L | L | H | L | L | L | H | H | H | H | L | L | L | L | ŧ* | SHIFT COUNT = 0, COMP POLARITY | | | L | L | H | H | L | L | L | H | H | Н | H | H | L | L | L | | SHIFT COUNT = 1, COMP POLARITY | | | L | H | L | H | L | L | L | H | H | H | H | H | H | L | L | | SHIFT COUNT = 2, COMP POLARITY | | | L | H | H | H | L | L | L | H | H | Н | H | H | H | H | L | | SHIFT COUNT = 3, COMP POLARITY | | THIS PLE11P4 IMPLEMENTS A 4-BIT RIGHT SHIFTER WITH PROGRAMMABLE OUTPUT POLARITY. THE SHIFTER CAN RIGHT SHIFT SEVEN BITS OF DATA, FOUR BITS AT A TIME. THE SEVEN DATA INPUTS (D6-D0) ARE SHIFTED 0, 1, 2, OR 3 LOCATIONS AS DETERMINED BY THE 2-BIT SHIFT CONTROL LINE (S1-S0). THE SHIFTED DATA IS THEN DIRECTED TO THE FOUR OUTPUTS (03-00). THE CUTPUT DATA IS NONINVERTED (O=D) WHEN INV=L AND INVERTED (O=/D) WHEN INV=H. THE OUTPUTS ARE FORCED LOW (O=L) WHEN /EN=H REGARDLESS OF OTHER INPUTS. THE PLE11P4 ALSO FEATURES THREE-STATE OUTPUTS WITH ONE ACTIVE LOW OUTPUT ENABLE (/E). A POSSIBLE UPGRADE VERSION OF THIS DESIGN IMPLEMENTED IN A PLE12P4 COULD INCLUDE A DIRECTION CONTROL LINE. THIS CONTROL LINE PERMITS THE 4-BIT RIGHT SHIFTER TO SHIFT DATA IN EITHER DIRECTION (LEFT OR RIGHT). #### OPERATIONS TABLE: | /EN | INV S1-S0 | D6-D0 03-00 | OPERATION | | |-----|-----------|-------------|-----------------------------------|--| | H | х х | X L | DISABLE OUTPUTS LOW | | | L | L N | D SHIFT(D | SHIFT NONINVERTED DATA "N" PLACES | | | L | H N | D SHIFT(/ | O) SHIFT INVERTED DATA "N" PLACES | | # 4-BIT RIGHT SHIFTER WITH PROGRAMMABLE OUTPUT POLARITY # Random Logic ``` PLE8 P8 ``` Y0 = D0 P5015 PLE CIRCUIT DESIGN SPECIFICATION MIKE VOGEL 11/28/83 8-BIT TWO'S COMPLEMENT CONVERSION MMI BREA, CALIFORNIA .ADD DO D1 D2 D3 D4 D5 D6 D7 .DAT Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y1 = D1 :+: D0 ; CONVERT 1ST BIT (LSB) XI = DI :+: DO ; CONVERT 2ND BIT Y2 = D2 :+: D0 + D1 ; CONVERT 3RD BIT Y3 = D3 :+: D0 + D1 + D2 ; CONVERT 4TH BIT Y4 = D4 :+: D0 + D1 + D2 + D3 ; CONVERT 5TH BIT Y5 = D5 :+: D0 + D1 + D2 + D3 + D4 ; CONVERT 6TH BIT Y6 = D6 :+: D0 + D1 + D2 + D3 + D4 + D5 ; CONVERT 7TH BIT Y7 = D7 :+: D0 + D1 + D2 + D3 + D4 + D5 + D6 ; CONVERT 8TH BIT (MSB) ### FUNCTION TABLE | D | D6 | | | | D2 | | | ¥7 | ¥6 | ¥5 | ¥4 | Y3 | ¥2 | Y1 | Y0 | ;DECIMAL | |---|-----|---|---|---|----|---|---|----|----|----|----|----|----|----|----|----------| | 1 | L | | L | L | L | L | L | L | L | L | L | L | L | L | L | 0 | | I | L | L | L | L | L | L | H | H | H | H | H | H | H | H | H | 1 | | I | L | L | L | L | L | H | H | H | H | H | H | H | H | L | H | 3 | | I | . L | L | L | L | H | H | H | H | H | H | H | H | L | L | H | 7 | | 1 | L | L | L | H | H | H | H | H | H | H | H | L | L | L | H | 15 | | I | L | L | H | H | H | H | H | H | H | H | L | L | L | L | H | 31 | | I | L | H | H | H | H | H | H | H | H | L | L | L | L | L | H | 63 | | I | . н | H | H | H | H | H | H | H | L | L | L | L | L | L | H | 127 | | F | H | H | H | H | H | H | H | L | L | L | L | L | L | L | L | 255 | | E | H | H | H | H | H | H | L | L | L | L | L | L | L | H | L | 254 | | E | H | H | H | H | H | L | L | L | L | L | L | L | H | L | L | 252 | | E | H | H | H | H | L | L | L | L | L | L | L | H | L | L | L | 248 | | E | H | H | H | L | L | L | L | L | L | L | H | L | L | L | L | 240 | | E | - | H | L | L | L | L | L | L | L | H | L | L | L | L | L | 224 | | E | | L | L | L | L | L | L | L | H | L | L | L | L | L | L | 192 | | F | L | L | L | L | L | L | L | H | L | L | L | L | L | L | L | 128 | | | | | | | | | | | | | | | | | | | TB01370 THIS PLESPS CONVERTS AN 8-BIT BINARY NUMBER (D7-D0) INTO TWO'S COMPLEMENT REPRESENTATION (Y7-Y0) WHERE D7 AND Y7 ARE THE MSB AND D0 AND Y0 ARE THE LSB. TWO'S COMPLEMENT REPRESENTATION IS USED IN SIGNED ARITHMETIC SYSTEMS. # 8-BIT TWO'S COMPLEMENT CONVERSION # Random Logic PLE5P8 P5027 PLE CIRCUIT DESIGN SPECIFICATION S. HORIKO 11/29/83 A PORTION OF TIMING GENERATOR FOR PAL ARRAY PROGRAMMING MMI JAPAN - .ADD AO A1 A2 A3 A4 - .DAT NAO NAI NA2 NA3 NA4 TIALR TVCC TO - ; NEXT ADDRESS GENERATOR NA0 = /A0 ; INCREMENTER (LSB) NA1 = A0 :+: Al ; INCREMENTER (BIT1) NA2 = A2 :+: A0\* A1 ; INCREMENTER (BIT2) NA3 = A3 :+: A0\* A1\* A2 ; INCREMENTER (BIT3) NA4 = A4 :+: A0\* A1\* A2\* A3 ; INCREMENTER (MSB) ; TIMING WAVEFORMS TIALR = /A4\*/A3 + /A4\* /A2\*/A1 ; TIMING FOR I, A AND L/R TVCC = /A4\*/A3\*A2 + /A4\* A3\*/A2\*/A1 ; TIMING FOR VCC TO = /A4\* A3\*/A2\*/A1\*/A0 + /A4\*/A3\* A2\* A1 + /A4\*/A3\* A2\* A0 ; TIMING FOR O ### FUNCTION TABLE A4 A3 A2 A1 A0 NA4 NA3 NA2 NA1 NA0 TIALR TVCC TO | , | NNNNN | | | | | | | 요한 아니는 그는 것이 되었다. 그런 한 경험에 함께 되는 것이 하는 것이 없는 것이 되었다.<br>요한 아니는 사람들은 그는 것이 되었다. 그렇게 되었다. 그는 것이 되었다. 그는 것이 되었다. | |---------|-------|--------|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ; AAAAA | AAAAA | TIMING | WAVEFO | RMS | | | | | | ;43210 | 43210 | TIALR | TVCC | <b>10</b> | , , ; | ## | ; | COMMENTS | | LLLLL | LLLLH | н | L | L<br>L | ; | 01 | | ASSERT TIALR | | LLLLH | LLLHL | H | L | L | - | 02 | • | | | LLLHL | LLLHH | H | L | L | | 03 | • | 이 그 그 이 사람들들이 그 이번 모양 일시 중요를 되었다. | | LLLHH | LLHLL | H | L | L | , | | ÷ | 하고 하는 이 회에 반물을 하는 것이 하지만 모습니다. | | LLHLL | LLHLH | H | H | L | , | | • | ASSERT TVCC | | LLHLH | LLHHL | Ħ | H | H | , | 1.1245 | ; | ASSERT TO | | LLHHL | LLHHH | H | Ħ | H | , | | | (1155 - 50 기업 - 15일 기업 | | LLHHH | LHLLL | Ħ | H | H | | | 3. | [1] | | LHLLL | LHLLH | H | H | H | | | • | 기가 있다면 하다는 사람이 아무지 않는 사람이 하다 많아 된다면 하다. | | LHLLH | LHLHL | Ħ | Ħ | L | , | 10 | • | CLEAR TO | | LHLHL | LHLHH | L | L | L | | 11 | • | CLEAR TIALR & TVCC | | LHLHH | LHHLL | L | L | L | 4 (1) | | • | 그 일반 15. 20. 5. 15. 15. 15. 15. 15. 15. 15. 15. 15. | | LHHLL | LHHLH | L | L | L | | 13 | ÷ | | | LHHLH | LHHHL | L | L | L | | 14 | | | | LHHHL | LHHHH | L | L | L | and the first of the same | 15 | | 등다면서 말이 잘 하는 하지만 하는데 그는 하나는 사람들이 | | LHHHH | HLLLL | L | L | L | the second of the second | 16 | | | | HLLLL | HLLLH | L | L | L | | 17 | ; | | | HLLLH | HLLHL | L | L | L | 1010 BH 11 1 TH | 18 | ; | | | HLLHL | HLLHH | L | L | L | | 19 | | 가게 되는 것이 되는 것이 되었다. 그는 것이 되었다. 그는 것이 되었다. 그런 그를 보고 있다. 그런 그를 보고 있다. 그런 그를 보고 있다.<br>1985년 - 1987년 | | HLLHH | HLHLL | L | L | L | | 20 | , | | | HLHLL | HLHLH | L | L | L | | | | 에 가입되고 이 경험하는 가면 있는 것이 되었다. 그는 이 사람이 되었다는 것이 되었다.<br>경기 내가 가입되는 것이 있는 것이 있는 것이 되었다. 그는 것이 되었다는 것이 없는 것이 없었다. 나를 했다. | | HLHLH | HLHHL | L | L | L | • | | • | 요 하는 것이 많아 있는 것이 되었다.<br>19 1일 : 10 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | HLHHL | HLHHH | L | L | L | • | 23 | • | | | HLHHH | HHLLL | L | L | L | • | 24 | | 사이 사람이 발생을 경기로 하는 사람이 가장 생각이 있는 것이다.<br>기사 사람은 사람이 되었다. 그 사람이 사람들은 사람들이 사람들이 가는 사람들이 사용했다. | | HHLLL | HHLLH | L | L | L | 3.44 | 25 | ; | | | HHLLH | HHLHL | L | L | L | | 26 | | | | HHLHL | HHLHH | L | L | L | | 27 | | | | HHLHH | HHHLL | L | L | L | | 28 | ; | | | HHHLL | HHHLH | L | L | L | • | 29 | , | | | HHHLH | HHHHL | L | L | L | The state of s | | | 경기 위에 가장 경기를 받는 것이 되었다. 그 사람들은 사람들이 되었다.<br>1984년 - 1일 | | HHHHL | нинин | L | L | L | 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1 | 31 | ٠, | | | нинин | LLLLL | L | L | L | | 32 | | | THIS LOGIC SPECIFICATION IS A TIMING SIGNAL GENERATOR TO BE USED FOR ARRAY PROGRAMMING OF PAL DEVICES. A PLE5P8 FOLLOWED BY AN 8-BIT REGISTER ARE USED TO IMPLEMENT THIS FUNCTION. THE PLE CONTAINS BOTH 5-BIT NEXT ADDRESS AND 3-BIT WAVEFORMS. TIALR OUTPUT IS A TIMING WAVEFORM FOR I, A, AND L/R SIGNALS, AND TVCC AND TO OUTPUTS ARE USED FOR VCC AND O SIGNALS, RESPECTIVELY. THE SCHEMATIC IS AS FOLLOWS: APPLYING 200KHz CLOCK SIGNAL TO THE CLK INPUT OF THE REGISTER GENERATES THE FOLLOWING TIMINGS: 1. I, A, AND L/R WIDTH : 50 usec 2. tD2 : 20 usec 3. tD : 5 usec 4. tVCCP : 30 usec 5. Tp : 20 usec BECAUSE THE TIMING PATTERNS ARE STORED IN THE PROM, WE CAN EASILY CALIBRATE THE RELATIONS AND THE PERIOD AMONG THOSE SIGNALS TO MAKE AN OPTIMUM CONDITION. # A PORTION OF A TIMING GENERATOR FOR PAL LOGIC CIRCUIT ARRAY PROGRAMMING TB01410M PLE CIRCUIT DESIGN SPECIFICATION ``` 10 ``` ``` s. HORIKO 11/29/83 P5028 TIMING GENERATOR FOR PAL DEVICE SECURITY FUSE PROGRAMMING MMI JAPAN .ADD AO A1 A2 A3 A4 .DAT NAO NAI NA2 NA3 NA4 TVCC TPO1 TP11 ; NEXT ADDRESS GENERATOR ; ( THE COUNTER LOCKS UP AT COUNT-22 ) = /A4* /A1*/A0 ; INCREMENTER (LSB) + /A4* A1*/A0 ; INCREMENTER (LSB) + A4*/A3*/A2* /A0 ; INCREMENTER (LSB) + A4*/A3* A2*/A1 ; INCREMENTER (LSB) NAO = /A4* + A4*/A3* A2*/A1 ; INCREMENTER (LSB) + A4*/A3*/A2*/A1* A0 ; INCREMENTER (BIT1) + A4*/A3*/A2* A1*/A0 ; INCREMENTER (BIT1) NA2 = /A4* A2*/A1 ; INCREMENTER (BIT2) + /A4* A2* /A0 ; INCREMENTER (BIT2) + /A4* /A2* A1* A0 ; INCREMENTER (BIT2) + A4*/A3* A2*/A1 ; INCREMENTER (BIT2) + A4*/A3*/A2* A1* A0 ; INCREMENTER (BIT2) = /A4* A3*/A2 ; INCREMENTER (BIT3) + /A4* A3* /A1 ; INCREMENTER (BIT3) + /A4* A3* /A0 ; INCREMENTER (BIT3) NA3 = /A4* A3*/A2 + /A4*/A3* A2* A1* A0 ; INCREMENTER (BIT3) NA4 = /A4* A3* A2* A1* A0 ; INCREMENTER (MSB) + A4*/A3*/A2 ; INCREMENTER (MSB) + A4*/A3* /Al ; INCREMENTER (MSB) ; TIMING WAVEFORMS ; TIMING FOR VCC TVCC = /A4 + A4*/A3*/A2*/A1 + A4*/A3*/A2* /A0 TP01 = /A4*/A3* A2 ; TIMING FOR PIN 01 + /A4*/A3* + /A4*/A3* Al A0 + /A4* A3*/A2*/A1*/A0 ; TIMING FOR PIN 11 TP11 = /A4* A3* A2 + /A4* A3* A1 + A4*/A3*/A2*/A1 ``` PLE5P8 # FUNCTION TABLE A4 A3 A2 A1 A0 NA4 NA3 NA2 NA1 NA0 TVCC TP01 TP11 | ; | NNNNN | | | | | | | | | | | | | |---------|-------|--------|------|-------|------|-----|----|-----|-------|-----------|-------------|---------|-------------------| | ; AAAAA | AAAAA | TIMING | WAVE | FORMS | | | | | | | | | | | ;43210 | 43210 | TVCCP | TP01 | TPll | | ; | ## | ; | | COMMEN | TS | | <u> 1845 - 18</u> | | LLLLL | LLLLH | H | L | L | | ; | 01 | ; | | ASSERT | TVCC, | START | HERE | | LLLLH | LLLHL | Ħ | H | L | | ; | 02 | ; | | ASSERT | TP01 | | | | LLLHL | LLLHH | Ħ | H | L | | ; | 03 | ; | | | | | | | LLLHH | LLHLL | Ħ | H | L | | ; | 04 | ; | 10.44 | | | | | | LLHLL | LLHLH | H | H | L | | ; | 05 | ; | | | | | | | LLHLH | LLHHL | Ħ | H | L | | ; | 06 | ; | | 전원 (File) | | | | | LLHHL | LLHHH | H | H | L | | ; | 07 | , | | | | | | | LLHHH | LHLLL | Ħ | H | L | 1.50 | ; | 08 | • | | | | | | | LHLLL | LHLLH | H | H | L | | ; | 09 | ; | | CLEAR | TP01 | | | | LHLLH | LHLHL | H | L | L | | , | 10 | • ; | | ASSERT | TPll | 6 | 343 63 | | LHLHL | LHLHH | H | L | H | | ; | 11 | ; | | | | | | | LHLHH | LHHLL | H | L | H | | ; | 12 | ; | | | | | | | LHHLL | LHHLH | H | L | Ħ | | ; | 13 | ; | | | | | Turb. | | LHHLH | LHHHL | H | L | H | | , | 14 | ; | | | The section | | | | LHHHL | LHHHH | H | L | H | | , | 15 | • | | | | | | | LHHHH | HLLLL | H | L | H | | | 16 | | | | | | | | HLLLL | HLLLH | H | L | Ħ | | ; | 17 | ٠, | | | | | | | HLLLH | HLLHL | H | L | H | | • | 18 | • | | | | | | | HLLHL | HLLHH | H | L | L | | ; | | | | CLEAR | TPll | | | | HLLHH | HLHLL | L | L | L | | . • | 20 | | | CLEAR | | | | | HLHLL | HLHLH | L | L | L | | | 21 | • | | | | | | | HLHLH | HLHLH | L | L | L | | | 22 | | | TOOP H | ERE UN | TTI. RE | SET | THIS LOGIC SPECIFICATION IS A TIMING SIGNAL GENERATOR TO BE USED FOR SECURITY FUSE PROGRAMMING OF PAL DEVICES. A PLE5P8 FOLLOWED BY AN 8-BIT REGISTER ARE USED TO IMPLEMENT THIS FUNCTION. THE PLE LOGIC CIRCUIT CONTAINS TWO FUNCTIONS IN THE SINGLE CHIP. THE FIRST FUNCTION IS A UNIQUE COUNTER USED FOR NEXT ADDRESS GENERATION. THE COUNTER INCREMENTS UP TO COUNT-21 AND THEN LOCKS UP THE INCREMENTAL OPERATION AT COUNT-22. THE SECOND FUNCTION IS A TIMING GENERATOR USED FOR DEFINING TIMING RELATIONSHIP AMOUNG VCC, PO1, AND P11 SIGNALS. THE SCHEMATIC IS AS FOLLOWS: THIS LOGIC OUTPUTS A SEQUENCE OF TIMING PATTERNS DURING THE INCREMENTAL OPERATION AND THEN HOLDS ALL OUTPUTS LOW UNTIL A RESET SIGNAL FOR THE 8-BIT REGISTER IS APPLIED. APPLYING 200 KHz CLOCK SIGNAL TO THE CLK INPUT OF THE REGISTER, THE FOLLOWING TIMINGS ARE GENERATED: 1. VCC WIDTH : 95 usec 2. TPP : 40 usec 3. tD : 5 usec BY APPLYING THIS DESIGN METHOD, WE CAN EASILY GENERATE A SEQUENCE OF UNIQUELY DEFINED PATTERNS EACH TIME THE RESET PULSE IS APPLIED. ## TIMING GENERATOR FOR PAL SECURITY FUSE PROGRAMMING # Fast Arithmetic Look-up In performing arithmetic operations like trigonometric functions, multiplications and division, in order to reduce the delay, look-up tables are often used. # Sine Look-up For trigonometric functions like sine function, it is very timeconsuming to generate the function using the polynomial which represents the function. PLE devices can provide a very good alternative for sine look-up. An example is to use a 2Kx8 PLE device to do a sine look-up of an 11-bit input to 8-bit sine outputs. Since sine function has the following property: $\sin(x) = \sin(\pi - x) = -\sin(\pi + x) = -\sin(2\pi - x) = \sin(2\pi + x)$ , what is needed is just the sine function for $0 < x < \pi/2$ ; the rest can be easily calculated using the above relations. In order to fully utilize the dynamic range, the inputs of the sine look-up PLE device should be normalized to $(\pi/2)/(2^n) = \pi[2^n + 1]$ where n is the number of address lines to the device. Since n is fixed for the PLE device chosen, and $\pi$ is a constant, for the look-up table $\pi/[2^n + 1]$ is a constant. Therefore, if the sine function of a given x is to be found, x will first be multiplied by the constant $[2^n + 1]/\pi$ and sent to the address of the PLE device to get the final result. Cos (x) is related to sine function as $\sin (\pi/2 - x)$ . Thus the cosine function can also be found in the same manner by using $\pi/2 - x$ instead of just x. Other functions like tangent, secant etc., can also be found as a function of sine. To increase the dynamic range of outputs, we can just use another PLE device to generate the less-significant bits of the sine function. If a larger dynamic range is needed for the inputs, the result may be approximated using the Taylor series: f (X) = f (X0) + f' (X0) (X - X0) + 1/2f" (X0) (X - X0)<sup>2</sup> + ... Where f' and f" are the first and second derivations of f. Since X0 by itself represents a resolution of $2^{-n}$ , and X is X0 concatenated with the rest of the bits, X - X0 must lie between 0 and $1/2^{-n}$ . For f (X) = $\sin$ (X), ``` f(X0) = \sin(X0) f'(X0) = \cos(X0) and f''(X0) = -\sin(X0) ``` So f" (X0) is between -1 and 0 for X0 lies between 0 and $\pi/2$ and X - X0 < $2^{-n}$ . Therefore, the last term will be between '1/2" and 0, and as long as we do not want to expand the dynamic range of X beyond 2n-bits, it should be sufficient to approximate sin (X) in the first two terms: $\sin (X) + \sin (X0) + \cos (X0) (X - X0)$ Since X – X0 is represented by only the bits after the more significant n-bits, and $\cos(X0) = \sin(\pi/2 - X0)$ , the implementation will be very simple. ## Division Division will normally be much slower than multiplication. There are several ways to perform division. Bit-by-bit division restoring and nonrestoring algorithms are generally very slow. Another way is to use several bits at a time division which is faster than the previous methods. A third way is to multiply the dividend by the inverse of the divisor. The inverse of the divisor can be found by getting an approximation followed by iterations. The approximation is again given by the Taylor series: f (X) = f (X0) + f' (X0) (X - X0) + $$1/2$$ f" (X0) (X - X0)<sup>2</sup> + ... and f (X0) = $1/X$ 0 f' (X0) = $-1/X$ 0<sup>2</sup> f" (X0) = $2/X$ 0<sup>3</sup> Say X0 is 8-bits long and the first approximation of the inverse is found using a 256x8 PLE device. The first approximation can be obtained by subtracting $(X-X0)/(X0^2)$ . Since the first approximation is limited by an error of approximately $(X-X0)^2/X0^2$ , and if X0 at least 1, the error is limited by approximately $(X-X0)^2$ . Since X0 has an 8-bit resolution, X-X0 is represented by the rest of the bits. The resolution of the second approximation will be about 16 bits. The third approximation is similarly deduced and has a resolution of about 32 bits, and the fourth has a resolution of about 64 bits. The inverse thus obtained is then multiplied by the dividend to give the quotient. # Scaling In arithmetic operations, scaling is sometimes needed. Scaling normally involves multiplication or division by a constant. If this constant can be expressed in 2<sup>n</sup> where n is an integer, then scaling is simply shifting. Scaling with other constants may need a multiplier. A multiplier is more expensive and has a higher pin count than using a PLE device because the constant that the operand is to be scaled by is not required as an input as in the case of a multiplier. This will tremendously reduce the overhead for data scaling. # **Other Applications** Arithmetic look-up are also very useful for arithmetic operations where conventional binary integral arithmetic is not applicable — like residue arithmetic, and distributed arithmetic. PLE8P8 P5018 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 12/08/82 4-BIT MULTIPLIER LOOK-UP TABLE MMI SANTA CLARA, CALIFORNIA .ADD X0 X1 X2 X3 Y0 Y1 Y2 Y3 .DAT SO S1 S2 S3 S4 S5 S6 S7 S7,S6,S5,S4,S3,S2,S1,S0 = x3,x2,x1,x0 .\*. y3,y2,y1,y0 ### FUNCTION TABLE X3 X2 X1 X0 Y3 Y2 Y1 Y0 S7 S6 S5 S4 S3 S2 S1 S0 | ; -OPER | ANDS- | PRODUCTS | | | | | | |---------|-------|----------|----|----|------|----|-----| | ; XXXX | YYYY | SSSSSSS | C | MC | MENT | 'S | | | ;3210 | 3210 | 76543210 | | | | | | | LLLL | LLLL | LLLLLLL | 0 | * | 0 | = | 0 | | LLLH | нннн | LLLLHHHH | 1 | * | 15 | = | 15 | | нннн | LLLH | LLLLHHHH | 15 | * | 1 | = | 15 | | ннин | нннн | HHHLLLLH | 15 | * | 15 | = | 225 | | | | | | | | | | #### DESCRIPTION THIS PLESPS PERFORMS 4-BIT LOOK-UP TABLE MULTIPLICATION. THE DEVICE ACCEPTS TWO 4-BIT OPERANDS (X3-X0 AND Y3-Y0) TO PRODUCE THE 8-BIT PRODUCT (S7-S0). THE PLESPS ALSO HAS THREE-STATE OUTPUTS WITH TWO ACTIVE-LOW OUTPUT ENABLE CONTROL PINS (/El AND /E2). X3 X2 X1 X0 TWO 4-BIT Y3 Y2 Y1 Y0 OPERANDS S7 S6 S5 S4 S3 S2 S1 S0 8-BIT PRODUCT 4-BIT MULTIPLIER LOOK-UP TABLE ``` PLE5P8 PLE CIRCUIT DESIGN SPECIFICATION PETER ZECHERLE 03/06/84 P5023 PETER ZECHERLE 03/06/84 ARC TANGENT LOOK-UP TABLE MMI GMBH MUNICH .ADD AO A1 A2 A3 A4 .DAT FO F1 F2 F3 F4 F5 F6 F7 F0 = A1* /A3*/A4 ; COMPUTE DIGIT FOR 2EXP-7 (0.00078125) (LSB) A2*/A3 + A0*/A1* A3*/A4 + /A0* A1* /A4 + /A0* A1* /A4 + /A0*/A1* /A3* A4 + A0* A2 A1* A2 F1 = /A1* A3*/A4 ; COMPUTE DIGIT FOR 2EXP-6 (0.015625) + A0* /A3* A4 Al* /A3* A4 A2*/A3* A4 A0* A1* /A3 A0* A2*/A3 + /A0* A1* A2* /A4 A0* /A2* A3*/A4 F2 = A0* /A3*/A4 ; COMPUTE DIGIT FOR 2EXP-5 (0.03125) + A1*/A2* /A4 A3* A4 + /A0* A2* A3*/A4 + /Al* A2* A3*/A4 A1*/A2* /A4 ; COMPUTE DIGIT FOR 2EXP-4 (0.0625) /A1* A2* /A4 + /A0* A3*/A4 + /A1* A3*/A4 F4 = /Al* = /Al* A3*/A4 + A0* Al*/A2* /A4 ; COMPUTE DIGIT FOR 2EXP-3 (0.125) A1* A2*/A3*/A4 + /A0* A3*/A4 F5 = A0*/A1* /A4 ; COMPUTE DIGIT FOR 2EXP-2 (0.25) A2*/A3*/A4 /A2* A3*/A4 + /A0* A3*/A4 F6 = A0*/A1*/A2*/A3 ; COMPUTE DIGIT FOR 2EXP-1 (0.5) + A0* A1* A2* A3 A4 F7 = Al ; COMPUTE DIGIT FOR 2EXPO (1) (MSB) A2 A3 ``` ### FUNCTION TABLE | ;- | ; | ANG | LE- | | F = ARCTAN (A) | | | | | | | | | | | | | |-----------|----|-----|-----|------|----------------|---------|----|-----------|----|----|----|----|----|---------|---------------|------------|--| | ; INTEGER | | | | | 3 | INTEGER | | FRACTIONS | | | | | | | F = ARCTAN(A) | | | | A4 | A3 | A2 | Al | A0 | | F7 | F6 | F5 | F4 | F3 | F2 | F1 | F0 | ; ANGLE | LOOK-UP | CALCULATED | | | L | L | L | L | L | | L | L | L | L | L | L | L | L | 0 | 0.0000 | 0.0000 | | | L | L | L | L | H | | L | H | H | L | L | H | L | L | 1 | 0.7813 | 0.7854 | | | L | L | L | H | L | | H | L | L | L | H | H | L | H | 2 | 1.1016 | 1.1071 | | | L | L | H | L | L | | H | L | H | L | H | L | L | H | 4 | 1.3203 | 1.3258 | | | L | L | H | L | H | | H | L | H | L | H | H | H | H | 5 | 1.3672 | 1.3734 | | | L | H | L | L | L | | H | L | H | H | H | L | H | L | 8 | 1.4531 | 1.4464 | | | H | L | L | L | L | | H | H | L | L | L | L | L | H | 16 | 1.5078 | 1.5084 | | | H | H | H | H | H | | H | H | L | L | L | H | L | H | 31 | 1.5391 | 1.5385 | | | | | | | 30.0 | | | | | | | | | | | | | | ### DESCRIPTION THIS APPLICATION ILLUSTRATES THE CALCULATION OF THE ARC TANGENT FUNCTION USING A PLESP8 AS A LOOK-UP TABLE. OTHER TRIGONOMETRIC FUNCTIONS (SUCH AS SINE, COSINE, COTANGENT, SECANT, COSECANT AND THEIR ARC INVERSE EQUIVALENT FUNCTIONS) OR HYPERBOLIC FUNCTIONS CAN ALSO BE CONSTRUCTED USING PLE DEVICES AS LOOK-UP TABLES. $$F = ARCTAN(A)$$ WHERE $F = ARC$ TANGENT OF A A = ANGLE IN RADIANS EXAMPLE: FOR A = 5, F = ARCTAN(5) = 1.3672 A PLE DEVICE WITH MORE INPUTS, SUCH AS THE PLE11P8, SHOULD BE USED TO CONSTRUCT A LOOK-UP TABLE WHEN ADDITIONAL ACCURACY IS REQUIRED. ``` PLE5P8 PLE CIRCUIT DESIGN SPECIFICATION P5024 WILLY VOLDAN 06/02/84 HYPOTENUSE OF A RIGHT TRIANGLE LOOK-UP TABLE MMI GMBH MUNICH .ADD A0 A1 B0 B1 B2 .DAT C0 C1 C2 C3 C4 C5 C6 C7 C0 = A0*/B2* B1 ; COMPUTE DIGIT FOR 2EXP-5 (0.03125) (LSB) + /Al* A0* B2*/Bl + Al* /B2* B0 + Al* /B2* B1 /B2* B1 + A1*/A0* B2*/B1*/B0 + A1* A0* B1* B0 A0*/B2* B0 C1 = A0* B1*/B0 ; COMPUTE DIGIT FOR 2EXP-4 (0.0625) + /A1* A0* B2 + A1*/A0*/B2* + A1*/A0* B2* /B0 + A0* B2* B0 + Al* A0* Bl C2 = A0*/B2* B0 ; COMPUTE DIGIT FOR 2EXP-3 (0.125) + /A1* A0*/B2* B1 + A1*/A0* B2*/B1 + A1* A0* B2* B1 + Al* /B2*/B1* B0 C3 = /A1* A0*/B2*/B1* B0 ; COMPUTE DIGIT FOR 2EXP-2 (0.25) + A1*/A0* B1*/B0 + A1*/A0* B2 + A1* B2* C4 = A1*/A0*/B2* B1 ; COMPUTE DIGIT FOR 2EXP-1 (0.5) + Al* A0* B2*/B1* B0 + Al* AO* Bl*/BO C5 = /A1* ; COMPUTE DIGIT FOR 2EXPO (1) A0*/B2*/B1 /A0* B1* B0 B2* B0 + A1* A0*/B2* /B0 + Al* A0* /Bl C6 = /A1* B1 + A1* /B2*/B1 + B2* B1 ; COMPUTE DIGIT FOR 2EXP1 (2) /A0* Bl B1*/B0 ; COMPUTE DIGIT FOR 2EXP2 (4) (MSB) + A1* A0* B1* B0 ``` # **Fast Arithmetic Look-up** # FUNCTION TABLE | • | ENGT<br>DE A | | SID:<br>IDE | | | NGT<br>TEG | H OF<br>ER | TH | | | TEN<br>ION | USE | SI | DES | LEN | GTH OF | HYPOTENU | JSE | |----|--------------|-------|-------------|----|-------|------------|------------|----|----|----|------------|-----|-------|-----|-----|--------|----------|-----| | Al | A0 | В2 | Bl | B0 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | ; A | В | LOO | K-UP | CALCULAT | ľED | | L | L | <br>L | L | L | <br>L | L | L | L | L | L | L | L | <br>0 | 0 | 0 | .00 | 0.00 | | | L | L | L | L | H | L | L | H | L | L | L | L | L | 0 | 1 | 1 | .00 | 1.00 | | | L | L | L | H | L | L | H | L | L | L | L | L | L | 0 | 2 | 2 | .00 | 2.00 | | | L | L | H | L | L | H | L | L | L | L | L | L | L | 0 | 4 | 4 | .00 | 4.00 | | | L | H | L | L | L | L | L | H | L | L | L | L | L | 1 | 0 | 1 | .00 | 1.00 | | | H | L | L | L | L | L | H | L | L | L. | L | L | L | 2 | 0 | 1 | .00 | 1.00 | | | H | L | L | H | L | L | H | L | H | H | L | L | H | 2 | 2 | 2 | .78 | 2.83 | | | H | L | H | L | L | H | L | L | L | H | H | H | H | 2 | 4 | 4 | . 47 | 4.47 | | | H | H | L | H | L | L | H | H | H | L | L | H | H | 3 | 2 | 3 | .59 | 3.61 | | | H | H | H | H | H | H | H | H | L | H | H | H | H | 3 | 7 | 7 | .47 | 7.62 | | # HYPOTENUSE OF A RIGHT TRIANGLE LOOK-UP TABLE THE GENERATION OF COMPLEX ARITHMETIC FUNCTIONS SUCH AS THE PYTHAGOREAN THEOREM IS GENERALLY VERY DIFFICULT TO IMPLEMENT DIRECTLY IN HARDWARE. HOWEVER, IMPLEMENTING THE FUNCTION AS A LOOK-UP TABLE USING A PLE GREATLY SIMPLIFIES THE PROBLEM. THIS EXAMPLE ILLUSTRATES HOW TO IMPLEMENT A LOOK-UP TABLE IN A PLE5P8 WHICH CALCULATES THE LENGTH OF THE HYPOTENUSE OF A RIGHT TRIANGLE AS A FUNCTION OF THE LENGTH OF THE TWO REMAINING SIDES OF THE TRIANGLE. THE THEOREM OF PATHAGOREAN STATES THAT THE LENGTH OF THE HYPOTENUSE OF A RIGHT TRIANGLE IS EQUAL TO THE SQUARE ROOT OF THE SUM OF THE SQUARE OF THE OTHER TWO SIDES OR C = SQRT(A\*\*2 + B\*\*2). THE INPUTS, "A" AND "B", CORRESPOND TO THE SIDES ADJACENT TO THE RIGHT ANGLE (I.E. 90 DEGREE ANGLE), WHILE THE OUTPUT, "C", CORRESPONDS TO THE SIDE OPPOSITE TO THE RIGHT ANGLE WHICH IS CALLED THE HYPOTENUSE. C = SQRT(A\*\*2 + B\*\*2) WHERE C = LENGTH OF SIDE C (THE HYPOTENUSE) A = LENGTH OF SIDE A B = LENGTH OF SIDE B EXAMPLE: FOR A = 2 AND B = 4, C = SQRT(2\*\*2 + 4\*\*2) = 4.47 ``` 10 ``` ``` PLE5P8 PLE CIRCUIT DESIGN SPECIFICATION P5025 PETER WITTFOTH 06/02/84 PERIMETER OF A CIRCLE LOOK-UP TABLE MMI GMBH MUNICH .ADD RO R1 R2 R3 R4 .DAT PO P1 P2 P3 P4 P5 P6 P7 /R1* R2*/R3*/R4 : COMPUTE DIGIT FOR 2EXPO (1) (LSB) + /R0*/R1* R2* /R4 R1* R2* R4 R1*/R2*/R3 R0*/R1*/R2* R3 + /R0* R1*/R2 R1*/R2* /R4 /R1*/R2* R4 P1 = R0* /R2*/R3 ; COMPUTE DIGIT FOR 2EXP1 (2) + /R0* R1* R2*/R3 + /R0* /R2* R3 R0* R2* R3 + /R0* R2*/R3* R4 + R0*/R1* R2* /R4 /R1* R2* R3*/R4 R3* R4 R0* R1* P2 = R0*/R1* /R3*/R4 ; COMPUTE DIGIT FOR 2EXP2 (4) + R0* R1*/R2*/R3* R4 + /R0* R1* R2* R3* R4 + /R0* R1*/R2* /R4 R1* R2*/R3*/R4 R0* R1* R3*/R4 + /R0*/R1*/R2* R4 /R1* R2*/R3* R4 R0*/R1* R3* R4 P3 = /R0* R1*/R2* /R4 ; COMPUTE DIGIT FOR 2EXP3 (8) R0*/R1*/R2* R3 R0*/R1*/R2* R4 /R2* R3* R4 R0* + R0* R2*/R3*/R4 + /R0* R2* R3*/R4 R1* R2* R3*/R4 R2*/R3* R4 R1* R2*/R3* R4 /R0* R1* R2* R4 + /R0*/R1* R2*/R3 P4 = R0* R1*/R2*/R3 ; COMPUTE DIGIT FOR 2EXP4 (16) R1*/R2*/R3* R4 + /R0*/R1* R2*/R3 R0*/R1* R2* /R4 /R1*/R2* R3 /R0* R1* R3*/R4 R1* R2* R3*/R4 /R1* R3* R4 + /R0* R2* R3* R4 ``` # Fast Arithmetic Look-up ``` R1* R2*/R3*/R4 ; COMPUTE DIGIT FOR 2EXP5 (32) /R1*/R2* R3*/R4 /R2*/R3* R4 R1*/R2* R4 /R1* R2* R3* R4 + /R0* R1*/R2* R3 + /R0*/R1* R2* R4 + /R0* R2* R3* R4 P6 = R0* R1* R3*/R4 + /R0*/R1* /R3* R4 ; COMPUTE DIGIT FOR 2EXP6 (64) R2* R3*/R4 /R2*/R3* R4 + R0* R1* R2* R3 P7 = R0* R2* R4 + R1* R2* R4 ; COMPUTE DIGIT FOR 2EXP7 (128) (MSB) R3* R4 FUNCTION TABLE ;---RADIUS---- -----PERIMETER----- ; INTEGER MSB INTEGER LSB PERIMETER OF A CIRCLE R4 R3 R2 R1 R0 P7 P6 P5 P4 P3 P2 P1 P0 ; RADIUS LOOK-UP CALCULATED LLLL LLLLLLLL LLLH LLLLHHL 1 - 6 6.3 12.6 L LLHL LLLLHHLH 2 13 LLHH L L L LHLLHH 3 19 18.8 LHLL LLLHHLLH 4 25 25.1 ``` # PERIMETER OF A CIRCLE LOOK-UP TABLE 8 16 50 101 195 50.3 100.5 194.8 TB01520M HLLL HLLLL HHHHH L L L HHLLHL HHLLLLHH 31 LHHLLHLH THIS EXAMPLE ILLUSTRATES HOW TO IMPLEMENT A LOOK-UP TABLE IN A PLE5P8 FOR THE PERIMETER OF A CIRCLE AS A FUNCTION OF THE RADIUS. THE INPUT PINS (R4-R0), WHICH REPRESENT THE RADIUS OF A CIRCLE, ARE MULTIPLIED BY 2 TIMES PI IN ORDER TO CALCULATE THE PERIMETER OF A CIRCLE (P7-P0). THIS LOOK-UP TABLE IS VALID FOR RADII BETWEEN 0 AND 31. A PLE8P8 SHOULD BE USED INSTEAD IF A LARGER RADIUS RANGE (BETWEEN 0 AND 81) IS REQUIRED. P = 2\*PI\*R WHERE P = PERIMETER OF THE CIRCLE PI = 3.1415 R = RADIUS OF THE CIRCLE (BETWEEN 0 AND 31) EXAMPLE: FOR R = 3, P = 2\*PI\*3 = 19 ``` PLE5P8 PLE CIRCUIT DESIGN SPECIFICATION P5026 WILLY VOLDAN 06/03/84 PERIOD OF OSCILLATION FOR A MATHEMATICAL PENDULUM LOOK-UP TABLE MMI GMBH MUNICH .ADD LO L1 L2 L3 L4 .DAT TO T1 T2 T3 T4 T5 T6 T7 T0 = /L4* /L2*/L1* L0 ; COMPUTE DIGIT FOR 2EXP-5 (0.03125) (LSB) + /L3*/L2* L1*/L0 L3*/L2* L0 + /L4* L2*/L1*/L0 + L4* L3* L0 + L4*/L3* L1 + L4*/L3* L2* /L0 Tl = /L2* L1*/L0 ; COMPUTE DIGIT FOR 2EXP-4 (0.0625) + /L4*/L3* L2* L0 + /L4* L3*/L2* L1 + /L4* L2*/L1*/L0 + L4*/L3*/L2* L1 + /L3* L2*/L1 + L4* L3* /L1* L0 + L4* L3* Ll*/LO T2 = /L4*/L3* Ll*/LO ; COMPUTE DIGIT FOR 2EXP-3 (0.125) + /L4* L3*/L2* L0 + L4*/L3*/L2*/L1*/L0 + L4*/L3* L1* L0 + L4* L3*/L2* L1*/L0 + L4* L3* L2*/L1 + L4* L2* L0 + /L4*/L3* /L1* L0 + /L4*/L3* L2* /L0 T3 = /L4* L3* L1* L0 ; COMPUTE DIGIT FOR 2EXP-2 (0.25) + L4*/L3* Ll + L4* L3* L2*/L1 /L3*/L2*/L1* L0 + /L3* L2* L1* L0 L3*/L2* L1* L0 + L3* L2*/L1* L0 + /L4* L2*/L1* L0 T4 = /L4*/L3* L1*/L0 ; COMPUTE DIGIT FOR 2EXP-1 (0.5) + /L3* L2* L1 + /L4* L3* L2*/L1 + L4*/L3* L2 + L4* L2* L1 L2* L1*/L0 ``` ``` T5 = /L4* /L2* /L0 ; COMPUTE DIGIT FOR 2EXPO (1) + /L4* /L2*/L1 + L3* /L0 + L3*/L2 + L3* /L1 + L4* L3 T6 = /L4* /L2* L1* L0 ; COMPUTE DIGIT FOR 2EXP1 (2) + /L4* L3* /L0 + /L4*/L3* L2 + /L4*/L3* /L1 T7 = L3* L2* L1* L0 ; COMPUTE DIGIT FOR 2EXP2 (4) (MSB) + L4 ``` # FUNCTION TABLE | IN | TITE TO | | | | | | OF | OPCI | LLA | TIO | N | | | | | |-----------|---------|-----------------------|---------------------|------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | ; INTEGER | | | | | INT | EGE | R | F | RAC | TIO | N | | PERIOD OF | OSCILLATION | | | L3 | L2 | Ll | ro . | <b>T</b> 7 | Т6 | <b>T</b> 5 | Т4 | <b>T</b> 3 | <b>T</b> 2 | Tl | TO | ; AMPLITUDE | LOOK-UP | CALCULATED | | | | L | L | L | L | L | H | L | L | | L | L | 1 | 2.0000 | 2.0050 | | | L | L | L | Ħ | L | L | H | L | H | H | L | H | 2 | 2.8125 | 2.8356 | | | L | L | Ħ | L | L | L | H | H | L | H | H | H | 3 | 3.4375 | 3.4728 | | | L | H | L | L | L | H | L | L | L | H | H | H | 5 | 4.4375 | 4.4834 | | | Ħ | L | L | L | L | H | H | L | L | L | L | L | 9 | 6.0000 | 6.0151 | | | L . | L | L | L | H | L | L | L | L | H | L | L | 17 | 8.2500 | 8.2670 | | | Ħ | H | H | H | Ħ | L | H | H | L | Ħ | L | H | 32 | 11.3125 | 11.3423 | | | | | L<br>L<br>L<br>H<br>L | L L L L H L L L L L | L L H<br>L H L<br>H L L<br>I L L L | L L L L L L L L L L L L L L L L L L L | L L L L L L L L L L L L L L L L L L L | L L L L L H L L H L L H L L H L L H L L H L L H L L H L L H L L H L | L L L L L H L L L H L L L H L L L H L L L H H L L L H L L L L H L L L L H L L L L H L L L L H L L L L L | L L L L L H L L L L H L L H L L H L L H L L H L L H H L L H L L L H L L L L L L | L L L L L H L L L L L L L L L L L L L L | L L L L L H L L L L L L L L L H L L L L | L L L L L H L L L L L L L L L L L L L L | L L L L L L L L L L L L L L L L L L L | L L L L L L L L L L L L 1 2.0000 L L L H L L H L H H L H 2 2.8125 L H L L L H H L H H H 3 3.4375 H L L L L H L L L H H H 5 4.4375 L L L L L H H L L L L L 9 6.0000 L L L L H L L L H L L 17 8.2500 | | # PERIOD OF OSCILLATION FOR A MATHEMATICAL PENDULUM LOOK-UP TABLE TB01550N #### DESCRIPTION THIS PLESP8 IS USED TO IMPLEMENT A LOOK-UP TABLE FOR THE PERIOD OF OSCILLATION OF A MATHEMATICAL PENDULUM. THE PERIOD OF OSCILLATION FOR MATHEMATICAL PENDULUM (T) IS DEPENDENT UPON ITS AMPLITUDE OF SWING (L) AND THE ACCELERATION DUE TO GRAVITY (G). THE PERIOD OF OSCILLATION IS CALCULATED USING THE FOLLOWING EQUATION: T = 2\*PI\*SQRT(L/G) WHERE T = PERIOD OF OSCILLATION IN SECONDS PI = 3.14 L = AMPLITUDE OF SWING IN METERS G = ACCELERATION DUE TO GRAVITY IN M/S/S (9.81 M/S/S) **EXAMPLE:** FOR L = 5, T = 2\*PI\*SQRT(5/G) = 4.4375 A PLE DEVICE WITH 5 INPUTS CAN BE USED TO CALCULATE THE PERIOD OF OSCILLATION FOR AMPLITUDES UP TO L = 32 METERS. PLE DEVICE WITH MORE INPUTS SHOULD BE USED TO CALCULATE LARGER PERIODS OF OSCILLATION. THIS EXAMPLE DEMONSTRATES HOW EASY IT IS TO CONSTRUCT LOOK-UP TABLES FOR COMPLEX ARITHMETIC FUNCTIONS USING PLE DEVICES PLE12P8 P5017 PLE CIRCUIT DESIGN SPECIFICATION FRANK LEE 10/14/83 ARITHMETIC LOGIC UNIT MMI SANTA CLARA, CALIFORNIA .ADD A3 A2 A1 A0 B3 B2 B1 B0 CIN I2 I1 I0 .DAT C3 C2 C1 C0 Z V C THIS DESIGN IS NOT YET SUPPORTED BY PLEASM \* = /C3\*/C2\*/C1\*/C0 ;A + B + CIN ; B - A - 1 + CIN : A - B - 1 + CIN ; A XOR B ; A + B ; A \* B ; PRESET ;OVERFLOW : ZERO #### **DESCRIPTION** THIS ALU CAN PERFORM 8 FUNCTIONS ON TWO 4-BIT OPERANDS A (A3-A0) AND B (B3-B0) WITH CARRYIN (CIN) AND GIVES A 4-BIT RESULT C (C3-C0) WITH CARRYOUT (C). IT WILL ALSO GIVE STATUS AS OVERFLOW (V) AND ZERO (Z). THE FUNCTION IS DETERMINED BY A 3-BIT FUNCTION SELECT CODE (S2-S0): #### **ARITHMETIC LOGIC UNIT** | MODE | 52 | SI | SU | FUNCTION | |------|----|----|----|-----------------| | 0 | 0 | 0 | 0 | CLEAR | | 1 | 0 | 0 | 1 | B - A - 1 + CIN | | 2 | 0 | 1 | 0 | A - B - 1 + CIN | | 3 | 0 | 1 | 1 | A + B + CIN | | 4 | 1 | 0 | 0 | A XOR B | | 5 | 1 | 0 | 1 | A + B | | 6 | 1 | 1 | 0 | A * B | | 7 | 1 | 1 | 1 | PRESET | | | | | | | # **Wallace Tree Compression** ## **Wallace Tree Compression** In performing arithmetic calculations, it may happen that more than two numbers are to be added together. Adding two numbers can be achieved by using a simple adder. If there are more than two numbers to be summed, several levels of adders may be needed. This often causes too much delay. An alternative is to use Wallace Tree Compression. Suppose there are m numbers each of n-bits wide. Summation over these numbers will range from 0 to m x $(2^n-1)$ which will take $\log_2[m(2^n-1)+1]$ bits (rounded UP to the nearest integer). For example, if there are five 2-bit numbers, i.e., m=5, and n=2, the sum will be bounded by 5 x $(2^2-1)=15$ which will need a total of 4 bits. One Wallace Tree Compression by itself will not be very useful. But consider if five 8-bit integers are added together. This technique enables vertical compression of these numbers in four groups. This type of vertical compression also eliminates the need of carry propagation. The five numbers are represented by: A = (a7, a6, a5, a4, a3, a2, a1, a0) B = (b7, b6, b5, b4, b3, b2, b1, b0) C = (c7, c6, c5, c4, c3, c2, c1, c0) D = (d7, d6, d5, d4, d3, d2, d1, d0) E = (e7, e6, e5, e4, e3, e2, e1, e0) where the 7th bits are the most significant; the calculation is as follows: The groups are assigned as follows: G1:(a0, a1, b0, b1,c0, c1, d0, d1, e0, e1) G2:(a2, a3, b2, b3, c2, c3, d2, d3, e2, e3) G3:(a4, a5, b4, b5, c4, c5, d4, d5, e4, e5) G4:(a6, a7, b6, b7, c6, c7, d6, d7, e6, e7) The above groups of bits can be compressed to: H1:(h13, h12, h11, h10) H2:(h23, h22, h21, h20) H3:(h3<sub>3</sub>, h3<sub>2</sub>, h3<sub>1</sub>, h3<sub>0</sub>) H4:(h43, h42, h41, h40) | | | G4 | G3 | G2 | G1 | | |-----|---------------------------------|---------------------------------|---------------------------------|---------------------------------|-----------------------------------|-------------------| | | | a7 a6 | a5 a4 | a3 a2 | a1 a0 | | | | | b7 b6 | b5 b4 | b3 b2 | b1 b0 | = B | | | | c7 c6 | c5 c4 | c3 c2 | c1 c0 | . <b>≐</b> C: "** | | | | d7 d6 | d5 d4 | d3 d2 | d1 d0 | = D | | | <b>•</b> | e7 e6 | e5 e4 | e3 e2 | e1 e0 | = E | | | Literative to a con- | an galakan an dama | | h1 <sub>3</sub> h1 <sub>2</sub> | h1 <sub>1</sub> h1 <sub>0</sub> | = H1 | | | | | h2 <sub>3</sub> h2 <sub>2</sub> | h2 <sub>1</sub> h2 <sub>0</sub> | | = H2 | | | | h3 <sub>3</sub> h3 <sub>2</sub> | h3 <sub>1</sub> h3 <sub>0</sub> | | | = H3 | | +) | h4 <sub>3</sub> h4 <sub>2</sub> | h4 <sub>1</sub> h4 <sub>0</sub> | | | | = H4 | | | | h3 <sub>3</sub> h3 <sub>2</sub> | h3 <sub>1</sub> h3 <sub>0</sub> | h1 <sub>3</sub> h1 <sub>2</sub> | h1 <sub>1</sub> , h1 <sub>0</sub> | | | +) | h4 <sub>3</sub> h4 <sub>2</sub> | h4 <sub>1</sub> h4 <sub>0</sub> | h2 <sub>3</sub> h2 <sub>2</sub> | h2 <sub>1</sub> h2 <sub>0</sub> | | | | S10 | S9 S8 | S7 S6 | S5 S4 | S3 S2 | S1 S0 | = result | S1 and S0 are just h1<sub>1</sub> and h1<sub>0</sub>. S10-S2 can be obtained through addition of other bits. The hardware implementation is as follows: G1 10 PLE10P4 4 G2 10 PLE10P4 4 G3 10 PLE10P4 4 G4 10 PLE10P4 4 74\$381 74\$381 ALU 74\$182 GENERATOR 855-82 81-80 BOOGNOM It needs four PLE10P4 devices, two 74S381 ALUs and one 74S182. An alternative is using ten 74S381 ALUs and four 74S182 Carry Lookahead Generators. A comparison between the two architectures gives the following data: | | USING WALLACE<br>TREE COMPRESSION | USING CONVENTIONAL ARITHMETIC LOGIC | |--------------------------------|-----------------------------------|-------------------------------------| | Delay (ns) | 79 | 115 | | Number of components | 7 | 14 | | Total number pins on the parts | 128 | 264 | Since Wallace tree compression can be of any configuration, there is no predefined part available. A PLE device provides an excellent solution. The designer may define his own configuration as long as it can be put in a commercially available PLE device. 10 PLE8P4 P5019 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 04/06/83 SEVEN 1-BIT INTEGER ROW PARTIAL PRODUCTS ADDER MMI SANTA CLARA, CALIFORNIA .ADD A B C D E F G .DAT PO P1 P2 P2,P1,P0 = A + B + C + D + E + F + G ; P = A+B+C+D+E+F+G FUNCTION TABLE ABCDEFGP2 P1 P0 | ; | | 1 | | | | | PPP | C | DMI | ME | NT | 3 | | | | | | | | | | | | |-----|---|-------|-------|---|---|---|-----|------|-----|----|----|---|---|---|---|---|---|---|---|---|---|---|----| | ; A | В | C | D | E | F | G | 210 | A | + | В | + | С | + | D | + | E | + | F | + | G | = | P | | | L | L | <br>L | <br>L | L | L | | LLL | <br> | + | 0 | + | 0 | + | 0 | + | 0 | + | 0 | + | 0 | _ | 0 | | | L | H | L | H | L | Ħ | L | LHH | | | 1 | | | | | | | | | | | | | | | H | L | H | L | H | L | H | HLL | 1 | + | 0 | + | 1 | + | 0 | + | 1 | + | 0 | + | 1 | = | 4 | | | H | H | H | H | H | H | H | ннн | 1 | + | 1 | + | 1 | + | 1 | + | 1 | + | 1 | + | 1 | = | 7 | Ž. | #### **DESCRIPTION** THIS PLESP4 PERFORMS PARTIAL PRODUCTS REDUCTION FOR WALLACE TREE COMPRESSION. SEVEN ROWS OF 1-BIT NUMBERS (A, B, C, D, E, F, AND G) ARE NUMERICALLY SUMMED TO PRODUCE A 3-BIT RESULT (P2-P0). TB01580M PLE10P4 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 08/22/83 P5020 FIVE 2-BIT INTEGER ROW PARTIAL PRODUCTS ADDER MMI SANTA CLARA, CALIFORNIA - .ADD AO A1 BO B1 CO C1 DO D1 EO E1 - .DAT PO P1 P2 P3 P3, P2, P1, P0 = A1, A0 .+. B1, B0 .+. C1, C0 .+. D1, D0 .+. E1, E0 ; P = A+B+C+D+E FUNCTION TABLE Al A0 Bl B0 Cl C0 Dl D0 El E0 P3 P2 Pl P0 | ; | AA | BB | CC | DD | EE | PPPP | С | MC | ME | NT: | S | | | | | | | | |-----|----|----|----|----|----|------|-------|----|----|-----|---|---|---|---|---|---|----|---| | ; | 10 | 10 | 10 | 10 | 10 | 3210 | A | + | В | + | c | + | D | + | E | = | P | | | - | LL | LL | LL | LL | LL | LLLL | <br>0 | + | 0 | + | 0 | + | 0 | + | 0 | = | 0 | - | | | LH | LH | LH | LH | LH | LHLH | 1 | + | 1 | + | 1 | + | 1 | + | 1 | = | 5 | | | . i | HL | HL | HL | HL | HL | HLHL | 2 | + | 2 | + | 2 | + | 2 | + | 2 | = | 10 | | | | нн | HH | нн | нн | HH | нннн | 3 | + | 3 | + | 3 | + | 3 | + | 3 | = | 15 | | ## **DESCRIPTION** THIS PLE10P4 PERFORMS PARTIAL PRODUCTS REDUCTION FOR WALLACE TREE COMPRESSION. FIVE ROWS OF 2-BIT NUMBERS (A1-A0, B1-B0, C1-C0, D1-D0, AND E1-E0) ARE NUMERICALLY SUMMED TO PRODUCE A 4-BIT RESULT (P3-P0). P3 P2 P1 P0 # FIVE 2-BIT INTEGER ROW PARTIAL PRODUCTS ADDER TB01590M 10 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 02/10/83 FOUR 3-BIT INTEGER ROW PARTIAL PRODUCTS ADDER MMI SANTA CLARA, CALIFORNIA - .ADD A0 A1 A2 B0 B1 B2 C0 C1 C2 D0 D1 D2 - .DAT PO P1 P2 P3 P4 P4, P3, P2, P1, P0 = A2, A1, A0 .+. B2, B1, B0 .+. C2, C1, C0 .+. D2, D1, D0 ; P = A+B+C+D #### FUNCTION TABLE A2 A1 A0 B2 B1 B0 C2 C1 C0 D2 D1 D0 P4 P3 P2 P1 P0 | ; AAA | BBB | CCC | DDD | PPPPP | C | MC | ME | NT: | 5 | | | | | |-------|-----|-----|-----|-------|---|----|----|-----|---|---|---|---|----| | ;210 | 210 | 210 | 210 | 43210 | A | + | В | + | С | + | D | = | P | | LLL | LLL | LLL | LLL | LLLLL | 0 | + | 0 | + | 0 | + | 0 | = | 0 | | LLH | LLH | LLH | LLH | LLHLL | 1 | + | 1 | + | 1 | + | 1 | = | 4 | | LHL | LHL | LHL | LHL | LHLLL | 2 | + | 2 | + | 2 | + | 2 | = | 8 | | LHH | LHH | LHH | LHH | LHHLL | 3 | + | 3 | + | 3 | + | 3 | 1 | 12 | | HLL | HLL | HLL | HLL | HLLLL | 4 | + | 4 | + | 4 | + | 4 | = | 16 | | HHH | ннн | ннн | ннн | HHHLL | 7 | + | 7 | + | 7 | + | 7 | = | 28 | # DESCRIPTION THIS PLE12P8 PERFORMS PARTIAL PRODUCTS REDUCTION FOR WALLACE TREE COMPRESSION. FOUR ROWS OF 3-BIT NUMBERS (A2-A0, B2-B0, C2-C0, AND D2-D0) ARE NUMERICALLY SUMMED TO PRODUCE A 5-BIT RESULT (P4-P0). # **FOUR 3-BIT INTEGER ROW** PARTIAL PRODUCTS ADDER PLE12P8 P5022 PLE CIRCUIT DESIGN SPECIFICATION VINCENT COLI 08/10/83 THREE 4-BIT INTEGER ROW PARTIAL PRODUCTS ADDER MMI SANTA CLARA, CALIFORNIA .ADD A0 A1 A2 A3 B0 B1 B2 B3 C0 C1 C2 C3 .DAT PO P1 P2 P3 P4 P5 P5, P4, P3, P2, P1, P0 = A3, A2, A1, A0 .+. B3, B2, B1, B0 .+. C3, C2, C1, C0 ; P = A+B+C #### FUNCTION TABLE A3 A2 A1 A0 B3 B2 B1 B0 C3 C2 C1 C0 P5 P4 P3 P2 P1 P0 | ; AAAA | BBBB | CCCC | PPPPPP | CC | MMENT | 'S | | | |--------|------|------|--------|----|-------|----|----|------| | ;3210 | 3210 | 3210 | 543210 | A | + E | + | C | = P. | | LLLL | LLLL | LLLL | LLLLLL | 0 | + 0 | + | 0 | = 0 | | LLLH | LLLH | LLLH | LLLLHH | 1 | + 1 | + | 1 | = 3 | | LLHL | LLHL | LLHL | LLLHHL | 2 | + 2 | + | 2 | = 6 | | LHLL | LHLL | LHLL | LLHHLL | 4 | + 4 | + | 4 | = 12 | | HLLL | HLLL | HLLL | LHHLLL | 8 | + 8 | + | 8 | = 24 | | нинн | нннн | нннн | нгнигн | 15 | + 15 | + | 15 | = 45 | #### DESCRIPTION THIS PLE12P8 PERFORMS PARTIAL PRODUCTS REDUCTION FOR WALLACE TREE COMPRESSION. THREE ROWS OF 4-BIT NUMBERS (A3-A0, B3-B0, AND C3-C0) ARE NUMERICALLY SUMMED TO PRODUCE A 6-BIT RESULT (P5-P0). # THREE 4-BIT INTEGER ROW PARTIAL PRODUCTS ADDER # Residue Arithmetic using PLE Devices Conventional binary arithmetic can be replaced by another kind of computational methodology known as the Residue Number System. The use of this system allows integer arithmetic to be performed by arrays of PLE devices. The idea of PLE devices as arithmetic elements is simply to store precomputed values of the arithmetic operation in the PLE memory cells and to use the input variables to the arithmetic as addresses to the PLE devices. Since we are computing the results of the arithmetic operations, the same PLE device organization may be used for many different functions. As an example, a 256x8-bit PLE device can be used as a 4 x 4-bit binary multiplied by any 3-bit constant. It is this flexibility which holds so much appeal for the use of PLE devices as computational elements. #### Introduction Arithmetic operations often involve carry propagation. This propagation causes too much delay for high-speed arithmetic. The Residue Number System (RNS) provides the required separation property needed for high-speed arithmetic. Each digit of the RNS representation is coded into a certain number of bits. In performing the basic operations of addition, subtraction, and multiplication, no information is required to be passed between the digits. Therefore, the number of bits required for representing each digit can be partitioned so that commercially available PLE devices can be used to implement the arithmetic. # **Basics of the Residue Number System** In this section, the elements of performing arithmetic using the RNS are introduced. The mechanism of coding numbers, the method of performing arithmetic using the RNS, and finally conversion between binary and RNS are presented. ## **Coding of Residue Numbers** In principle, the coding of Residue Numbers is extremely simple. A residue digit is the remainder when the number to be coded is divided by another number (a modulus). As an example, the residue of 15 divided by a modulus 7 which yields 1 as the remainder can be represented by $|15|_7 = 1$ . If operations are performed on an RNS where only one modulus is used, it will not be advantageous against a simple binary scheme at all since no information is encoded. Only the encoding of the binary numbers will provide the separation property which will speed up the arithmetic operation. The advantage of the RNS accrues when more digits are used. Another example of encoding a number using 3 moduli to give a 3-digit RNS representation is as follows: let the moduli be m1 = 3, m2 = 4, m3 = 5. The residues of X = 25 will be shown as xi where i = 1, 2, 3. Thus, $X1 = |25|_{m1} = |25|_3 = 1$ $X2 = |25|_{m2} = |25|_4 = 1$ $X3 = |25|_{m3} = |25|_{5} = 0$ In the RNS using the moduli 3, 4, 5, the number 25 is represented as (1, 1, 0). The number of unique representations for a set of moduli is the Least Common Multiple (LCM) of the moduli. The most efficient set of moduli is one in which all moduli are pairwise relatively prime. Tables 1 illustrates an example of a set of moduli (3, 4) which can represent 12 integers. Note that the representations of 0 and 12 are the same, since the representation repeats itself after 12 integers. | X | (3)<br>x1 | (4)<br>x2 | |----|-----------|-----------| | 0 | 0 | 0 : | | 1 | 1 3 | 1 | | 2 | 2 | 2 | | 3 | 0 | 3 | | 4 | 1 | 0 | | 5 | 2 | 1 | | 6 | 0 | 2 | | 7 | 1 | 3 | | 8 | 2 | 0 | | 9 | 0 | 1 | | 10 | 1 | 2 | | 11 | 2 | 3 | | 12 | 0 | 0 | Table 1. Representation of 0 to 12 in RNS Using Moduli 3 and 4. The Representation Repeats Itself After 12 Integers In table 2, (4, 6) is the set of moduli uses. Since 4 and 6 are not relatively prime, the number of integers that can be represented is not the product of 4 and 6, but instead is the LCM of 4 and 6 which is 12. The representation again repeats itself once every 12 integers. | × | (3)<br>x1 | (4)<br>x2 | u velicike (1885).<br>Protesta je sa d | |---------|-----------|-----------------|-------------------------------------------------| | 0 | 0 | 0 | | | sp. 15. | A. 1 65 | 1 | | | 2 | 2 | 2 | | | .3 | 3 | 3 | | | 4 | 0 | 4 | | | 5. | 1.5 | 5 | president to the | | 6 | 2 | 0 | | | 7 | 3 | 1 | | | 8 | 0 | 2 | | | 9 | 1 | 3 | | | 10 | 2 | 4 | | | 11 | 3 | 5 | | | 12 | 0 75 | | wasta sa | | 13 | 1 | 1 | | | 14 | 2 | 2 | | | 15, | 3 | 3 | ameno as do o | | 1.6/⊝ | 0 | (r <b>- 4</b> ) | 7 27 | | 17 | | 5 | | | . 18 | 2 € | . 0 | de la serie | | 19 | 3 | 1 | The selective transfer<br>as appropriate to the | | 20 | 0 | 2 | 101 233 | | 21 | 1 | 3 | | | 22 | 2 | 4 | | | 23 | . 3 | 5 | | | 24 | 0 | 0 | | Table 2. Representation of 0x24 for Moduli 4 and 6. Since 4 and 6 are Not Relatively Prime, and their LCM is Only 12, the Representation Again Repeats Itself Every 12 Integers Negative numbers are formed in the same way negative numbers are formed in binary (two's complement) system. To form the two's complement of a number in binary, we subtract the number 2B where B is the number of bits of the representation. In RNS, we subtract the RNS number from mi to form the negative. Table 1 can be rewritten as in table 3 for encoding of negative numbers. ige of the architecture and in all the gregorii Francesco II gelag (1917) in di neggest (1917) kap di interestablik. Tana Buran Suran Santa (1917) in di neggest (1917) in di neggest (1917) in di neggest (1917). that in the States in the control of the large and the resonant topic real of the rance as in the same with the safe to a รางเราสิงให้สู่ในที่ เอารักได้ เราจากกระทำสุดให้เกิดเกิดที่สู่เกาะโดยเพื่อเกิดเดือนที่สื่อนที่สู่สำคัญ | x | (3)<br>x1 | (4)<br>x2 | |---|-----------|-----------| | 0 | 0 | 0 | | 1 | 1 | 1 | | 2 | 2 | 2 | | 3 | 0 | 3 | | 4 | 1 | 0 | | 5 | 2 | 1 | | 6 | 0 | 2 | | 5 | 1 | 3 | | 4 | 2 | 0 | | 3 | 0 | 4 | | 2 | 1 | 2 | | 1 | 2 | 3 | Table 3. Representation of -6 to 5 in RNS using Moduli 3 and 4 # Arithmetic Using the RNS For two RNS numbers, X and Y, the result of the addition of the two numbers, Z, in RNS is given by: $|xi + yi|_{mi} = zi$ for all of the RNS digits. The same result is found of subtraction and multiplication. This means that arithmetic can be carried out between the same digits of the two numbers, X and Y, without interaction between adjacent digits. The arithmetic is therefore "carryfree". As an example, let us consider the following computation: $$Z = (863 \times 3942) + (-862 \times 3942) = 3942$$ We only need sufficient dynamic range to represent the result; intermediate overflows can be ignored. Let us choose the following moduli for the RNS representation: $$m1 = 7$$ , $m2 = 9$ , $m3 = 11$ , $m4 = 13$ M = 9009 The above set can represent numbers in the range -4505 to 4504, and so this number range is sufficient for the calculation of this example. The computation is shown in table 4. | X | (7)<br>x1 | (9)<br>x2 | (11)<br>x3 | (13)<br>x4 | | |-------------|-----------|-----------|------------|------------|--------| | 3942 | 1 | 0 | 4 | 3 | | | 863 | 2 | 8 | 5, | 5 | - 14x | | 862 | . 1 | 7 | 4 | 4 | | | -862 | 6 | 2 | 7 | 9 | | | 863 x 3942 | 2 | 0 " | 9 | 2 | | | -862 x 3942 | 6 | 0 | 6 | 1 | | | Z | 1 | 0 | 4 | 3 | = 3942 | Table 4. Calculating $Z = 863 \times 3942 + (-862 \times 3942) = 3942$ # Division and Scaling Division of residue numbers is more complicated than addition, subtraction, or multiplication. If the dividend is exactly divisible by the divisor, the operation is easier. In this case, a division by a number is the same as a multiplication by the inverse of that number. The multiplication inverse of an integer X in modulo arithmetic can be found by finding the vector (d1,...,dn) which satisfies the following: $$|X.d|_{mi} = 1$$ For example, 95 divided by 5 in moduli 2, 7 and 9 can be done by first finding the vectors representing 95 and the inverse of $|95|_2 = 1$ $|95|_7 = 4$ $|95|_9 = 5$ So, for the multiplicative inverse of 5, we have: $|1/5|_2 = 1$ $|5 \times 1|_2 = 1$ $|1/5|_7 = 3$ since $|5 \times 3|_7 = 1$ $|1/5|_9 = 2$ 5 x 2 0 = 1 Therefore. this paper. $|95/5|_2 = |95|_2 |_2 \times |1/5|_2 |_2 = |1 \times 1|_2 = 1$ $|95/5|_7 = ||95|_7 \times |1/5|_7 |_7 = |4 \times 3|_7 = 5$ $|95/5|_9 = |95|_9 \times |1/5|_9 |_9 = |5 \times 2|_9 = 1$ and the answer is 19. The operation becomes more complicated when the dividend is not exactly divisible by the divisor or one of the moduli of the miltiplicative inverse does not exist, say, if the residue of the divisor for that modulus is 0. In this case, we need to obtain the remainder and then subtract the remainder from the dividend and then perform the division. The problem in finding the remainder seems to be the same as performing the division itself. However, this type of division can be done in a process called scaling, which will not be discussed in detail in In spite of the improvements made in implementing scaling algorithms, scaling still represents a major effort in any calculation. It is advisable to use RNS only on systems where many arithmetic operations can be performed for each scaling operation. # A System Using an RNS An RNS is very useful in systems which have predefined operations and dynamic ranges. Moreover, it can only operate on integers, or at most, block floating-point numbers. Since the RNS involves conversions between integers and their RNS representations, and conversions by themselves are already time-consuming, the problem to be solved in the RNS system should be operation intensive. Figure 1. Architecture of an RNS # Conversion to RNS Representation The conversion of an integer to RNS can be viewed as a mapping process. PLE devices provide a natural implementation for mapping. For example, if an 8-bit integer is used to represent numbers ranging from 0 to 255, and the following moduli are arbitrarily chosen for conversion to RNS - 2, 11 and 15 (which can represent 330 integers), 8 bits of address are needed for the integer input and 9 outputs (1 for modulus 2, 4 for modulus 11 and 4 for modulus 15). In reality, only 8 outputs are needed because that bit of residue for modulus 2 is not required, since the least significant bit of the integer is also the residue of itself in modulus. In fact, a PLE8P8 will be sufficient. Figure 2. Mapping an 8-Bit Integer, X, to Its Residues on Moduli 2, 11 and 15 Another example is a 14-bit integer which is to be converted to RNS. A 14-bit address needs 16K address spaces for the mapping. 16K is too deep for a PLE device. An alternative is to use 4K-deep PLE devices. PLE12P4 and PLE12P8 devices and a selector (e.g., a PLE5P8 to control the PLE devices (See Figure 3)). The PLE5P8 device will decode two of the address bits and will selectively enable one of the four sets of PLE devices as the mapping set, thus deepening the effective address to 16K. Figure 3. Mapping a 14-Bit Integer, X, to Its Residues by Selectively Enabling the Outputs of One of the Four Sets of 12-Input PLE Devices This method of expansion is not effective with bigger integers. If the integer is N-bit and the PLE address space available is M-bit, then 2N-M sets of PLE devices will be needed. Besides, as the dynamic range increases, the width of the outputs will also increase about proportionally. An alternative method is to use two or more levels of PLE devices to generate the residues. The first level generates the remainders from the more significant bits of the integer and the products of some of the moduli. These remainders are in turns concatenated with the rest of the bits to become the inputs to the second level PLE devices. For example, for a 16-bit integer 43689, and let us use (2, 11, 13, 15, 23) as the set of moduli. We may choose 23, 30 and 143 as the moduli for the first level. The first level consists of PLE12P4s and PLE12P8s which generate the remainders of the most significant 12 bits of 43689 which is 2730. We know that |2730|23 will be at most 22 and can therefore be represented by a 5-bit number; |2730|15 will be at most 14 and can be represented by another 4-bit number; and 2730 143 will be at most 142 and can be represented by a 6-bit number. The 5bit number represented by |2730|23 will be concatenated with the least significant 4 bits of the integer and gives a 9-bit number which can perform another division by 23 to give the final |43689|23; the 4-bit number represented by |2730|15 will be concatenated with the least significant 4 bits of the integer and gives an 8-bit number which can perform another division by 15 to give the final |43689|15; the 6-bit number represented by |2730|143 will be concatenated with the least significant 4 bits of the integer and gives a 10-bit number which can perform another division by 11 and 13 to give the final |43689|11 and |43689|13. As in the first example, |43689| 2 is just the least significant bit of the integer. Figure 4. Mapping a 16-Bit Integer X to Residues in Modulo 2, 11, 13, 15, and 23 Using Two-Level Mapping. The First Level Gives Remainders from the More Significant Twelve Bits, While the Second Level Finds the Final Residues In some circumstances, although an N-bit integer only has a dynamic range of $2^N$ , the intermediate calculations may over- flow. It is sometimes necessary to add some other moduli to boost up the dynamic range for the intermediate calculations. ## **Arithmetic Operations In RNS** The arithmetic operations of the RNS is different from regular arithmetic in that even simple addition must be performed in modulo arithmetic. Simple ALU may not be able to handle this arithmetic. Again, PLE devices are proven to be most useful. A PLE8P4 device can perform addition, subtraction, or multiplication on two 4-bit residue numbers and give a 4-bit modulo result. Figure 5. Calculating C = A + B, A - B, B - A x B Using PLE8P4 If the modulus is large, say greater than 64, the combined number of bits for two residues will be greater than the number of address bits for the largest of the commercially available PLE device. Of course, more than one device can be used to deepen the effective address space. In this case, for every additional bit of a modulus, two more bits of address will be needed — one for each operand. In other words, for each additional bit of a modulus the address space of operation will be quadrupled. It is not very effective when the modulus grows too large. Fortunately, for both addition and multiplication, there are more efficient procedures. ## **Large Modulus Addition** Table 5 shows the contents required for the addition operations in modulus 11. There is a lot of redundancy in the table which can be compressed by reducing what should be eight bits of inputs to five bits. What we need is just another level of mapping. There are a total of 121 combinations for a number of modulus 11 operating on another operand of the same modulus. In reality, only numbers ranging from 0 to 10 can be represented in modulus 11. The sum ranges from 0 to 20 (not in modulus 11). This range can be represented by a new set of submoduli (3, 7) which is five bits wide. In fact, any new set of submoduli which has a dynamic range of at least twenty-one can be used. The operands in modulus 11 will be converted to their representations in submoduli 3 and 7. The addition is done in the submoduli and the result is reconverted back to modulus 11 RNS (see Table 6). 10 | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | |-------|----|----|----|----|----|----|----|----|----|-----|----|----| | | 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | | | 1 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | | | 2 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | 1 | | | 3 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | 1 | 2 | | | 4 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | - 1 | 2 | 3 | | 11 /4 | 5 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | | | 6 | 6 | 7 | 8 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | | | 7 | 7 | 8 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | | | 8 | 8 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | | 9 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | | | 10 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Table 5. Addition Table in Modulo 11 Arithmetic | | | - 22-22 | | | 2 | 23 c | | | FO 3 1 | | | | | | | | | | | | | |----------|---|---------|---|---|---|------|---|---|--------|---|----|----|----|----|----|----|----|----|----|----|----| | x + y | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | | x + y 11 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | | x + y 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | | x + y 3 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 | Table 6. Conversion Table Between Modulo 11 Arithmetic and Modulo 3 and 7 Arithmetic Figure 6. Calculating Addition of Two Numbers in Modulo 11 Using Submoduli Operations # **Large Modulus Multiplication** The solution to this problem in multiplication is similar. For example, if two RNS digits in modulus 91 is to be multiplied, (7, 13) may be chosen as a set of submoduli. The representation of an RNS digit in modulus 91 needs 7-bits. These 7-bits are first mapped to two RNS digits — in modulo 7 which needs 3-bits; and in modulo 13 which needs 4-bits. The representations of the two operands in the two moduli can then be multiplied and give the result in modulo 7 and modulo 13. The result is then converted back to modulo 91. Unfortunately, this scheme can be used only when the modulus can be expressed as a product to two integers which are relatively prime. But, in this case, the RNS digit may simply be repre- sented as the residue of the two smaller integers instead of using them as submoduli. Figure 7. Calculating Multiplication of Two Numbers in Modulo 91 Using Submoduli Operations Suppose another modulus 101 is used. 101 is a prime number and RNS in modulus 101 ranges from 0 to 100. The real dynamic range of the product of two numbers in modulus 101 is 0 to 10000, which is already too large for a PLE address space. For this modulus, we may use three 4K-deep PLE devices to deepen the address space. For a modulus like 1001, it may not be too efficient to use this scheme. Instead. since: $$xy = [(x + y)^2 - (x - y)^2]/4$$ or = [x + y)^2]/4 - [(x - y)^2]/4. we may do x + y and x - y first and then do the squaring of the sum and the difference scaled by a factor of 4. Since the final product of two integers must be an integer, the squaring and scaling may be performed in one operation with the fractional part discarded. The way to obtain x + y and x - y is the same as what was discussed earlier in the "Large Modulo Addition" session. In any event, operations on residues of large moduli are slower and involve more hardware and are not recommended. Figure 8. Performing Modulo 1001 Multiplication ## The Reverse Conversion The reverse mapping from RNS to integer is not as straightforward as the other way. For an RNS system which has a total of twelve bits for all the residues, we can still use 12-input PLE devices to convert. We may also use several sets of 12-input PLE devices to reverse map the RNS if the integer is not much longer. But for very long integers, we may need to use the general algorithm for the reverse map: - 1. Find $M = m1 \times m2 \times ... \times m_{n-1}$ (where n is the number of moduli) - 2. Find ti = M/mi 3. Find X = |x1t1 + x2t2 + ... + xn - 1tn - 1|M In hardware implementation, ti's are all known beforehand. We can map xi's to get the xiti's. Then we may perform Wallace Tree Compression (see the session on this subject in this handbook for more information) on the xiti's to give two-level operands which add to the final sum and divide it by M to get X. Again, PLE devices provide the best solution for Wallace Tree Compression. Figure 9a. Reverse Mapping to Get Xiti Figure 9b. Modulo M Wallace Tree Compression to Reduce the Number of Levels for Summation to 2 Followed by an Addition and Division to get $X=|x_1t_1+...+x_nt_n|$ M #### Conclusion Memory elements provide excellent solutions to mapping functions — for control purposes, for arithmetic operations and general logic replacements. This paper investigates the possibility of using PLE devices as arithmetic units. In fact, for logic like residue number arithmetic, there is no better solution than to use these devices. ## Acknowledgement Portions of this article were extracted from "Integer Arithmetic Using PROMs" by Dr. G.A. Jullien of the University of Windsor, Canada. **10** # Distributed Arithmetic Using PLE Devices In digital signal processing, sum-of-product type of operations are often necessary. These operations take the form of: $$y = \sum_{i=0}^{M} a_i x_i$$ where $a_i$ 's are some constants If real multiplications are to be performed on every product term, it will need a total of M multiplications and M-1 additions. Multiplication operations normally take much longer than simple addition. An alternative to calculate equations of the above form is by using distributed arithmetic. Suppose there is an N-bit integer X given by: $$x = [x(N - 1), x(N-2),...,x(1),x(0)]$$ or equivalently: $$x = \begin{bmatrix} N - 1 \\ Z \\ i = 0 \end{bmatrix} x(i) 2^{i}$$ where x(N - 1) is the most significant bit. The equation: $$y = \sum_{i=0}^{M} a_i x$$ can be expressed as: $$y = \sum_{\substack{i=1\\N-1}}^{M} a_{ij} \begin{pmatrix} N-1\\ \Sigma & x_{ij} \end{pmatrix} \begin{pmatrix} 1\\ \Sigma & x_{ij} \end{pmatrix} \begin{pmatrix} 1\\ \Sigma & x_{ij} \end{pmatrix}$$ $$= \sum_{j=0}^{N} 2^{j} \begin{pmatrix} M\\ \Sigma & a_{ij} \end{pmatrix} \begin{pmatrix} 1\\ \Sigma & a_{ij} \end{pmatrix}$$ Now, let: $$H(j) = \sum_{i=1}^{M} a_i x_i(j)$$ Since H (j) is independent of i and since $a_1$ 's are all constants, we precompute for every $x(j) = [x_1(j), x_2(j), ..., x_M(j)]$ the values $[x_1(j), x_2(j), ..., x_M(j)]$ the values of H (j). Then x(j) can be used as the address of PLE devices whose outputs are the precomputed result H(j). Figure 1. Mapping the j<sup>th</sup> Bit from Each of the x<sub>i</sub>'s to An L-bit Result If there are M bits of data and the result is L-bit wide, and if M is very large, say 20, and L is 8, then we need 20 bits of address lines if we want to use only PLE mapping. Since 20 bits of address translate to 1M words, and there is no available 1M-deep PLE device on the market, it is not realistic to use PLE mapping. Instead, H (j) can be partitioned as follows: H (j) = $$\sum_{i=1}^{20} a_i x_i$$ (j) for M = 20 = $\sum_{i=1}^{20} a_i x_i$ (j) + $\sum_{i=11}^{20} a_i x_i$ (j) 1 = 1 i = 11 the 20-bit address can be separated to two 10-bit addresses and each of them is individually mapped. The two outputs will then be added together to give H (J). An implementation of this mapping is shown in figure 2. Figure 2. Mapping the j<sup>th</sup> Bit of Each of x<sub>i</sub>'s to an L-bit Result When There Are Too Many x's (20 in This Case) There is another alternative for implementing a sum-of-product operation: by using a multiplier accumulator (MAC). The main constraint on distributed arithmetic is that one set of the multiplicands must be fixed, i.e. ai's in this case, for the sum-of-product mapping while a MAC will allow flexibility. There are normally some constraints on the width for the data bus from which the operands are loaded. If all the operands are new, it will need M cycles to load in the operands anyway, distributed arithmetic offers no advantages over MAC since distributed arithmetic needs to wait for all the operands to be loaded in before any operation can start while MAC can perform a multiplication and an addition every cycle. M cycles will be needed anyway for the complete operation using a MAC while distributed arithmetic may take even longer. On the other hand, for operations like convolutions where one set of operands are fixed and only one new variable operand is needed for every result, distributed arithmetic will be a better solution since it can give a result in every clock-cycle while a MAC will need M-cycles (because recalculations of all the product terms are necessary). An implementation for convolution is shown in Figure 3. Figure 3. An Implementation of a Distributed Arithmetic System for Convolution There is another way to implement distributed arithmetic through bit-serialization: From H (j), the sum-of-product of y can be obtained as: $$y = \sum_{i=0}^{N-1} 2^{i} J(i)$$ To implement this equation, consider that the least significant bit of the result is to be used only for rounding purposes only. Only the more significant bits will be retained. The computation can be performed in the following way: 1) For $$j = 0$$ , $y_0 = 2^0H(0) = H(0)$ 2) For $j = 1$ to $N - 1$ $y_i = H(j) + 1/2H(j - 1)$ Note that the second term of the last equation means that the previous result $(y_{j-1})$ is shifted right one-bit; the last bit of $y_{i-1}$ is truncated. The implementation of such a system is shown in Figure 3. The system consists of a shift register, a mapper (PLE circuits, or PLE circuits with adders), an accumulator, and an ALU. Figure 4. A Bit-Serialization Implementation for a Distributed Arithmetic System The operations are as follows: - 1) Load xi onto the load and shift register at clock 0. - Load H (0) onto accumulator and shift all registers at clock 1. - 3) From clock k (between clock 2 to clock N 1), the content of the accumulator will be replaced by the sum of H (k-1) and the more significant N - 1 bits of the current accumulator value. - 4) For clock N, the following are performed: - a) Repeat step 3. At the end of the operation, the accumulator contains the value of the result (scaled by the number of shifts) - x<sub>j+1</sub> is loaded onto the load and shift register. The shifting frequency is equal to N times the basic rate. Due to the fact that there are a number of shift operations necessary for each data load, this method is recommended for the following conditions: - This design is under cost, power dissipation, and board space constraints. - 2) This design is for high M-to-N-ratio array multiplications. # Registered PLE Devices in Pipelined Arithmetic PLE devices are useful as logic elements, and registered PLEs are excellent media for pipelined arithmetic. Monolithic Memories supplies a number of registered PLE devices which provide effective solutions to pipelined systems. A data processing system may have fall-through architecture. Since many of these operations may take a long time, it happens that the devices are not often tied up in operations. For example, in a system as in figure 1, the operations can be divided into three functional blocks. When the operands are loaded in, block 1 will operate first, followed by block 2 and then by block 3. When the data is in block 2, block 1 is not doing anything. We cannot at this time put in the next set of operands because changes in operands may disturb the operation in block 2. Figure 1. An Example of the Fall-Through Approach to Arithmetic Operation A solution to this is by registering the operands and signal paths when the operations is switched to block 2; and by registering the operands and signal paths again when the operations is carried out in block 3. The result is stated in figure 2. This architecture is called the pipelined structure. It makes the loading of the second set of operands possible even before the first result is out, thus increasing the throughput. Figure 2. Pipelined Arithmetic Operation The introduction of the registers for the pipeline increases the operation time of every block due to the addition of the setup times and the clock to output delays. The result is as follows: 1) Overall delay. The architecture in Figure 2 will need at least an additional 2 setup time and 2 clock to output delays of a register. In real, it will be more, because the minimum clock period will be determined by the sum of (i) the maximum of the operation times of individual blocks, and (ii) the setup time of the pipelined registers and (iii) the clock to output delay of the pipelined registers. Symbolically, the overall delays for the architectures in Figures 1 and 2 are: $$\begin{aligned} t_{pd}(Fig.1) &= t_{pd}(blk \ 1) + t_{pd}(blk \ 2) + t_{pd}(blk \ 3) \\ t_{pd}(Fig.2) &= 2x[max[t_{pd}(blk \ 1), t_{pd}(blk \ 2), t_{pd}(blk \ 3)] \\ &+ t_{obs} + t_{odb} + t_{odb}(bl) \end{aligned}$$ $+ t_{su} + t_{clk\}} + t_{pd}(blk\ 3)$ Where $t_{pd}(Fig.1)$ and $t_{pd}$ (Fig. 2) are the propagation delays of the architectures in figure 1 and figure 2 respectively; $t_{pd}(blk\ 2)$ , $t_{pd}(blk\ 3)$ are the propagation delays of block 1, block 2, and block 3 respectively; and $t_{su}$ and $t_{clk}$ are the setup time and clock-to-output delay of the registers respectively. 2) Throughputs of clock rate. The architecture in figure 1 has a throughput period of $(t_{pd}(blk\ 1) + t_{pd}(blk\ 2) + t_{pd}(blk\ 3) + t_{su} + t_{clk})$ , assuming that the operands are coming from and the result is going to some registers; the architecture in Figure 2 has a throughput period of (max[ $t_{pd}(blk\ 2)$ , $t_{pd}(blk\ 2)$ , $t_{pd}(blk\ 3)$ ] + $t_{su}$ + $t_{clk}$ ) which is faster. PLE devices are useful as logic elements, and registered PLE devices are excellent media for pipelined arithmetic. Monolithic Memories supplies a number of registered PLE devices which provide effective solutions to pipelined systems. Applications for pipeline arithmetic include array and digital signal processing. make above to | | PAL® Device introduction | |----|----------------------------------| | 2 | PAL®/HAL® Device Specifications | | 3 | PAL Device Programmer Ref. Guide | | 4 | HAL/ZHAL™ Devices | | 5 | Logic Cell Array™ | | 6 | PALASM® Software Syntax | | 7 | PAL Device Applications | | 8 | Logic Tutorial | | 9 | PLE™ Devices | | 10 | PLE Circuit Applications | | 11 | Article Reprints | | 12 | General Information | | 13 | Package Drawings | | 47 | Representatives and Distributors | # **General Applications** # **Table of Contents** | Article Reprints | | |--------------------------------------------------------------------|-------| | Table of Contents for Section 11 | 11-2 | | Testing Your PAL Devices | | | PAL20RA10 Design for Testability | 11-8 | | PAL Design Function and Test Vectors | 11-10 | | Metastability | 11-13 | | High-Speed Bipolar PROMs Find New Applications as | | | Programmable Logic Elements | 11-17 | | ABEL <sup>TM</sup> a Complete Design Tool for Programmable Logic | 11-25 | | CUPL <sup>TM</sup> the Universal Compiler for Programmable Logic . | 11-29 | # **Testing Your PAL Devices** ## Manouchehr Vafai #### Introduction The advantage of Programmable Array Logic (PAL®) circuits as a basic building block of digital system is now well established. PAL circuits are a unified group of devices which combine programmable flexibility with high speed and extensive selection of interface options. The architecture of PAL circuits consists of programmable-AND-OR gate arrays, output-registers and I/O feedback as shown in Figure 1. Figure 1. PAL Circuit Architecture The increased system speed, reduced chip count and availability of a CAD tool called PALASM™ software should leave no doubt for design engineers that they have made a right choice in choosing PAL circuits. The HAL circuit family is the masked program version of a PAL circuit. HAL® circuits will provide the users a cost-effective solution for large quantities and is unique in that it is a gate array with a programmable prototype. The following steps are required when designing with PAL circuits. - Familiarity with Demorgan's law. - · Familiarity with the Karnaugh maps. - Ability to express logic equation in Sum-of-Product form. - Ability to write simple seed vector for function table. - · Familiarity with different PAL circuits. # **Programming PAL Circuits** PAL circuits will be programmed using PALASM software. PALASM software is the CAD tool developed by Monolithic Memories to facilitate the process of programming. PALASM software is a Fortran IV program which assembles and simulates PAL circuits design specifications. It generates PAL circuit fuse patterns in formats compatible with PAL circuits or PROM programmers. Besides generating PAL circuit fuse pattern in different pro- gramming formats, PALASM software does the following: - Assembles PAL circuit design specification and reports error messages. - Simulates the Function Table. - Tests each product term for Stuck at zero (SA0) and stuck at one (SA1) faults. The purpose of writing vectors is to prove that a device is capable of performing it's function before it is put in a system. PALASM software will exercise the vectors and will report any discrepancy. Writing vectors will raise confidence that a device will function properly at least in the design level. The simulator also transfers the function table vectors to a set of universal test vectors which may be used for functional testing after the device is programmed. When a new system is transferred to production, the system designer hands over the responsibility for the system to the test engineering department, who now determines how and what test should be performed to ensure proper operation of the system. At this point the system designer transmits the necessary information for understanding the system operation. Unfortunately, much information is lost at this point. Test engineers usually have a hard time understanding how the system works with insufficient information. It is the design engineer who best knows the operation of his PAL circuit design, and it is the design engineer who can quickly specify a few seed vectors to give the test a starting point in solving the future problem. ## **Design for Testability** In short the only way to control a digital circuit is to apply a known value to it's input. Fault simulation has been the best technique of yielding a quantitive measure of test effectiveness. Fault simulation will test stuck-at-0 (SA0) and stuck-at-1 (SA1) of input and output lines. By generating test vectors that will test for each product term for (SA0) and (SA1) faults, then by observing the corresponding output and comparing it with the fault-free output, one can conclude whether a fault can be detected or not. Consider the following example: Figure 2. Logic Diagram and It's PAL Circuit Implementation ABCDEFZ 1110XX1 (vector-1) The (vector-1) selects a product term P1. Under a fault-free condition, the output (2) will be high (we can observe this); however, under a fault condition the output will be low. In other words, one can conclude that either product term (P1) is (SA0) or outputs Z (Figure 2.) are (SA0). Now consider vector 2. A B C D E F G 0 0 0 0 0 0 0 0 (vector-2) As it can be seen that both of the product terms are low, if the observed output is high, one can conclude that either product terms or outputs are Stuck-at-one. Fault simulation grading is used by Monolithic Memories to evaluate candidates design for transfering from a PAL circuit to a HAL circuit. In designing with PAL circuits, four different cases should be considered. - A purely combinational circuit where output is function of input. - A purely combinational circuit where output is function of input and feedback from output. - A purely sequential logic where output is function of input and feedback from output. - A combinational-sequential logic where output is function of input, feedback from combinational output and feedback from sequential output. In cases 1 and 2 we can define a structured way of writing function table. Cases 3 and 4, on the other hand, because of dependency of the device on the previous state of the device, impose a relatively more sophisticated scheme of testing strategy. In the following examples the various techniques which might be helpful in testability of PALs, will be discussed. ## **Example 1: Glitch-free and Testable** Suppose we want to implement (EQ-1) using any of the combinational PAL. $$F = X^*A + \overline{X}^*B$$ (eq-1) The K-MAP and logic diagram are shown in (Figure 3.) Figure 3. Logic Diagram and It's K-Map The above logic is testable because we have full control over each node for (SA0) and (SA1) test. The implementation using PAL circuits is as follows: Figure 4. PAL Circuit Implementation of the Logic Ideally the output should always be high if both inputs are high. The circuit is not glitch-free, the output might momentarily drop to low if we change the state of X, due to propagation delay between X and $\overline{X}$ . The problem will be solved by including a redundant (AB) term to (eq-2). The equation will look like this. $$F = XA + \overline{X}B + AB$$ (eq-2) The output is glitch-free, but untestable! Figure 5. A Glitch-free Circuit Node (2) is not Observable for (SA0). One can not force node (2) to one and keep node (1) and (3) in the low state. So the redundant product term is untestable. This circuit can be made testable by the addition of control signal (Y) as follows: Figure 6. Glitch-free and Testable Logic Now the logic is glitch-free and testable. # Example 2: Untestable Logic — A Simple Example The logic F := F is untestable Figure 7. Implementation of F := F 1 The initial state of the oscillator is unknown; this system can be made testable as follows: Figure 8. Implementation of F := F with SET and RESET It has been done by addition of two control signals (RESET and SET) and one extra product term. # **Illegal States** Upon power-up the initial state of output registers are unknown; this might force the device into one of the "illegal states". The design engineer should be worried about the illegal state at design time. For example let's look at modulo-6 state machine Figure 9. State Transition Diagram for a Modulo-6 Counter The design engineer might ignore the other possible state (6, 7) but his ignorance might be costly at test time. If upon power-up the machine starts at either of (6) or (7) state, there is no way to control the state-machine. The best solution is to force both of the illegal states into one of the known states. Figure 10. A Modulo 5 Counter with No Illegal State # Example 3: Design "pitfall" Case One Consider the implementation of the following example Figure 11. Implementation of Q1 := I1 \* Q1 Using a PAL If Q1 falls to zero, it will stay there forever. The logic needs a control signal for output reset. #### Example 4: Design "Pitfall" Case Two Consider the implementation of the following equation: $\overline{Q0} = \overline{A} \times \overline{Q1} \times Q0 + A \times Q1 \times \overline{Q0} + \overline{Q0}$ Figure 12. Implementation of $\overline{Q0} = \overline{A}^{\dagger}\overline{Q1}^{\dagger}Q0 + A^{\dagger}Q1^{\dagger}\overline{Q0} + \overline{Q0}$ If $\overline{Q0}$ goes to one it will stay there forever, the logic needs a control signal to clear it's output. # Hard Array Logic (HAL) Devices The HAL device is the Hard Array version of a PAL device. HAL logic circuits are the best choice for designs that are firm and volumes are large enough to justify the initial cost. Besides having Boolean equation in PAL DESIGN SPECIFICATION format the user should provide the following. - A FUNCTION TABLE which gives enough information about the operation of the device. Normally this FUNC-TION TABLE shall test a minimum of 50% "Stuck at fault" grading using PALASM or TEGAS fault grading test. - The FUNCTION TABLE shall be constructed such that the device may be initilized to a known state within a specified number of steps (or clocks). The HAL CIRCUIT SPECIFICATION is the input file used with PALASM software for the HAL's. The input format as shown in example 5 is as follow: - Line 1 HAL circuit part number - Line 2 user's part number followed by originator's name and the date - Line 3 device application name - · Line 4 user's company name, city, state - Line 5 pin list which is a sequence of symbolic names separated by one or more spaces. All pins including VCC and GND must be named - Line M the logic equation which are used to generate metal masks from the provided equations PAL®, and HAL® are Registered Trademarks of Monolithic Memories #### **EXAMPLE 5** • Line N the function table which begins with the key word "FUNCTION TABLE." It's followed by a pin list which may be in a different order and polarity from the pin list in line 5. VCC and GND cannot be listed. The pin list is followed by dashed line; e.g.; \_\_ \_ which in turn is followed by a list of vectors, one vector per line. One state must be specified for each pin name and optionally separated by spaces. A vector is a sequence of states listed in the same order as the pin list and followed by an optional comment. The allowable states are H (HIGH LEVEL), L (LOW LEVEL), X (IRRELEVENT), C (TRANSITION FROM HIGH TO LOW OR CLOCK PULSE) and Z (HIGH IMPEDENCE). After preparing the PAL DESIGN SPECIFICATION in the above format, PALASM software can be used to simulate and perform fault testing. PRODUCT: PRODUCT: ``` 9 XXXXXXXXX1X01HXXXXXXX1 PASS SIMULATION PRODUCT: 1 OF EQUATION. ``` 6 UNITESTED (SA1) FAULT 6 UNITESTED (SA1) FAULT 6 UNITESTED (SA1) FAULT 7 P Q P Q P Q NUMBER OF STUCK AT ONE (SAL) FAULTS ARE = 8 2 OF EQUATION. 2 OF ECUATION. NUMBER OF STUCK AT ZERO (SAO) FAULTS ARE = 9 PRODUCT TERM COVERAGE = 85% #### **FAULT-TESTING** The following information is reported to the user - Total number of SA1 Faults. (8 in example 5) - Total number of detected SA0 faults. (9 in example 5) SA1 faults + SA0 faults - 2 \* total number of product terms \* 100 % $$\left(\frac{8+9}{2*10}\right)$$ \*100% = 85% ex-5) - One vector may detect more than one SA0 OR SA1 FAULTS (vector # 11 in example 5) - The user is reported with a message which tells him the product term for which it was not tested. (PRODUCT TERM 1 & 2-EQ 6, in example 5) The following vectors can be added to the function table in example 5 in order to achieve 100% fault coverage. | - | | | run | IJĸĿ | MNO | PQR | | COMMENTS (EXAM | APLE 5 | 5) | <u> </u> | |---|------|----|-----|------|-----|-----|--------|----------------|--------|-----|----------| | | | | | XXXX | | | 8.3563 | | SAO 1 | EST | | | X | CX X | XX | XXX | XXXX | XXX | HHL | | (EQ-6,PT-1,2) | SAl 1 | EST | | PALASM™ software has tested the above function table for example 5, the result is as follows: NUMBER OF STUCK AT ONE (SA1) FAULTS ARE = 10 NUMBER OF STUCK AT ZERO (SA0) FAULTS ARE = 10 PRODUCT TERM COVERAGE =100% PALASM™ is a trademark of Monolithic Memories. 11 # PAL® 20RA10 Design for Testability **Edwin Young** This article is written to help customers of the PAL20RA1 recognize some fundamental design-for-testability issues which may arise due to the part's unique architecture. Customers should understand that these issues represent design criteria which Monolithic Memories will use to accept PAL20RA10 patterns for test generation/fault grading and for estimating the resource cost to test engineering if accepted. This article does not address the BUSINESS REQUIREMENTS such as the need for acceptable test vectors and the acceptability of a particular pattern for processing as a HAL® device. The designer who wishes to use a 20RA10 in his/her design must bear in mind that although the part has preloadability, certain designs could diminish the effectiveness of this feature. The following rules are presented to help establish Test Engineering acceptance standards for the 20RA10. Additional general guidelines applicable are available in the PAL Handbook article reprint "Testing Your PAL Devices" by M. Vafai. # **Avoid False Latching Situations** The equation D = (A\*B) + (C+D) and its variants are susceptible to latching hazards since ATE may have considerable input skew. Of course, from a testing viewpoint, such implementations should be avoided. But if they must be implemented, care must be exercised in developing the function table so as to account for the possibility of latching. The designer must adopt and stick to some guideline such as "no more than one input undergoes a change in logic value per vector" when specifying the function table. Assume A, B and C are primary inputs while D is a fed-back output. The waveforms to the left show two possible outcomes for output D depending on the skew of inputs A and B, which is a function of tester calibration. The latch problem described is not unique to the 20RA10 but is clearly applicable to any PAL with asynchronous outputs with feedback (e.g., 16R4). The designer should realize, however, that false latching may occur on a 20RA10 even if all outputs are registered. Consider the equation set D:= C and D.CLKF = A\*B for a simple registered 20RA10 output. The resulting waveforms would look similar to those of the previous asynchronous example. The important distinction here is that a 20RA10 has programmable asynchronous clocks rather than a single 'master clock' pin which can cause difficulties in testing. # Allow Data to Setup Prior to Clocking The previous two pitfalls were examples of flaky latching due to glitches during testing. Consider the equation set C := B and C.CLKF = A for a registered output. The following example shows a definite positive latching...but of flaky (skewed) data. Assume B is a primary input. Then the timing for situations at far left and left may be with A as feedback and as primary input respectively. This example illustrates another aspect of the programmable asynchronous clock feature of the 20RA20: Clock pulses can have critical minimal or no delay relative to data setup time. Note that all other registered PAL devices have dedicated common clock pins to which delayed pulses are applied by the ATE to allow sufficient data setup time and ATE input skew. #### Avoid Unreachable States The 20RA10 may be preloaded to any state desired for testing purposes. Unfortunately, the desired state may not exist long enough for the simulator or ATE to use it. With all other preloadable PALs, any arbitrary state may be preloaded into the registers on a given test vector and the state will persist into the next vector providing the required conditions to detect some fault/s. This means all stuck-at-type faults possibly detectable can be detected. With the 20RA10, the preloaded state may feed back to assert state dependent resets or presets on one or more PAL® and HAL® are registered trademarks of Monolithic Memories. TWX: 910-338-2376 2175 Mission College Blvd. Santa Clara, CA 95054-1592 Tel: (408) 970-9700 TWX: 910-338-2374 M-R registers. Consequently, the desired state may last only a few nanoseconds after the preload vector is complete before changing to some new state. Since the desired state is not stable going into the vector immediately following the preload vector, the faults expected to be detected become non-detectable. Another problem arises whenever output control logic is a function of state. In this case, assume the desired state for detecting faults is preload and is stable in the next vector. If this state provides the conditions necessary to detect faults and also disables the outputs, then the faults will be effectivley masked from detection. # Caution on Individual Register Bypass Mode The 20RA10 allows the designer to permanently and independently bypass any register. Those registers not permanently bypassed may be bypassed under program control by setting both SET and RESET nodes to logic high. In this 'bypass mode', the register's D node is multiplexed to the output rather than its Q node. There is generally no test problem in going into bypass mode. The pitfall is in returning to 'register mode' operation, which only the 20RA10 can do. Consider the equation set C.RSTF = A and C.SETF = B of a simple registered output and An indeterminate state on the output can occur if both primary inputs A and B go to logic low on the same vector. the following possible waveforms. A race condition will occur to see whether set or reset operation prevails in going from bypass to register mode. There are two methods by which to get known states for testing purposes: - 1) Clock a known value into the register on the next vector or; - Set RESET to logic low on one vector and then SET to low on the next or vice versa. 11 # **PAL® Design Function and Test Vectors** E. Young #### Introduction This article was written to help customers understand the purpose of seed vectors and provide some general guidelines as to what elements are important in developing them. It is assumed that the reader has read the "PALASM™ Manual" and the "PAL® Handbook" article reprint Testing Your PAL Devices. In general, PAL®/HAL® devices are required to provide a function table or "Seed Vectors" to Monolithic Memories in order to ensure that parts shipped have a high degree of reliability for the application intended. Ideally, these vectors should accomplish three objectives: - 1) Initialize the PAL device preferably in the same way as in the actual system: - 2) Exercise the customer's functions thoroughly, emulating actual system operation as closely as possible; - 3) Provide a high degree of fault coverage. ## Initialization Seed vectors which initialize the PAL logic circuit consist of one or more vectors placed at the very beginning which will bring both combinatorial and registered outputs to a stable and known logic state (1 or 0). This is necessary in the system also so that its operation upon power-up is predictable. Furthermore, care should be taken to ensure that the initialization state is a legal state of the state machine for which the PAL device is intended. #### **Exercise Functions** The essential functions for which the PAL device was originally designed must be exercised fully. This will assure that the tested parts work the way they were intended to. In addition to essential "designed-for" functions, it is prudent to include general test exercises such as verifying that outputs don't change in the absence of clock pulses and checking to see that inputs in the "don't care" (X) state don't produce adverse responses. General test exercises help to reinforce the validity of a design and can uncover overlooked design errors. After a set of exercises has been decided upon, the next step is to write them in a format suitable for simulation purposes. The designer may have originally defined the functions in terms of equations, state diagrams, truth tables, etc. Truth tables are readily reformatted to PALASM1 syntax "Function Tables" and exercises with the simulation option (code=S). State diagrams can be converted by expressing each state and input edge in binary vector format and sequencing them according to the diagram's flow. The customer should become thoroughly familiar with the syntax of the function table description (see the PALASM Manual for a detailed treatment of syntax) before attempting to translate truth tables, etc. The following simple example demonstrates how exercising seed vectors might be derived from a designer's state diagram: Assume the following state and edge definitions accompany the diagram: | STATE 0 = LL | | EDGE 0 = LL | |-----------------------|----------------|-------------| | STATE 1 = LH | | EDGE 1 = LH | | STATE 2 = HL | | EDGE 2 = LL | | ILLEGAL) STATE 3 = HH | | EDGE 3 = LH | | | | EDGE 4 = LL | | | | EDGE 5 = HH | | | (INITIALIZING) | EDGE 6 = HL | | | (INITIALIZING) | EDGE 7 = HL | | | (INITIALIZING) | EDGE 8 = HL | | | (INITIALIZING) | EDGE 9 = HL | From the above information, it is possible to create the truth table for the diagram and then the function table representation: | EDGE | PRESENT STATE | NEXT STATE | | | |------|---------------|------------|--|--| | AB | CD | CD | | | | HL | xx | ш, | | | | НН | Ĺ | HL | | | | LL | HL | HL | | | | LH | HL | LH | | | | LH | LH | Ц | | | | LL | LL | LH | | | | LL | LH | HL | | | PAL® and HAL® are registered trademarks of Monolithic Memories. PALASM™ is a trademark of Monolithic Memories. TWX: 910-338-2376 Monolithic Memories | F | FUNCTION TABLE REPRESENTATION | | | | | | | | | | | |----------|-------------------------------|-------------------|--|--|--|--|--|--|--|--|--| | FUNCTION | FUNCTION TABLE | | | | | | | | | | | | AB | CD | | | | | | | | | | | | HL | LL | INITIALIZE DEVICE | | | | | | | | | | | нн | HL | TEST EDGE 5 | | | | | | | | | | | LL | HL | TEST EDGE 4 | | | | | | | | | | | LH | LH | TEST EDGE 3 | | | | | | | | | | | LH | LL | TEST EDGE 1 | | | | | | | | | | | LL | LH | TEST EDGE 0 | | | | | | | | | | | LL | HL | TEST EDGE 2 | | | | | | | | | | # Fault Coverage Another criterion for seed vector completeness is "fault coverage". Fault coverage is an empirical method and is more quantitative than functional exercising — indeed, no knowledge of the circuit's intended function is necessary or assumed (although it could help) while developing fault coverage vectors. Fault coverage, being an empirical approach to determining a logic circuit's reliability, uses the concept of "failure models" to grade the effectiveness of a given set of test vectors. This is called "fault grading". In fault grading a set of vectors, a fault coverage value is calculated that is simply the ratio of detected faults to total faults expressed as a percentage. Test vectors may be graded against one or more failure models. Some well-known models include single stuck-at-1/ stuck-at-0, pattern sensitivities, shorts and opens and multiple stuck-at models. Selection of a failure model (or models) for fault grading fundamentally depends on the model's empirical effectiveness for screening bad parts and will be affected by a number of factors including circuit technology and fault simulator capabilities. The most common and primary fault coverage failure model considered by "TGEN" at Monolithic Memories is the classic single stuck-at-1/stuck-at-0 failure model. "TGEN" automatically appends test vectors which test for the following additional failure models where applicable: 1) Adjacencies, 2) Clock, 3) Tri-state. "TGEN" has a specified minimum value of fault coverage for PAL and HAL devices based on the single stuck-at failure model. The minimum values are determined by current "TGEN" policy (see your FAE) and reflect the economic trade-off between acceptable levels of reliability and the cost of test generation for maximum coverage. PAL and HAL devices for which the specified minimum values cannot be attained will require the customer's written waiver for low coverage prior to production release of the pattern. The fault coverage percentage determined by "TGEN" is different from the percentage determined by selecting the fault testing option (code=F) of PALASM1 software. In PALASM1 software fault coverage is based on product term coverage (PTC). PTC is still the ratio of detected to total faults except that "detected" and "total" fault sums refer to stuck-at faults on product term outputs only. PTC ignores stuck-at faults which occur anywhere else. A more accurate procedure is to calculate the coverage based on all the circuit nodes where a stuck-at condition may occur. When every node (fault site or wire) is considered, the coverage calculated correlates to the design's testability better and will generally be a much lower value than PTC. "TGEN" goes one step further in conservatism by calculating fault coverage on a "collapsed" fault basis. Fault collapsing simply divides all the stuck-at faults into groups such that, within a group, if one fault is detected, then all the others in the group are detected too. The advantage of collapsing it that only one representative fault in a group needs to be selected for test generation and if it is detected, then the other "equivalent" faults are detected by definition. This saves time and effort on test generation for equivalent faults. Calculations on a collapsed fault basis treat each group as one fault. The following simplified example demonstrates the difference in fault coverage calculations using a collapsed fault list: Note: This example is a simplified one for illustrative purposes only and does not show the effects of faults normally associated with input or output buffers. Also, some partial collapsing has already been done (i.e., input faults of "OR" gate are collapsed into output faults of "AND" gates). Assume the above circuit is to be realized as a PAL or HAL device. Suppose some seed vectors are provided also, as shown here: | | Α | В | С | D | E | F | G | Н | ı | |----------|---|---|---|---|---|---|---|---|---| | VECTOR 1 | Н | Н | Н | L | L | L | L | L | L | | VECTOR 2 | L | L | L | Н | Н | н | L | L | L | | VECTOR 3 | L | L | L | L | L | L | Н | Н | Н | | VECTOR 4 | L | L | L | L | L | L | L | L | L | # **PAL Function and Test Vectors** The seed vectors on the previous page yield various values for fault coverages corresponding to the method of calculation as shown in the table below. | | PTC | EVERY NODE | COLLAPSED | | |------------------------------------------|---------------------------|------------------------------------------------------------------------------|-----------------------------------------|----------| | SUBSET OF TOTAL | 20 | 2,4,6,20,26 | 2 | Vector 1 | | FAULTS CONSIDERED FOR CALCULATIONS | 22 10 0 | 8,10,12,22 | 8 | Vector 2 | | THAT ARE DETECTED BY EACH VECTOR | 24 | 14,16,18,24 | 14 | Vector 3 | | (SHOWN AT FAR RIGHT) | 19,21,23 | 19,21,23,25 | 19 | Vector 4 | | TOTAL FAULTS CONSIDERED FOR CALCULATIONS | 19,20,<br>21,22,<br>23,24 | 1,2,3,4,5,6,7,8,9,10,11,<br>12,13,14,15,16,17,18,<br>19,20,21,22,23,24,25,26 | 1,2,3,5,7,<br>8,9,11,13,<br>14,15,17,19 | | | PERCENT COVERAGE | 6/6 = 100% | 17/26 = 65% | 4/13 = 31% | | As can be seen from the above example, given the same seed vectors, PALASM1 software would show 100% coverage whereas "TGEN" would show 31% coverage. Notice that the poor coverage by "TGEN" is due to none of the input nodes being tested for stuck-at-1. In most instances, a better set of test vectors can improve the coverage significantly. For the above example, the reader can verify that the following slight modification of the seed vectors would yield 100% coverage for all calculation methods: | | Α | В | С | D | E | F | G | н | ı | |----------|---|----|-----|---|---|---|----|-----|---| | VECTOR 1 | Н | Н | Н | L | L | L | L | L | L | | VECTOR 2 | L | L | L | Н | Н | Н | E. | L | L | | VECTOR 3 | L | L | Ž.L | L | L | L | Н | , H | Н | | VECTOR 4 | L | Н | Н | L | Н | Н | L | Н | Н | | VECTOR 5 | Н | L | Н | Н | L | Н | Н | L | Н | | VECTOR 6 | Н | Η. | L | Н | Н | L | Н | Н | L | # **Testability** The previous sections described some essentials for comprehensive seed vector set. Variations on how fault coverage is calculated was covered also. However, no matter how it is calculated, fault coverage is only as good as the testability of the circuit permits. Using the stuck-at failure model, the customer must consider both absolute and practical fault coverages achievable for his PAL/HAL logic circuit design. Certain testa- bility factors, such as redundancy, number of test points (outputs) or reconvergence, affect absolute (i.e., theoretical maximum) coverage. Other factors, including preloadable state machines, the amount of feedback and overall controllability, will affect practical coverage since many faults may be potentially detectable but uneconomical to detect due to excessive vectors or difficult to reach states. As testability is improved, absolute and practical fault coverage will usually increase. # A Study of the anomalous behavior of synchronizer circuits Danesh M. Tayana **METASTABILITY** ## INTRODUCTION This article will summarize the results of the studies performed on synchronizer circuits. The information presented may be used by system designers to gain insight into the anomalous behavior of edgetriggered flip-flops. Understanding flip-flop behavior and applying some simple design practices can result in an increased reliability of any system. #### METASTABILITY In the digital world a bit represents the fundamental unit of measure. The output state of any digital device is either "HIGH" (a voltage level above VIH) or "LOW" (a voltage level below VIL) as shown in figure 2. Under the proper operating conditions the register in figure 1 outputs a HIGH or a LOW on the rising edge of the clock within a nominal delay called the "clock to out" delay. If the setup and hold times are violated the register has a small probability of entering a third region of operation called the "metastable" state. Metastable is a Greek word meaning "in between" and it is a state between HIGH and LOW. Even though most synchronizers snap out of metastability in a short period of time, theoretically this state can persist indefinitely. Some of the registers built from older technologies had metastable states which lasted as long as a few microseconds. When the output of a device goes into metastability the clock to out delay will be grossly affected. This may alter the system's worst case propagation delay and potentially lead to a system crash! #### SYNCHRONIZERS The design of a synchronous digital system is based on the assumption that the maximum propagation delay of a flip-flop and any other gates are known. A digital system is free of hazardous race conditions and timing anomalies if the maximum propagation delay in the system does not exceed the clock's period. In systems where an asynchronous input is interfaced with a clocked device such as a flip-flop, the maximum specified propagation delay of this device may no longer be valid if certain electrical parameters are violated. Computer peripherals, an operator's keyboard, or two independently clocked subsystems are instances where there is a possibility of interfacing an asynchronous input which will violate the synchronizer's electrical A popular device typically used in synchronized systems is the edge-triggered register shown in figure 1. The edge-triggered register will properly synchronize the incoming data to the system's clock as long as its operating conditions are satisfied. Table 1 summarizes these specifications for Monolithic Memories Inc.'s (MMI) 74LS374 register. It is difficult to guarantee setup and hold time requirements when the data is asynchronously interfaced to a register. The violation of setup or hold time in a register has a probability of initiating a misbehavior termed "Metastability." | SYMBOL | PARAMETER | CO | UNIT | | | |-----------------|--------------------------|------|------|------|----| | | | MIN. | TYP. | MAX. | | | V <sub>CC</sub> | Supply Voltage | 4.5 | 5 | 5.5 | V | | TA | Operating free air temp. | 0 | | 75 | °C | | t₩ | Width of clock | 15 | | | ns | | t <sub>su</sub> | Setup time | 20 | | | ns | | th | Hold time | 0 | | | ns | Figure 2 NS The diagrams in figure 3 illustrate some examples of waveforms in the metastable condition. From the waveforms it is evident that the outputs are distorted under metastable conditions. Figure 3d shows the output of a typical 74LS374 register manufactured by Monolithic Memories. Monolithic Memories family of bipolar devices exhibit superior metastable hardened performance due to their high speed bipolar technology and advance Schottky TTL circuit design techniques. Most of these devices typically snap out of metastability in a flashing 15 nanoseconds. #### WHY THE SYNCHRONIZER FAILS Before attempting to explain how the synchronizer's internal circuity fails let's take a look at an interesting problem. PROBLEM: In the SR type latch shown in figure 4 what happens if the set (S) and the reset (R) inputs are simultaneously raised from a LOW voltage level to a HIGH level? Monolithic Memories ANSWER: The outputs will be in a stable state of HIGH prior to the RS transition and will quickly oscillate to a final steady state of either HIGH or LOW (see figure 3a). To demonstrate this result the reader is encouraged to do this excercise either mentally or to actually build the circuit and view the output on the oscilloscope. Figure 3 Clock driven master-slave flip-flops contain the same type of cross tied RS latch within their internal circuitry. The NAND gate equivalent of the master-slave D type flip-flop is shown in figure 5. The gates circled in this figure can potentially behave similar to the above problem. If the clock and data are triggered within a specific window of one another the output may have an oscillatory behavior before settling down. Cross tied RS latch structure is seen in the master-slave edge triggered flip-flop. Figure 5 #### METASTABLE DETECTOR This section will show how to characterize the behavior of an edge triggered flip-flop with an asynchronous data interface. If the setup and hold times of the flip-flop are satisfied the output behaves properly (figure 6a). One of the four possible events below can take place if the flip-flop goes metastable: - 1) The output starts to make a transition but snaps back to its original state (figure 6b). - 2) The output makes a complete transition but the maximum propagation delay of the device is exceeded (figure 6c). - 3) The output starts oscillating and retains its present state (figure 6d). - 4) The output oscillates to a new state (figure 6e). Figure 6 The circuit shown in figure 7 is used to obtain experimental results of a metastable device. The circuit can detect and count the number of events of metastability. The device under test (DUT) is forced into metastability by repeatedly sweeping the edges of the data past the rising edges of the clock. The modulation of the data is possible by using a comparator device (UI) along with an external sawtooth waveform. Thousands of transitions are created within the setup and hold time window of the DUT. Sweeping the data edges past the low to high clock transitions simulates an asynchonous input and increases the probability of getting a metastable failure on the output (Q) of the DUT. - ① JITTER BAND SIMULATES AN ASYNCHRONOUS BEHAVIOR - (2) METASTABLE OUTPUT - (1) PROPER OUTPUT WAVEFORM - △CLOCK SAMPLES THE OUTPUT (Q) AFTER A DELAY △. Figure 7 If the output of the device goes into metastability it will be detected by the comparator pair (U2) and (U3). The comparators will have complementary outputs if the output (Q) of DUT is anywhere between VIH and VIL. The outputs of the comparators are latched by a delayed version of the clock ( $\triangle$ Clock). The EXCLUSIVE-NOR gate followed by the register signal the event of metastability to an external counter. The variable delay ( $\Delta$ ) between the two clocks will sample the output at various locations on the time axis. As this delay is varied the event of metastability is sampled and counted at these locations by our circuit. Therefore the output of our circuit measures the rate of metastability versus time delay. The real behavior of a metastable output can thus be effectively characterized with this scheme, that is, we can determine the length of time a metastable condition will persist and the density distribution of the metastable event. Three 74374 devices and four PAL devices are used in this experiment. The plots of metastable failure versus time are shown in figures 8a.b. The next section will discuss in detail the characteristics of these plots. #### EXPERIMENTAL RESULTS Various graphs of metastability failure rate versus delay time are illustrated in figure 8. We can conclude from these graphs that the rate of metastability failure decreases as the sample clock ( $\Delta CLOCK$ ) moves farther and farther away from the DUT clock. The pictures shown in figure 9 have captured repeated events of metastability on the oscilloscope. Let's take a closer look at one of the graphs to examine the behavior of the device. The PAL16R4A-4 device exhibits one count per second if the delay ( $\Delta$ ) is 60 nanoseconds. As the delay ( $\Delta$ ) is decreased, the rate increases exponentially until the delay equals 32 ns at which point the rate flattens out and remains fixed. The 32 ns forms the knee of our araph and will be referred to as $\Delta o$ . The rate will remain constant if the delay ( $\Delta$ ) is decreased past the knee of our graph. Further reduction in the delay will place the sampling clock's rising edge prior to data transitions and thus the error rate vanishes to zero. The time at which the rate goes to zero is marked with an (X) on the graphs. By using this time (X), and another location on the graph such as the time where only one error per second occurs, we can associate an approximate range of metastability for different devices. This range of metastability is referred to as the "mean time to snap out of metastability". From the graph it is evident that the mean time to snap out of metastability for the PAL16R4A-4 logic circuit is the difference between 60 ns and 25 ns which is 35 ns. Figure 8a ......... All of the graphs illustrated can be quantified by an equation of the form: $$\log FAILURE = \log MAX - b(\Delta - \Delta 0)$$ Since a natural logarithm is a constant multiple of base 10 logarithm we can rewrite the above equation as: $$\alpha \cdot \ln FAILURE = \alpha \cdot \ln MAX - b(\Delta - \Delta 0)$$ In the above equation the MAX value is representative of the maximum metastability failure rate in our device. This MAX value is closely related to the frequency at which a metastable condition may occur in our device. The frequency at which metastability occurs is simply a constant multiple of the product of CLOCK and DATA frequency. $$MAX = Kl \cdot f_{CLOCK} \cdot f_{DATA}$$ Substituting this in our original equation we get $$\begin{split} \alpha \cdot \ln \text{FAILURE} &= \alpha \cdot \ln \left( \text{K1} \cdot f_{\text{CLOCK}} \cdot f_{\text{DATA}} \right) - b(\Delta - \Delta o) \\ \ln \text{FAILURE} &= \ln \left( \text{K1} \cdot f_{\text{CLOCK}} \cdot f_{\text{DATA}} \right) - b/\alpha(\Delta - \Delta o) \\ \text{FAILURE} &= \left( \text{K1} \cdot f_{\text{CLOCK}} \cdot f_{\text{DATA}} \right) e^{-k2(\Delta - \Delta o)} \end{split}$$ Figure 9 (2v/DIV, 5ns/DIV) Table 2 gives the three important parameters which can be used by system designers to fully characterize the metastable behavior of the mentioned devices. These parameters can be obtained for different devices by duplicating this experiment. An example is given below to show how the information on table 2 may help the designer in the design of asynchronous systems. | MANUFACTURER | DEVICE | K <sub>1</sub> (Sec) | K <sub>2</sub> (ns <sup>-2</sup> ) | △0 (ns) | |--------------|------------|----------------------|------------------------------------|---------| | | PAL16R4 | 1 x 10-7 | 4.3 | 37 | | | PAL16R4A | 1 x 10 <sup>-7</sup> | 4.3 | 34.5 | | MMI | PAL16R4A-2 | l x 10-7 | .64 | 25 | | | PAL16R4A-4 | 1 x 10 <sup>-7</sup> | .5 | 31 | | | 74LS374 | 2 x 10-7 | 1.8 | 27.5 | | AMD | 74LS374 | 2 x 10-7 | 2.0 | 34.5 | | FAIRCHILD | 74F374 | 2 x 10-7 | 11.5 | 17.5 | Table 2 #### EXAMPLE For the hardware implementation in figure 10 determine the maximum clock frequency to give a typical error rate of one failure per year. We must choose the minimum period to give an error rate of less than Figure 10 one failure per year. From this result we can determine the maximum clock frequency. The time $\Delta$ in the equation below will determine the distance between clock edges. We must determine $\Delta$ from the equation by numerical extrapolation. The system clock's period can be represented as ( $\Delta$ + Tcc + setup), or plugging in the numbers it is $\Delta$ +75. FAILURE = $$(Kl \cdot f_{CLOCK} \cdot f_{DATA}) e^{-K2(\Delta - \Delta 0)}$$ and plugging in the appropriate values we have: $$3.2EE - 8 = [(1EE - 7)(1/(\Delta + 75ns))(9600)]e^{-[(4.3)(\Delta - 37)]}$$ Solving for $\Delta$ , we see that it is approximately 43 nanoseconds. The system period is thus seen to be the sum of 43ns and 75ns or 118ns. The maximum clock frequency is the inverse of the period or approximately 8 MHz. #### CONCLUSION Synchronization of two independent pulse trains is possible through the use of edge triggered registers. The electrical characteristics of the flip-flop are affected when the setup and hold times of the device are violated. This misbehavior is termed "metastability" and its probability of occurrence can be derived for a given system. The factors which affect this probability and the length of time which a metastable condition persists are influenced by the technology of the device as well as by the circuit design techniques. An important fact which needs to be stressed is that even if a register's output goes metastable, the system may not necessarily fail if the register snaps out in time to satisfy the system's worst case timing requirement. The following design practices are suggested when using synchronizers: Try to minimize the number of locations where asynchronous signals enter your system. Clocking the asynchronous inputs through two pipelined registers can greatly reduce the error rate. Use a single clock within your local system environment. For multiple system clocks, derive all the clock signals from a single source to assure synchronization between different devices within the system. When analyzing the worst case timing of your system, add the time to snap out of metastability to any register in an asynchronous data path. A single PAL\* with registers can be your best choice for state machine analysis of asynchronous events. As the registers have virtually identical setup times, the simultaneous observation of a metastable event by different register states are likely to be the same. Contrasted to a distributed system of observing register states with different setup times, the PAL system of register states with identical setup times is a superior synchronizer. Avoid edge sensitive devices on the output paths of the registers which have asynchronous inputs. The glitch created when the synchronizer goes metastable is enough to trigger the edge sensitive device. The use of level sensitive devices is generally a better design practice. PAL devices can be effective synchronizers where various registering schemes are easily implemented. PAL16R4A-2 # High-Speed Bipolar PROMs Find New Applications As Programmable Logic Elements\* Vincent J. Coli and Frank Lee Classic applications for bipolar PROMs include instruction storage for microprogram control store and software for microprocessor programs. However, due to a new design methodology and state-of-the-art performance, PROMs are finding increasing numbers of applications as Programmable Logic Element (or PLE) devices. This paper will cover the architecture, applications, and software support for PLE devices. 그는 선생님들에 한 경기 있는데 이 경기를 통해 없는 그래까 그리는 경기를 하는 것 같다. \* This paper is a slightly modified version of the paper by the same name which appeared in the Conference Proceedings of the 9th West Coast Computer Faire, pages 40-47; April 1984. TWX: 910-338-2376 2175 Mission College Blvd. Santa Clara, CA 95054-1592 Tel: (408) 970-9700 TWX: 910-338-2374 # High-Speed Bipolar PROMs Find New Applications As Programmable Logic Elements Vincent J. Coli and Frank Lee Classic applications for bipolar PROMs include instruction storage for microprogram control store and software for microprocessor programs. However, due to a new design methodology and state-of-the-art performance, PROMs are finding increasing numbers of applications as Programmable Logic Element (or PLE) devices. This paper will cover the architecture, applications, and software support for PLE devices. # **Fuse-Programmable Logic Families** A typical combinatorial Boolean equation can be written in sum-of-product form, which consists of several AND gates summed at an OR gate. In general, a set of combinatorial Boolean equations with n inputs (I0, 11, ..., In-1) and m outputs (O0, O1, ..., Om-1) can be generated through one level of AND gates followed by one level of OR gates. Custom logic functions can be defined using programmable logic. Figure 1. Structure of Programmable Logic Devices Fuse-programmable devices normally consist of two levels of logic — AND-array and OR-array — as suggested above. There are three basic types of fuse-programmable devices — PROM (Programmable Read Only Memory), PLA (Programmable Logic Array), and PAL® (Programmable Array Logic) devices. Which arrays are fuse-programmable distinguish these three types of devices. PLAs offer the greatest flexibility since both the AND and OR arrays are programmable. This flexibility comes with the cost of lower performance, higher power dissipation, and generally higher price. A PAL device has only the AND-array programmable; the OR-array is fixed. Each output has an OR gate associated with it which sums a fixed number of product terms (AND combinations). Statistically there is only a limited number of product terms in any equation. So the flexibility of a PLA is normally not needed. This is a compromise between flexibility and cost and performance. The OR-array is programmable in a PROM, but the fixed AND-array consists of all combinations of literals for each of the input variables. For example, there are 32 product terms available in a PROM with 5 inputs a,b,c,d,e (corresponding to words 0 through 31 in the PROM memory): where '\*' represents the Boolean AND operator and '/' represents the Boolean NOT or inverter operator. The fuses in the OR-array are programmed to select the desired AND combinations. PROGRAMMABLE LOGIC ELEMENT PROGRAMMABLE LOGIC ARRAY PROGRAMMABLE ARRAY LOGIC FIXED AND ARRAY PROGRAMMABLE OR ARRAY BOTH ARRAYS PROGRAMMABLE PROGRAMMABLE PROGRAMMABLE AND ARRAY FIXED OR ARRAY Figure 2. Structural Difference Between PLE (PROM), PLA and PAL Devices. Note that the PAL and PLE Logic Circuits Complement Each Other. The PAL Device has Many Input Terms While the PLE Device is Rich in Product Terms The existence of all combinations of literals for all inputs makes it possible to define functions which cannot be implemented in a PLA or a PAL device. For example, a 5-input Exclusive-OR (XOR) function can be implemented using sixteen product terms. This may exceed the number of product terms available in a PAL device and will consume too many product terms in a PLA, but can be constructed quite efficiently in a PROM. It is important to realize that any combination of inputs can be decoded in a PROM as long as sufficient input pins are provided since a PROM provides 2<sup>n</sup> product terms (where n is the number of inputs). Another way of looking at this is that PROMs store the logic transfer function in a memory. The fixed AND-array (or AND-plane) consists fo the row and column decoders while the fuses in the OR-array (or OR-plane) are the bits in the memory. In a memory, a fuse blown versus a fuse intact distinguishes a HIGH from a LOW. Figure 3. Block Diagram of a PROM Viewed as PLE Device. Notice that the PLE Provides Many (2<sup>n</sup>, Where n is the Number of Inputs) Product Terms. A By-Product of this is Programmable Output Polarity: Either Active-High or Active-Low Output Polarities are Available Due to this special characteristic of abundant product terms, PROMs are also often used as logic devices. In this paper, PROMs are referred to as PLE (Programmable Logic Element) devices. # **Advantages of PLE Devices** PLE devices provide a cost-effective solution for many applications. Here are just some of the advantages of PLE devices: - 1) Customizable Logic The designeer is limited to standard functions if SSI/MSI devices are used. The designer can create his own logic chips using PLE devices. - 2) Design Flexibility Modification of design is possible even without redesigning the PC board. For example, the address space of a microprocessor-based system can be reconfigured by merely programming a new device if the decoding is implemented in a PLE device. This feature comes in handy if you want to upgrade a system which originally used 64-K Dynamic RAMs to now use state-of-the-art 256-K Dynamic RAMs. - 3) Reduce Errors Errors are sometimes unavoidable and oftentimes quite expensive. Programmable devices make it easier and less expensive to correct errors. - Reduction of Printed Circuit Board Space—PLE devices save C board space since several SSI/MSI functions can be ntegrated into a single package. - 5) Fast Turnaround Time With existing commercial programmers and development software support, a prototype of the sustom tailored PLE device will be ready in just a few minutes. # A Great Performer! #### PLE Applications PLE applications include random logic replacement, decoder/ encoders, code converters, custom ALUs, error detection and correction, look-up tables (both trigonometric and arithmetic), lata scaling, compression arithmetic like Wallace Tree adders, distributed arithmetic, and residue arithmetic. Several levels of random logic chips can be replaced by one PLE ogic circuit. As discussed earlier, PLE devices can implement ogic in sum of products form. Despite the existence of dedicated encoders and decoders, many of these functions are application dependent. A standard 3-to-8 decoder/demultiplexer (74S138) can be used in decoding applications. But the decoding scheme may require several 3-to-8 decoder/demultiplexers and additional SSI OR-gates. On the other hand, a PLE device can be customized to perform the required decoding function with no additional gates. Simple decoders, such as those used for decoding memory chip selects from address lines, can be implemented in a PLE device with five to ten inputs. More complex decoding may require eight to twelve inputs. Figure 4. PLE Address Decoding Application. The PLE Device Selects One of Eight 2Kx8 Static RAMs by Decoding Several Microprocessor Address Lines PLE devices also offer a very flexible solution for code conversion applications. Translations of codes such as from ASCII to EBCIDIC, Binary to BCD (Binary Coded Decimal), or BCD to Gray code can be implemented in PLEs. The 74S184 Binary-to-BCD Converter is actually a 32x8 PROM. Figure 5. Two Examples of PLE Code Converters. The Second Example Illustrates How to Use Two Inputs as Code Select Lines so that Four Converters can be Provided in One PLE Device # **High-Speed Bipolar PROMs Find New Applications as PLE Devices** Standard ALUs (such as the 74S181) may not provide a very specalilized function which a particular system requires, such as BCD arithmetic. In this case a PLE device is again a good alternative. Although the PLE device may be slower than a dedicated ALU, the presence of this specialized function is critical. For example, a 4-bit ALU can be constructed in a PLE device with twelve inputs (A3-A0, B3-B0, I2-I0, Cin) and eight outputs (F3-F0,/G,/P, Cout, A = B). Any eight functions can be implemented. Figure 6. Block Diagram for a 4-Bit ALU which can be Implemented in a PLE Device Data scaling is another PLE device application. A dedicated multiplier is not required if the scaling factor is a constant; the prescaled result can be stored in a PLE device. Fixed-bit multipliers are typically implemented in PLE devices. Column compression technique (also called Wallace Tree Compression) is used when expanding an array of several smaller parallel multipliers to perform large wordlength multiplication. These smaller multipliers will generate partial products (intermediate results) which must be numerically summed according to bit significance in order to calculate the final wordlength multiplication. Many levels of 2-input bus adders can be used to add these partial products, but the carry propagation delays may be too long. However, partial product adders implemented in PLE devices can do compression of many levels without passing carries. Thus, the summmation will be much faster. "... THE 'S556, TOGETHER WITH PLE≥ ORGANIZED IN A WALLACE-TREE CONFIGURATION, CAN SAIL RIGHT ALONG AT THE RATE OF FOUR 56 X 56 MULTIPLICATIONS EVERY MICROSECOND ..." Group Code Recorder (GCR) is an encoding/decoding scheme used for error detection on tape. During a WRITE operation, each 8-bit word is divided into two 4-bit nibbles. Both nibbles are then encoded into 5-bit codes before being recorded onto tape. Both 5-bit codes are decoded back to the original 4-bit nibbles and then combined during a READ operation. PLE circuits are exceptionally useful in mapping the 4-bit data to the 5-bit code and back. Figure 7. GCR Encoder/Decoder Block Diagram Exclusive-OR gates, being half adders, are very prevalent in Error Detection and Correction (EDC) schemes. Many SSI chips are required to implement this function while PLA and PAL devices may not provide sufficient product terms. PLE devices are again an ideal solution. Figure 8. Exclusive-OR Gates can be Implemented in PLE Very Efficiently. A 4-Input XOR Gate (a) Maps into a Checkerboard Pattern in a Karnaugh Map (b) and Requires Eight Product Terms (c). The PLE Implementation is Shown in (d). An 8-input XOR Gate Requires Sixteen Product Terms (d) In many applications, the speed of the converging series used to generate the trigonometric functions is too slow and the accuracy obtained by direct table look-up requires too much hardware. A good compromise between speed and hardware is to store an approximation to the function in a PLE device. Then use this approximation as a starting point for an iterative algorithm (such as Newton-Raphson) to obtain additional accuracy. High-Speed division, multiplication, and square-root calculations can be performed in a similar manner. Figure 9. PLE Look-Up Tables and Iteration Loops can be Used to Generate Very Accurate Trigonometric and Arithmetic Functions. An Approximation to the Function is Stored and Additional Accuracy is Gained Using Iteration Operations listributed arithmetic is used for performing convolution opertions without using multiplier/accumulators. If the coefficients re constant, a look-up table for convolution can be stored in a 'LE device, thus replacing the multiplier. lesidue arithmetic (also called Carry-Independant arithmetic); a technique used to perform very fast integer arithmetic. High peed is achieved by using numbers in residue representation of that the sequential delay of carries on digits of higher ignificance is eliminated. A Residue Numbering System (RNS) determined using an optimum moduli when designing the ystem. Conversion to and from residue representation are asic mapping functions which can be conveniently done in a LE device. Also, since operations in residue arithmetic are erformed using modulo addition and multiplication without arries, these operations can also be done using PLE devices. In eneral, residue arithmetic should only be used for integer ithmetic which requires intensive operations. Figure 10. Architecture of a System Based on RNS. An Integer Number is Converted to RNS Representation Using PLE Devices, Then the RNS Arithmetic is Performed Using Some Other PLE Devices, and Finally the RNS Result is Converted Back to Integer Representation Again Using PLE Devices ### Restrictions The basic restrictions for using PLE devices to replace SSI/MSI parts are: Since a memory element has a product term for every combination of literals of all the input terms, static hazard is normally unavoidable. For example, there are 5 inputs available in a 32 x 8 PROM. In order to generate a function like: The actual implementation inside the PROM will be: If a = b = c = d = HIGH, according to the first equation, we shall expect f to remain HIGH independent of e changing. In the actual PROM implementaton, there will be no hazard if e stays either HIGH or LOW. But if e changes, depending on whether e or e will occur first, there exists the possibility that both product terms in the second equation will be LOW momentarily, which may cause a static logic hazard (HIGH to LOW to HIGH) for f. This hazard is commonly called a "glitch". Static hazards are not a problem for many applications, like those offered in this paper, but extreme care must be taken if the output of a PLE device is used to strobe another device. 11 | ADDRESS | e | đ | C | ь | a | f | |----------------|-------|---|---|-------|-------------|-------| | 00 | 0 | 0 | 0 | 0 | 0 | 0 | | 01<br>02 | 0 | 0 | 0 | 0 | 0 | 0 | | 0C | 0 | 1 | 1 | . 0 | 0 | 0 | | OD<br>OE | 0 | į | i | 0 | 1 0 | Ŏ | | OF | 0 | į | i | 1 | 1 | 1 | | 10<br>11<br>12 | 1 1 1 | 0 | 0 | 0 0 1 | 0<br>1<br>0 | 0 0 0 | | | | | | • | | | | 1D<br>1E | 1 | 1 | 1 | 0 | 1 | 0 | | <b>i</b> | ī | î | i | ì | 1 | 1- | Figure 11. This Truth Table Graphically Illustrates the Possible Glitch (HIGH to LOW to HIGH Hazard) for the Function f = a\*b\*c\*d implemented in a 32x8 PROM. Address 0F and 1F Contain a 1 while All Other Locations Contain a 0 for Output f. If Address Inpute Should Change, the PROM Decoders Could Momentarily Selct a Location Containing a 0 2) Although PROMs are available with registered outputs, internal feedback from the outputs and buried registers are not yet available in PROMs. External connections from some outputs to inputs must be made for applications which require feedback (such as in state machines). However, Registered PROMs without feedback are useful for pipelining (overlap instruction fetch and execution) in order to increase system throughput. # **PLEASM Software Support** Monolithic Memories has developed a software tool to assist in designing and programming PROMs as PLE devices. This package, called "PLEASM" (PLE Assembler), is available for several computers including the VAX/VMS and IBM PC/DOS. PLEASM converts design equations (Boolean and arithmetic) into truth tables and formats compatible with PROM programmers. A simulator is also provided to test a design using a Function Table before actually programming the PLE device. The PLEASM operators are listed below and the PLEASM catalog of operations is given on the next page. A sample PLE Design Specification (source code for PLEASM software) with PLEASM outputs is given in Figure 12. PLEASM software may be requested through the Monolithic Memories IdeaLogic Exchange. ### **Operators** (in hierarchy of evaluation) - ; Comment follows - Dot operator (pin list or arithmetic operator follows) - ADD Address pins (Inputs) - DAT Data pins (Outputs) - Delimiter, separates binary bits (MSB first) - Equality (combinatorial) #### **BOOLEAN OPERATORS** - / Complement, prefix to a pin name - \* AND (product) - + OR (sum) - : +: XOR (exclusive or) - : \*: XNOR (exclusive nor) ### ARITHMETIC OPERATORS - . \* . Multiply (numeric multiplication) - . + . Plus (numeric addition) Monolithic Memories PLEASM version 1.2D © copyright 1984 Monolithic Memories PLEASM — PLE Assembler — provides the following options: - C Catalog - Prints the PLEASM catalog of operations - E Echo Input - Prints the PLE design specifications - T Truth Table - Prints the entire truth table - B Brief Table - Prints only used addresses in the truth table - H Hex Table - Prints the truth table in HEX form - S Simulate - Exercises the function table in the logic equations - I Intel Hex - Generates INTEL HEX programming - A ASCII Hex - Generates ASCII HEX programming format - Q Quit - Exits PLEASM | PLE5P8 | | PL | E DESIGN | SPEC | FICATION | |------------------|-------------|----|----------|------|------------| | P5000 | | | VINCENT | COLI | 10/03/82 | | BASIC GATES | | | | | 10.0704.00 | | MMI SANTA CLARA, | CALIFORNIA | | | | | | .ADD IO I1 I2 I3 | 14 | | | | | | DAT 01 02 03 04 | 05 06 07 08 | | | | | | - | | | | | | | | |----|-------|--------|-----------|-------------|-----|------------|--------| | 01 | = 10 | | | | ; E | UFFER | | | 02 | - /10 | | | | ; 1 | NVERTER | | | 03 | = 10 | * 11 | * 12 | 13 * 14 | ; 2 | ND GATE | | | 04 | = IO | + . 11 | + 12 | 13 + 14 | ; 0 | OR GATE | | | 05 | = /10 | + /11 | + /12 | - /13 + /14 | ; N | AND GATE | | | 06 | = /10 | * /11 | * /12 * | /13 * /14 | ; N | OR GATE | | | 07 | = 10 | :+: 11 | :+: 12 :+ | : I3 :+: I4 | ; E | XCLUSIVE O | R GATE | #### FUNCTION TABLE 10 11 12 13 14 01 02 03 04 05 06 07 08 O8 = I0 :\*: I1 :\*: I2 :\*: I3 :\*: I4 | ; INPUT | | OUT | PUTS | FRO | M BAS | IC G | ATES | | | |---------|-----|-----|------|-----|-------|------|------|------|-------------------| | ;01234 | BUF | INV | AND | OR | NAND | NOR | XOR | XNOR | COMMENTS | | LLLLL | L | н | L | L | н | н | L | L | ALL ZEROS | | ннннн | H | L | H | H | L | L, | H | H | ALL ONES | | HLHLH | Н | L | L | H | H | L | H | H | ODD CHECKERBOARD | | LHLHL | L | H | L | H | н | L | L | L | EVEN CHECKERBOARD | ; EXCLUSIVE NOR GATE #### DESCRIPTION THIS EXAMPLE ILLUSTRATES THE USE OF PLES TO IMPLEMENT THE BASIC GATES: BUFFER, INVERTER, AND GATE, OR GATE, NAND GATE, NOR GATE, EXCLUSIVE OR GATE, AND EXCLUSIVE NOR GATE. NOTE ALSO THAT THREE-STATE OUTPUTS ARE PROVIDED WITH ONE ACTIVE LOW OUTPUT ENABLE CONTROL (/E). PLEASM GENERATES THE PROM TRUTH TABLE FROM THE LOGIC EQUATIONS AND SIMULATES THE FUNCTION TABLE IN THE LOGIC EQUATIONS. Figure 12a. PLE Design Specification. This is the Source Code for PLEASM Software. PLEASM Software Generates the Truth Table and Programming Formats from the Equations. PLEASM Software Also Exercises the Function Table in the Equation and Reports Errors BASIC GATES .ADD 10 11 12 13 14 .DAT 01 02 03 04 05 06 07 08 igure 12b. Truth Table. PLEASM Software Generates This Truth Table which can be Used for Verifying Your Design BASIC GATES .ADD 10 11 12 13 14 .DAT 01 02 03 04 05 06 07 08 | ADD | HEX ADDRESS | HEX DATA | |-----|-------------|----------| | 0 | 000 | 32 | | 1 | 001 | D9 | | 3 | 002 | DA | | . 3 | 003 | 19 | | 4 | 004 | DA | | 5 | 005 | 19 | | 6 | 006 | 1A | | 7 | 007 | D9 | | 8 | 008 | DA | | 9 | 009 | 19 | | 10 | 00A | 1A | | 11 | 00B | D9 | | 12 | 00C | 1A | | 13 | OOD | D9 | | 14 | 00E | DA | | 15 | OOF | 19 | | 16 | 010 | DA | | 17 | 011 | 19 | | 18 | 012 | 1A | | 19 | 013 | D9 | | 20 | 014 | 1A | | 21 | 015 | D9 | | 22 | 016 | DA | | 23 | 017 | 19 | | 24 | 018 | 1A | | 25 | 019 | D9 | | 26 | 01A | DA | | 27 | 01B | 19 | | 28 | 01C | DA | | 29 | 01D | 19 | | 30 | OlE | 1A | | 31 | 01F | CD | HEX CHECK SUM = 00F3C Figure 12c. Hex Table. PLEASM Software Generates This Truth Table in Hexadecimal Form for Verification of Locations in the PLE 32 D9 DA 19 DA 19 1A D9 DA 19 1A D9 DA 19 1A D9 DA 19 . DA 19 1A D9 1A D9 DA 19 1A D9 DA 19 DA 19 1A CD . Figure 12d. ASCII Hex Programming Format. PLEASM Software Generates this ASCII Hex Programming Format with Hex Check Sum. Control Characters are included so that the information can be Down-Loaded Directly to a PROM Programmer :1000000032D9DA19DA191AD9DA191AD9DA1940 :10001000DA191AD91AD9DA191AD9DA19DA191ACD54 :00000001FF Figure 12e. Intel Hex Programming Format. PLEASM Software Generates this Intel Hex Programming Format with a Hex Check Sum Following Every 16 Bytes of Data # **High-Speed Bipolar PROMs Find New Applications as PLE Devices** # **PLE Family** Monolithic Memories carries a family of fast PROMs which can be used as Memory or PLE devices. Since the critical parameter for logic applications is speed, our series of fast PROMs have worst-case memory access times (or propagation delays) ranging from 15 ns for small PROMs to 40 ns for large PROMs. The Logic Symbols for four of the PLE devices are given in Figure 13 and a summary of the PLE family is given below: ### **PLE Selection Guide** | PAR<br>NUMB | | INPUTS | OUTPUTS | PRODUCT<br>TERMS | OUTPUT<br>REGISTERS | t <sub>PD</sub> (ns)<br>MAX* | |-------------|-----|----------------|---------|------------------|---------------------|------------------------------| | PLE5P | 3 | «· 5 | 8 | 32 | | 25 | | PLE5P | ВА | 5 | 8 | 32 | | 15 | | PLE8P | 4 | 8 | 4 | 256 | | 30 | | PLE8P | 3 | 8 | 8 | 256 | | 28 | | PLE9P | 4 | 9 | 4 | 512 | | 35 | | PLE9P | 3 | 9 | 8 | 512 | | 30 | | PLE10 | P4 | 10 | 4 | 1024 | | 35 | | PLE10 | 28 | 10 | 8 | 1024 | | 35† | | PLE11I | 24 | 11 | 4 | 2048 | | 35 | | PLE11I | 28 | 11 | 8 | 2048 | | 35 | | PLE12I | P4 | 12 | 4 | 4096 | | 35 | | PLE12I | 28 | 12 | 8 | 4096 | | 40 | | PLE9R | В | 9 | 8 | 512 | 8 8 | 15 | | PLE10 | ₹8 | 10 | 8 | 1024 | 8 | 15 | | PLE11I | RA8 | Green 11 magen | 8 | 2048 | . 8 | 15 | | PLE11I | RS8 | 11 | 8 | 2048 | 8 | 15 | <sup>\*</sup>Clock to output time for registered outputs NOTE: Commercial limits specified. # **Acknowledgements** Several of the designs discussed in this paper were proposed by our good friend and colleague Ulrik Mueller, who is now studying Computer Science in his native country, Denmark, and our Monolithic Memories Pal Zahir Ebrahim. Special thanks also go to Ranjit Padmanabhan for writing the PLEASM simulator. # Summary There are many interesting applications for high-speed PROMs used as PLE devices. A software package called "PLEASM" software is available as a development tool. ### References - "PAL Programmable Array Logic Handbook", 3rd edition, J. Birkner, V. Coli, Monolithic Memories, Inc. - 2. "Systems Design Handbook", Monolithic Memories, Inc. - "Bipolar LSI 1984 Databook", 5th edition, Monolithic Memories, Inc. - "PROMs and PLEs: An Application Perspective", Z. Ebrahim, Monolithic Memories Application Note AN-126. - "An Introduction to Arithmetic for Digital Designers", S. Waser, M.J. Flynn, Holt, Rinehart & Winston, N.Y., 1982. Figure 13. Four Sample PLE Logic Symbols <sup>†</sup> Preliminary data. Michael J. Holley DATA I/O 10525 Willows Rd. N.E. Redmond, WA 98073-9746 As the use of PAL® and PLE devices (PROMs) increases, the need for high-level design tools becomes necessary. Designers need easier, faster, and more efficient ways to design with such programmable devices. With the more complex devices currently being introduced to the market, this need is even greater. Additionally, a designer should be able to specify logic designs in a way that makes sense in engineering terms; he or she should not have to learn a new way of thinking about designs. ABEL™, a complete logic design tool for PAL devices, PLE devices and FPLA devices meets these requirements. ABEL™ incorporates a high-level design language and a set of software programs that process logic designs to give correct and efficient designs. The ABEL™ design language offers structures familiar to designers: state diagrams, truth tables, and Boolean equations. The designer can choose any of these structures or combine them to describe a design. Macros and directives are also available to simplify complex designs. The ABEL™ software programs process designs described with the high-level language. Processing includes syntax checking, automatic logic reduction, automatic design simulation, verification that a given design can be implemented in a chosen device, and automatic generation of design documentation. To use ABEL™, the designer uses an editor to create a source file containing an ABEL™ design description. He then processes the source file with the ABEL™ software programs to produce a programmer load file. The programmer load file is used by logic and PLE programmers to program devices. Several programmer load file formats are supported by ABEL™ so that different programmers may be used. The source file created by the designer must contain test vectors if simulation is to be performed. Test vectors describe the desired (expected) input-to-output function of the design in a truth table format. The ABEL™ simulator applies the inputs contained in the test vectors to the design and checks the obtained outputs against the expected outputs in the vectors. If the outputs obtained during simulation do not match those specified in the test vectors, an error is reported. Following are two designs described in the ABEL™ design language. These designs would be processed to verify their correctness and to reduce the number of terms required to implement them. The first design is for a PAL device, the second for a PLE logic circuit. ABEL™ is a trademark of DATA I/O. ### 6809 MEMORY ADDRESS DECODER Address decoding is a typical application of programmable logic devices, and the following describes the ABEL™ implementation of such a design. Figure 1. Block Diagram: 6809 Memory Address Decoder ### **Design Specification** Figure 1 shows a block diagram for the design and a continuous block of memory divided into sections containing dynamic RAM (DRAM), I/O (IO), and two sections of ROM (ROM1 and ROM2). The purpose of this decoder is to monitor the six high-order bits (A15-A10) of a sixteen-bit address bus and select the correct section of memory based on the value of these address bits. To perform this function, a simple decoder with six inputs and four outputs is designed with a 14L4 PAL device. Table 1 shows the address ranges associated with each section of memory. These address ranges can also be seen in figure 1. Figure 2. Simplified Block Diagram: 6809 Memory Address Decoder ### **Design Method** Figure 2 shows a simplified block diagram for the address decoder. The address decoder is implemented with simple AL® is a registered trademark of Monolithic Memories. Monolithic Memories TWX: 910-338-2376 # ABEL™, A Complete Design Tool For Programmable Logic Boolean equations employing both relational and logical operators as shown in figure 3. A significant amount of simplification is achieved by grouping the address bits into a set named Address. The lower-order ten address bits that are not used for the address decode are given "don't care" values in the address set. In this way, the designer indicates that the address in the overall design (that beyond the decoder) contains sixteen bits, but that bits 0-9 do not affect the decode of that address. This is opposed to simply defining the set as, Address = [A15,A14,A13,A12,A11,A10], which ignores the existence of the lower-order bits. Specifying all 16 address lines as members of the address set also allows full 16-bit comparisons of the address value against the ranges shown in table 1. ### **Test Vectors** In this design, the test vectors are a straightforward listing of the values that must appear on the output lines for specific address values. The address values are specified in hexadecimal notation on the left side of the "->"" symbol. Input to a design always appear on the left side | Memory Section | Address Range (hex) | |----------------|---------------------| | DRAM | 0000-DFFF | | 1/0 | E000-E7FF | | ROM2 | F000-F7FF | | ROM1 | F800-FFFF | Table 1. Address Ranges for 6809 Controller of the test vectors. The expected outputs are specified to the right of the "->" symbol. The designer chose in this case to use the symbols H and L instead of the binary values 1 and 0 to describe the outputs. The correspondence between the symbols and the binary values was defined in the constant declaration section of the source file, just above the section labeled equations. ``` module m6809a title '6809 memory decode 24 Feb 1984' Jean Designer Data I/O Corp Redmond WA device 'P14L4': 1109 A15, A14, A13, A12, A11, A10 pin 1, 2, 3, 4, 5, 6; ROM1, IO, ROM2, DRAM pin 14, 15, 16, 17; H, L, X = 1, 0, X.; equations ! DRAM (Address (= ^hDFFF); (Address ) = ^hE000) & (Address (= ^hE7FF); 110 ! ROM2 (Address )= ^hF000) & (Address <= ^hF7FF); (Address >= ^hF800); ! ROM1 (ROM1, ROM2, IO, DRAMI) test vectors (Address -> н, ^h0000 -> £: L J; н, н, н, н, ^h4000 E L J; -> н, н, ^h8000 E н, L ]; ^hC000 Ε н. L 1; 3; ^hE000 -> C H н, н, 3; ^hE800 -> C Н. н, н, Н ^hF000 -> C н, н э; н, H 3; ^hF800 C end m6809a ``` Figure 3. Source File: 6809 Memory Address Decoder ### Seven-Segment Display Decoder This display decoder decodes a four-bit binary number to display the decimal equivalent on a seven-segment LED display. The design incorporates the ABEL™ truth table format and is implemented on a RA5P8 PLE. Figure 4. Block Diagram: Seven-Segment Display Decoder ### **Design Specification** Figure 4 shows a block diagram for the decoder design and a drawing of the display with each of the seven segments abeled to correspond to the decoder outputs. To light up any one of the segments, the corresponding line must be driven low. Four input lines D0-D3 are decoded to drive the correct output lines. The outputs are named a, b, c, d, e, f, and g corresponding to the display segments. All outputs are active low. An enable, ena, is provided. When ena is low, he decoder is enabled; when ena is high, all outputs are triven to high impedance. Figure 5. Simplified Block Diagram: Seven-Segment Display Decoder ### **Jesign Method** Figures 5 and 6 show the simplified block diagram and the source file for the ABEL™ implementation of the display lecoder. The FLAG statement is used to make sure that the rogrammer load file is in the Motorola Exorciser format. The binary inputs and the decoded outputs are grouped into he sets bcd and led to simplify notation. The constants ON and *OFF* are declared so that the design can be described in terms of turning a segment on or off. To turn a segment on, the appropriate line must be driven low, thus *ON* is declared as 0 and *OFF* as 1. The design is described in two sections: an equations section and a truth table section. The decoding function is described with a truth table that specifies the outputs required for each combination of inputs. The first line of the truth table (the truth table header) names the inputs and outputs. In this example, the inputs are contained in the set named *bcd* and the outputs are in *led*. The body of the truth table defines the input-to-output function. Because the design decodes a number to a seven-segment display, values for *bcd* are expressed as decimal numbers, and values for *led* are expressed with the constants *ON* and *OFF* that were defined in the declarations section of the source file. This makes the truth table easy to read and understand; the incoming value is a number and the outputs are on and off signals to the LED. The input and output values could have just as easily been described in another form. Take for example the line in the truth table: 5 -> [ON,OFF,ON,ON,OFF,ON,ON] This could have been written in the equivalent form: $$[0,1,0,1] - > 36$$ In this second form, 5 was expressed as a set containing binary values, and the LED set was converted to decimal. (Remember that *ON*was defined as 0 and *OFF* was defined as 1.) Either of the two forms is valid, but the first is more appropriate for this design. The first form can be read as, "the number five turns on the first segment, turns off the second,..." whereas the second form cannot be so easily translated into terms meaningful for this design. # **Test Vectors** The test vectors for this design test the decoder outputs for the ten valid combinations of input bits. The enable is also tested by setting ena high for the different combinations. All outputs should be at high impedance whenever ena is high. If they are not, an error has occurred. # Summary Two designs described with the ABEL™ design language have been shown. The first design shows how Boolean equations with logical and relational operators are used to describe an address decoder. The second design shows how a truth table describes a seven-segment display decoder design for a PLE logic circuit. In both designs, test vectors were written to test the function of the design using ABEL™ simulator. In addition to the Boolean equations and truth table shown in these examples, ABEL™ features a state diagram structure. The state diagram allows the designer to fully describe state machines in terms of their states and state transitions. Regardless of the method used to describe logic, ABEL™'s automatic logic reduction and simulation ensure that the design uses as few terms as possible and that it operates as the designer intended. The end results are savings in time, devices, board space, and money. ``` module bcd7rom flag '-d82' title 'seven segment display decoder 16 Mar 1984' Redmond WA Data I/O Corp BCD-to-seven-segment decoder similar to the 7449 fl g lb segment identification el d lc device 'RA5P8': U6 pin 10, 11, 12, 13; D3. D2. D1. DO a, b, c, d, e, f, g pin 1, 2, 3, 4, 5, 6, 7; pin 15; = [D3, D2, D1, D0]; bcd led = [a, b, c, d, e, f, g]; ON. OFF = 0, 1; " for common anode LEDs L, H, X, Z = 0, 1, .X., .Z.; truth_table (bcd -> led) input outputs d ь C ON, OFF3; Ō -> [ ON. ON. ON. ON. ON. 1 -> COFF. ON. ON, OFF, OFF, OFF, OFF1: 2 -> E ON, ON, OFF, ON, ON, OFF, ON3; 3 -> C ON. ON, ON, DN, OFF. OFF. CNO: ON, ONJ: COFF. ON, OFF, OFF, 4 -> ON, -> C ON, ON, 5 ON, OFF, ONJ; OFF, ON, ON, ON, 6 -> C ON, OFF, ON, ON, CNO: DN, OFF, 7 -> [ ON, DN. OFF, OFF. OFF1: ON, ON, -> C ON, ON, 8 ON, ON, ON3; ON, OFF. ON, -> [ ON, ON. DN, ONI; test_vectors ([ena,bcd] -> led) outputs " inputs d OFF, OFF); [L, 1] -> COFF. ON, ON, OFF, OFF, ON, OFF, ON, OFF, ON, : CNO CL, 23 -> C ON, [L, 3] ON, OFF, OFF, CNO; -> [ ON, ON, ON, CL, 43 -> COFF, ON, ON, OFF, OFF, ON, : CNO (L, 5) -> C ON, OFF, ON, ON, OFF, ON, ONJ: ON, OFF, ON, ON, CNO: CL, 61 -> [ ON, ON, OFF, [L, 7] -> C ON, ON, ON, OFF, OFF, OFF1: [L, 8] -> C ON, ON, ON, ON. ON, ON. OND: CL, 93 C ON, ON. OFF. ON. ONJ; -> ON, ON, [L, 0] ON, -> C ON. ON, ON, ON, ON, OFF1: z, CH, 51 -> C z, Ζ, z, Z, Z, ZJ; z, z, CH, 91 -> Е Z, z, z, z, Z]; z, [H, 0] -> C Z, Z, Z, Ζ, z, Z]; end bcd7rom ``` Figure 6. Source File: Seven-Segment Display Decoder # The Universal Compiler For **Programmable Logic** CUPL is the first software CAD tool designed especially for the support of all programmable logic devices (PLDs), including PALs and PROMs. It was developed specifically for YOU, the Hardware Design Engineer. Each feature of the CUPL language has been chosen to make using programmable logic easier and faster than conventional TTL logic design. # MAJOR FEATURES OF CUPL ### 1. UNIVERSAL - PRODUCT SUPPORT: CUPL supports products from every a. manufacturer of programmable logic. With CUPL you are free to use not only PALS, but also other programmable logic devices. - PALASM CONVERSIONS: CUPL has a PALASM to CUPL language b. translator which allows for an easy conversion from your previous PALASM designs to CUPL. - LOGIC PROGRAMMER COMPATIBILITY: CUPL produces a standard JEDEC download file and is compatible with any logic programmer that uses JEDEC files. ### 2. HIGH LEVEL LANGUAGE High Level Language means that the software has features that allow you to work in terms that are more like the way you think than like the final PLD programming pattern. Examples of these are: - FLEXIBLE INPUT: CUPL gives the engineer complete freedom in entering logic descriptions for their design: - EQUATIONS - TRUTH TABLES - STATE MACHINE SYNTAX - EXPRESSION SUBSTITUTION: This allows you to pick a name for an equation and then, rather than write the equation each time it is used, you need only use the name. CUPL will properly substitute the equation during the compile process. - c. SHORTHAND FEATURES: Instead of writing out fully expanded equations CUPL provides various shorthand capabilities such as: - LIST NOTATION: Rather than [A7,A6,A5,A4,A3,A2,A1,A0] CUPL only requires [A7..0] - BIT FIELDS: A group of bits may be assigned to a name, asin FIELD ADDR = [A7..0] Then ADDR may be used in other expressions - RANGE FUNCTION: Rather than A15 & !A14 # A15 & A14 & !A13 # A15 & A14 & A13 & !A12 CUPL only requires ADDR:[8000..EFFF] - THE DISTRIBUTIVEPROPERTY: From Boolean Algebra, where A & (B # C) is replaced by A & B # A & C - DeMORGAN'S THEOREM: From Boolean Algebra, where !(A & B) is replaced by !A # !B ### 3. SELF DOCUMENTING CUPL provides a template file which provides a standard "fill-in-theblanks" documentation system that is uniform among all CUPL users. Also, CUPL allows for free form comments through out your work so there can be detailed explanations included in each part of the project. ### 4. ERROR CHECKING CUPL includes a comprehensive error checking capability with detailed error messages designed to lead you to the source of the problem. ### 5. LOGIC REDUCTION CUPL contains the fastest and most powerful minimizer offered for Programmable Logic equation reduction. The minimizer allows the choice of various levels of minimization ranging from just fitting into the target device to the absolute minimum. ### 6. SIMULATION With CSIM, the CUPL Simulator, you can simulate your logic prior to programming an actual device. Not only can this save devices but it can help in debugging a system level problem. ### 7. TEST VECTOR GENERATION Once the stimulus/response function table information has been entered into the simulator, CSIM will verify the associated test vectors and append them to the JEDEC file for downloading to the logic programmer. The programmer will verify not only the fuse map, but also the functionality of the PLD, giving you added confidence in the operation of your custom part. ### 8. EXPANDABILITY CUPL is designed for growth so as new PALs and other devices are introduced you will be kept current with updated device libraries and product enhancements. ### DESIGN EXAMPLE USING CUPL In the following design example, a single PAL (or PROM) is used to replace four TTL packages on the interface card for an IBM-PC computer. The Prototype I/O Channel Interface Card, as supplied by IBM, uses four SSI packages to decode the ten bit I/O address and control the direction and enable for the bus buffer on the PCB. The PAL approach conserves real estate and also adds flexibility to decode not only the preassigned address, but the ability to change the board address to any location in the I/O map by merely replacing the programmable device. ### 1. CIRCUIT OPERATION The inputs to the decoding logic are the expansion bus addresses A0 thru A9. The logic compares the address on the expansion bus and asserts the "IO\_DECODE" signal when the correct address range of 3F0-3FF is seen. In addition, the "ENABLE" signal is also asserted if either the I/O READ or I/O WRITE signals are active during this time. The READ signal, which controls the direction of the data bus buffer, is asserted whenever I/O READ is active and AEN, the DMA Address enable signal is inactive. The AEN signal is negated when the microprocessor has control of the address bus and is generating an I/O cycle. ### 2. DESIGN METHOD First, all device pins are assigned in the logic description file (see figure 1) using CUPL's pin declaration statements. Note the use of indexed variables for the address bus allows a simple assignment for pins 1 thru 8. The active polarity for input and output pins are made in these declarations, so the designer need only be concerned with the logic instead of voltage levels. The address bus is assigned a name using the FIELD statement. This lets the designer then describe the desired address range with the single equation: range = ioadr:[300..31F]; instead of the difficult to understand range = a9 & a8 & !a7 & !a6 & !a5; This range expression is then used in the output equation for IO\_DECODE and ENABLE. Since ENABLE may be asserted whenever IOR or IOW are true, the intermediate variable IOREQ is created to define this condition. The resultant CUPL equation for ENABLE is simply enable = range & ioreq ; Finally, the READ signal is created using the active IOR and the inactive AEN signals as follows: read = ior & !aen ; Note that for a device such as the PAL16L8 which has a fixed inverting buffer on all of its output pins, CUPL will automatically convert the logic equations when an output is desired to be active-level HI, as with the READ output above. ### 3. CUPL OUTPUT FILES CUPL will create a standard JEDEC output file which is compatible with most logic programmers. A simple serial download link is all that is usually required to transfer the fuse information to the programmer. In addition, CUPL generates an extensive documentation file which assists the designer in analyzing his/her design. Figure 2 shows a small section of this file, illustrating such features as pin and variable names, product term utilization, and other information. ``` PARTNO P90001234 : NAME PCIO ; DATE 02/14/85 ; REV 01 ; DESIGNER Kahl/Osann : COMPANY Assisted Technology ; ASSEMBLY PC Proto Board : LOCATION U2 : /* This device provides a one-chip I/O interface for an equivalent */ /* of the IBM-PC proto board. This logic description may be placed */ /* in either a PROM or PAL without alteration. /* Allowable Target Device Types : PAL--> PAL16L8, PAL16P8 */ PROM-> PLE12P4 */ /** Inputs **/ ; /* CPU Address bits 0 thru 9 */ PIN [1..8] = [a2..9] = aen ; /* DMA Address Enable */ PIN 9 ; /* I/O Read Strobe (active LO) */ PIN 17 = !ior = !iow : /* I/O Write Strobe (active LO) */ PIN 18 /** Outputs **/ = read = read ; /* Direction Control For Bus Buffer */ = !enable ; /* Enable For Bus Buffer */ PIN 12 PIN 13 PIN 14 = !io decode : /* Decoded I/O Strobe for On Board Use */ /** Declarations and Intermediate Variable Definitions **/ field icadr = [a9..2] ; /* Name the I/O Address Bus "icadr" */ ioreg = ior # iow ; /* Define I/O Request */ range = ioadr:[300..31F] & !aen ; /* Decoded I/O Address Range and */ /* not DMA cycle */ /** Logic Equations **/ enable = range & ioreq ; io decode = range : read = ior & !aen : /* Change the intermediate variable "range" for other I/O Locations */ ``` Figure 1. 11 # CUPL™ Universal Compiler for Programmable Logic | CUPL | 2.02a | |----------|----------------------------------------------------| | Device | p1618 DLIB-c-18-5 | | Partno | P90001234 | | Name | PCIO | | Revision | <b>21</b> , 53, 53, 53, 53, 53, 53, 53, 53, 53, 53 | | Date | 02/14/85 | | Designer | Kah1/Osann | | Company | Assisted Technology | | Assembly | PC Proto Board | | Location | uz . | | | | \_\_\_\_\_\_ Symbol Table | Pol | Name | Ext | Pin | Type | Used | Max | |--------|------------|-----|-----|----------|-------------------------|-----------------------------------------| | | | | | | | | | | a2 | | 1.0 | V | rei <del>n</del> er die | | | | <b>a</b> 3 | | 2 | V | | | | | a4 | | 3 | V | | <b>-</b> | | | a5 | | 4 | V | - | | | | a6 | | 5 | V | | | | | a7 | | 6 | V | | | | | a8 | | 7 | V | - | _ | | 1 84 A | a9 | | 8 | V | <u></u> | | | | aen | | 9 | V | | | | 1 | enable | | 13 | V | 2 | 7 | | ļ. | io_decode | | 14 | V | 1 | 7 | | | ioadr | | 0 | F | <del>-</del> | <del></del> | | 1 | ior | | 17 | V | - | - <del>-</del> - | | | ioreq | | 0 | I | 2 | - | | ! | iow | | 18 | <b>V</b> | 90 <del>5</del> 0 90 0 | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | | | range | | 0 | I | 1 | - | | | read | | 12 | V | 2 | 7 | | | enable | oe | 13 | D | 1 | 1 | | | io_decode | ce | 14 | a | 1 1 | 1 1 1 1 A | | | ior | ce | 17 | D | 1 | 1 | | | iow | oe | 18 | D | 1.1 | 1 | | | read | oe | 12 | D | <ul> <li>1</li> </ul> | 1 | LEGEND D : default var F : field U : undefined V : var F : field I : intermediate var V : var X : extended var N: node M: extended node Figure 2. # 11 # CUPL-GTS DRAW LOGIC SCHEMATICS FOR PAL DESIGNS! In recent years, programs like CUPL and ABEL have become available to provide high level language support for PAL designs. These languages allow the designer to represent a PAL function in terms of high-level equations, truth tables or state machines. All of these logic description formats are non-graphical in nature and require a good working knowledge of the computer they run on. Many hardware designers, however, are most comfortable with the traditional logic schematic and have historically had little reason to use a computer in the design process. Use of a high-level PAL design language presents most of us with a variety of simultaneous unknowns: - 1. The computer and its operating system. - The full screen editor necessary to create the logic description file. - 3. The logic compiler or assembler language syntax. - 4. Boolean algebra theory. - 5. PAL architectures. Where this combination places an unnecessary burden on the designer, an alternative is now available. CUPL-GTS is a powerful combination of hardware and software which turns an IBM-PC type computer into a programmable logic workstation which allows the user to draw logic schematics for the function of a PAL. A basic premise in creating CUPL-GTS was to provide a friendly environment where the user is isolated from the traditional keyboard as much as possible. To this end, virtually all functions can be actuated with one button by way of the mouse and a series of pop-up menus which ease the user's task. An area is provided at the top of the CUPL-GTS screen for prompting the user regarding the next operation in a command sequence. Highlighting of various elements on the screen is coordinated with these prompts to enhance their effectiveness. For the most part, the user need only utilize the conventional keyboard for defining symbolic names for wires, pins, objects, and files. An on-screen HELP facility is provided to aid the user with CUPL-GTS commands. In addition to the basic set of object types which can be easily picked from a pop-up menu, the ability to call up macro-objects is also provided. These macro-objects have been previously drawn using CUPL-GTS and stored away on the disk under their own symbolic name. After a logic schematic has been entered, the user may quickly check to see if the design fits in a specific PAL. This is done by selecting the "Translate to PLD" command from the main menu which automatically invokes the GTS translation programs. These programs run in an on-screen window which overlays the graphical information, providing feedback in the form of error messages displayed in this window. Following the automatic execution of these programs, the cursor is returned to the user who can then continue to work in the graphics environment without ever having fully left. In this way many errors can be quickly determined and remedied without ever having to let go of the mouse. When the user wishes a hard copy version of a design, the print command from the main menu may be selected. This causes the GTS print program to execute in an on-screen window according to the printer configuration file (PRINTCAP) which is stored on the disk. The PRINTCAP file allows the user to configure the GTS print function for any dot matrix printer they might have. Often a logic description not fit in a particular PAL due to a logic capacity (product-term) limitation. When this occurs, the universal capability of CUPL-GTS will easily allow the user to try placing this same logic in a different PAL of similar architecture. Since CUPL-GTS incorporates CUPL the high level language in its internal operation, it also benefits from CUPL's powerful "Quine Procedure" logic minimizer. This is especially advantageous for CUPL-GTS as logic descriptions showing many levels of gates can be very deceptive in their ability to consume the logic capacity of a PAL. The presence of the logic minimizer can eliminate unnecessary and redundant logical functions, and maximizes the probability that a design will fit in a target PAL. Also included with CUPL-GTS is the CUPL simulator, CSIM, which allows the user to simulate a logic design prior to physically creating a programmed PAL. Not only can this save devices, but it can help significantly in debugging a system level problem. CUPL-GTS is desinged for growth and expandability. As new programmable logic devices are introduced users will be kept current with updated device libraries and product enhancements. Most of us first use PAL devices to replace TTL in order to shrink a design and/or add functionality. The following example shows how the simple I/O decoder design previously discussed would appear on the CUPL-GTS screen prior to translation to a PAL16L8, PAL16P8 or PLE12P4. de l'Espair de Coulombre de Coulombre de l'Espair de l'Espair de l'Espair de Coulombre (Espair de l'Espair de Le des Coulombre de l'Espair de l'Ambre de l'Espair de l'Espair de l'Espair de l'Espair de l'Espair de l'Espai Le de l'Espair A CUPL-GTS Design Screen | | PAL® Device Introduction | | |---------------------------------------------------------------------------------------------|-----------------------------------------|----| | | PAL®/HAL® Device Specifications | 2 | | 는 마음을 통해 있는 경찰에 있는 생생들이 보고 있는 것이 없었다. 그런 그 사람들이 되었다. 그런 | | | | | PAL Device Programmer Ref. Guide | 3 | | | HAL/ZHAL™ Devices | 4 | | | Logic Cell Array™ | 5 | | | PALASM® Software Syntax | 6 | | | PAL Device Applications | 7 | | | Logic Tutorial | 8 | | | PLE™ Devices | 9 | | | PLE Circuit Applications | 10 | | $\lambda$ | Article Reprints | | | | General Information | 12 | | | Package Drawings | 13 | | / | Representatives and Distributors | 14 | | | 그 집에 가장 하다 하다 나는 사람들이 되었다면 하는데 하는데 되었다. | | ### **Clock Frequency** # Maximum clock frequency, f<sub>max</sub> The highest rate at which the clock input of a bistable circuit can be driven through its required sequence while maintaining stable transitions of logic level at the output with input conditions established that should cause changes of output logic level in accordance with the specification. ### Current ### High-level input current, IIH The current into\* an input when a high-level voltage is applied to that input. ### High-level output current, IOH The current into\* an output with input conditions applied that according to the product specification will establish a high level at the output. # High-level output current, I<sub>CEX</sub> The high-level leakage current of an open collector output. ### Low-level input current, IIL The current into\* an input when a low-level voltage is applied to that input. #### Low-level output current, Io The current into\* an output with input conditions applied that according to the product specification will establish a low level at the output. # Off-state (high-impedance-state) output current (of a three-state output), $I_{\rm OZ}$ The current into\* an output having three-state capability with input conditions applied that according to the product specification will establish the high-impedance state at the output. ### Short-circuit output current, IOS The current into\* an output when that output is short-circuited to ground (or other specified potential) with input conditions applied to establish the output logic level farthest from ground potential (or other specified potential). ### Supply current, I<sub>CC</sub> The current into\* the $V_{CC}$ supply terminal of an integrated circuit \*Current out of a terminal is given as a negative value. # **Hold Time** # Hold time t<sub>h</sub> The interval during which a signal is retained at a specified input terminal after an active transition occurs at another specified input terminal. # NOTES: 1. The hold time is the actual time between two events and may be insufficient to accomplish the intended result. A minimum value is specified that is the shortest interval for which correct operation of the logic element is guaranteed. The hold time may have a negative value in which case the minimum limit defines the longest interval (between the release of data and the active transition) for which correct operation of the logic element is guaranteed. ### **Output Enable and Disable Time** # Output enable time (of a three-state output) to high level, $t_{\text{PZH}}$ (or low level, $t_{\text{PZL}})$ The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to the defined high (or low) level. # Output enable time (of a three-state output) to high or low level, $t_{\mbox{\scriptsize PZX}}$ The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to either of the defined active levels (high or low). # Output disable time (of a three-state output) from high level, $t_{\text{PHZ}}$ (or low level, $t_{\text{PLZ}}$ ) The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined high (or low) level to a high-impedance (off) state. # Output disable time (of a three-state output) from high or low level, $t_{\text{PX7}}$ The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from either of the defined active levels (high or low) to a high-impedance (off) state. # $t_{\text{EA}}$ is the output enable access time of memory devices. $t_{\text{ER}}$ is the output disable (enable recovery) time of memory devices. ### **Propagation Time** ### Propagation delay time, tpD The time between the specified reference points on the input and output voltage waveforms with the output changing from one defined level (high or low) to the other defined level. ### Propagation delay time, low-to-high-level output, tpi H The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined low level to the defined high level. ## Propagation delay time, high-to-low-level output, tpHL The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined high level to the defined low level. $\mathbf{t}_{\mathbf{A}\mathbf{A}}$ is the address (to output) access time of memory devices. #### Pulse Width ### Pulse width, tw The time interval between specified reference points on the leading and trailing edges of the pulse waveform. ### **Setup Time** # Setup time, t<sub>su</sub> The time interval between the application of a signal that is maintained at one specified input terminal and a consecutive active transition at another specified input terminal. - NOTES: 1. The setup time is the actual time between two events and may be insufficient to accomplish the setup. A minimum value is specified that is the shortest interval for which correct operation of the device is guaranteed. - The setup time may have a negative value in which case the minimum limit defines the longest interval (between the active transition and the application of the other signal) for which correct operation of the device is guaranteed. # Voltage # High-level input voltage, VIH An input voltage within the more positive (less negative) of the two ranges of values assumable by a binary variable. NOTE: A minimum is specified that is the least positive value of high-level voltage for which operation of the logic element within specification limits is guaranteed. ### High-level output voltage, VOH The voltage at an output terminal with input conditions applied that will establish a high level at the output. The actual input conditions needed are determined by the individual product specification. ### Input clamp voltage, Vic An input voltage in a region of relatively low differential resistance that serves to limit the input voltage swing. # Low-level input voltage, V<sub>IL</sub> An input voltage level within the less positive (more negative) of the two ranges of values assumable by a binary variable. NOTE: A maximum is specified that is the most positive value of low-level input voltage for which operation of the logic element within specification limits is guaranteed. ### Low-level output voltage, Vol The voltage at an output terminal with input conditions applied that will establish a low level at the output. The actual input conditions needed are determined by the individual product specification. #### Negative-going threshold voltage V<sub>T\_</sub> The voltage level at an input that causes a transition as the input voltage falls from a level above the positive-going threshold voltage, $V_{\rm T}$ $_{+}$ . ### Positive-going threshold voltage, V<sub>T</sub>, The voltage level at an input that causes a transition as the input voltage rises from a level below the negative-going threshold voltage, $V_{\rm T-}$ . # **Truth Table Explanations** H = high level (steady-state) L = low level (steady-state) ↑ = transition from low-to-high level ↓ = transition from high-to-low level X = don't care (any input, including transitions) Z = off (high-impedance) state of a three-state - = off (high-impedance) state of a three-state output - a..h = the level of steady-state inputs at inputs A through H respectively - Q<sub>0</sub> = level of Q before the indicated steady-state input conditions were established - Q̄<sub>0</sub> = complement of Q̄<sub>0</sub> or level of Q̄ before the indicated steady-state input conditions were established - Q<sub>n</sub> = level of Q before the most recent active transition indicated by ↓ or ↑ If, in the input columns, a row contains only the symbols H, L, and/or X, this means the indicated output is valid whenever the input configuration is achieved and regardless of the sequence in which it is achieved. The output persists as long as the input configuration is maintained. If, in the input columns, a row contains H, L, and/or X together with $\uparrow$ and/or $\downarrow$ , this means the output is valid whenever the input configuration is achieved and the indicated transition has occurred (the transition(s) must occur following the achievement of the steady-state levels). If the output is shown as a level (H, L, Q<sub>0</sub>, or $\overline{\rm Q}_0$ ), it persists as long as the steady-state input levels and the levels that terminate indicated transitions are maintained. Unless otherwise indicated, input transitions in the opposite direction to those shown have no effect at the output. Apple Strategic Sign medica and a medical paper and a military and separate section of the control contro The residence of the second , gabang b**ak**atah panggan sani Georgia ्रिक्षेत्र के के किया परिश्व किर्माला कहाँ है कि स्वाक्षेत्र है कहा है है । इसके कहाँ कहाँ के अध्यक्षित है कि का अध्यक्षित कहाँ है । g de la companya co La companya de co and the second of o o medicina kapidi dalah perjena kenjumah bilan menjumban kening di sebagai mediligisa beranda beranda beranda Sebagai perjena beranda perjena beranda beranda beranda beranda beranda beranda beranda beranda beranda berand . 1966 - Ale Margolio, de Carlo Franco, en el proposo de la comercia de la comercia de la comercia de la comer La comercia de co Comercia de la del la comercia del la comercia de la comercia de la comercia de la comercia de la comercia del la comercia del la comercia de la comercia de la comercia del 1.1. (A. 1986年) (中国新闻) A. 1986年 tigare et percettioner et giften de en de en de percettion percettion de la communication de la communication de communication de la communication de la communication de la communication de la communication de la communi de la communication ्रे के बिक्के के पान मुख्यान प्रकार स्थान के कार्ने के ज़िल्ल on Politica (Company) de la company co a avolution includes the second and has ায় কৰা সংগ্ৰাক্তি । জনিবা নামৰ প্ৰস্থিতি হয় সংগ্ৰাহ কৰি । বিশ্ব কৰা সুস্থান কৰিছে জনমানৰ বিশ্ব কৰা সংগ্ৰাহ সংগ্ৰাহ । বিশ্ব বাবে সংগ্ৰাহ । বুলি ক্ষা নামৰিক সংগ্ৰাহ । ### scholagiskop e svoja žiosta ob Company of the form of the second sec en en la companya de co The Second of the American Second of the Sec (ii) Le montaine de la commentation commen The property of the property of the control | | 그를 하는 것이 하는 사람이 하다는 생각이 되었다. 그는 학생들이 하는 사람들이 되었다. 그들은 사람들은 사람들은 사람들이 되었다. 그는 사람들이 되었다. | |----|----------------------------------------------------------------------------------------| | 2 | PAL®/HAL® Device Specifications | | 3 | PAL Device Programmer Ref. Guide | | 4 | HAL/ZHAL™ Devices | | 5 | Logic Cell Array™ | | 6 | PALASM® Software Syntax | | 7 | PAL Device Applications | | 8 | Logic Tutorial | | 9 | PLE™ Devices | | 10 | PLE Circuit Applications | | 11 | Article Reprints | | 12 | General Information | | 13 | Package Drawings | | 14 | Representatives and Distributors | | | <del>' ' '</del> | **PAL® Device Introduction** 145 ± .020 .011 ± .003 .279 ± .076 3.683 ± .508 .040 ± .010 1.016 ± .254 2°- 13° REF. (2) 9.525 ± .635 160 MIN 1. Specified body dimensions allow for differences between SSI, MSI and LSI packages. Specified body dimensions allow for universities between 501, from and 201 personals. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 – 10 mils thickness to all lead tip dimensions. 1. Specified body dimensions allow for differences between SSI, MSI and LSI packages. 2. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 - 10 mils thickness to all lead tip dimensions. BSC .075 1.905 MAX 3.683 ± .508 .011 ± .003 .279 ± .076 .375 ± .025 9.525 ± .635 **REF.** (2) PO00030M ### **Package Drawings** .457 ± .102 24JS Ceramic SKINNYDIP (5/16"x1-1/4") Mil-M-38510, Appendix C, D-9 .056 ± .004 1.422 ± .102 .311 .060 1.524 MAX 1.258 + .022 7.899 .200 .158 ± .016 .293 ± .012 .015 MIN 31.953 ± .635 5.080 7.442 ± .305 4.013 + .406 .381 .325 ± .025 8.255 ± .635 .145 ± .020 .160 .011 ± .003 3.683 ± .508 BSC 4.064 .279 ± .076 .375 ± .025 9.525 ± .635 ### Notes: - 1. Specified body dimensions allow for differences between MSI and LSI packages. - 2. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 10 mils thickness to all lead tip dimensions. Notes: <sup>1.</sup> Solder fillets on lid edges not shown. # **Package Drawings** 20W Cerpack Mil-M-38510, Appendix C, F-9 24W Cerpack Mil-M-38510, Appendix C, F-6 NLESS OTHERWISE SPECIFIED: ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ±.007 INCHES PO00090 ### Package Drawings 16N Molded DIP (1/4"x3/4") ### 18N Molded DIP (1/4"x7/8") #### Notes: - 1. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 10 mils thickness to all lead tip dimensions. - 2. Both Version 1 and Version 2 configurations are manufactured interchangeably. - 3. Ejector pin marks on Version 1 are optional. ### **Package Drawings** 16W Cerpack Mil-M-38510, Appendix C, F-5 18W Cerpack UNLESS OTHERWISE SPECIFIED: "ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ±.007 INCHES PO00130 ### Notes: - 1. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 10 mils thickness to all lead tip dimensions. - 2. Both Version 1 and Version 2 configurations are manufactured interchangeably. - 3. Ejector pin marks on Version 1 are optional. # **Package Drawings** ### Notes: - 1. Lead material tolerances are for tin plate finish only. Solder dip finish adds 2 10 mils thickness to all lead tip dimensions. - 2. Both Version 1 and Version 2 configurations are manufactured interchangeably. - 3. Ejector pin marks on Version 1 are optional. 19 E 10 236 F 10 F # Package Drawings 20NL Molded Chip Carrier (.351"x.351") UNLESS OTHERWISE SPECIFIED: ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ± .007 INCHES ### Package Drawings 28NL Molded Chip (.451"x.451") UNLESS OTHERWISE SPECIFIED: ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ±.007 INCHES PO00180M # Package Drawings 16F-4/5 Flat Pack (1/4"x3/8") 18F-2/3 Flat Pack (3/8"x3/8") UNLESS OTHERWISE SPECIFIED: ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ±.007 INCHES ### Package Drawings 20F-3 Flat Pack (1/4"x3/8") UNLESS OTHERWISE SPECIFIED: ALL DIMENSIONS MIN.-MAX. IN INCHES ALL DIMENSIONS MIN.-MAX. IN MILLIMETERS ALL TOLERANCES ARE ± .007 INCHES PO00210N | 1 | PAL® Device Introduction | |----|----------------------------------| | 2 | PAL®/HAL® Device Specifications | | 3 | PAL Device Programmer Ref. Guide | | 4 | HAL/ZHAL™ Devices | | 5 | Logic Cell Array™ | | 6 | PALASM® Software Syntax | | | PAL Device Applications | | 8 | Logic Tutorial | | 9 | PLE™ Devices | | 10 | PLE Circuit Applications | | 11 | Article Reprints | | 12 | General Information | | 13 | Package Drawings | | 14 | Representatives and Distributors | ## **Monolithic Memories Area and Regional Sales Managers** | Arizona Phoenix Ron Scarfo | (602) 971-7997 | Georgia Norcross Tom Lewis | (404) 447-0006 | New Jersey<br>Cherry Hill<br>Bruce Berlet | (609) 751-1288 | |-------------------------------------------|----------------------------------|-----------------------------------------------|----------------------------------------------------|-----------------------------------------------------|----------------------------------------------------| | California<br>San Jose | - 1 | Illinois<br>Naperville | | Scott Dunlop<br>Ken Toney | (609) 751-1288<br>(609) 751-1288 | | George Anderl | (408) 249-7766 | Dick Jones | (312) 961-9200 | Ohio | | | Mark Lunsford<br>Lou Scalzo | (408) 249-7766<br>(408) 249-7766 | Massachusetts<br>Framingham | | <b>Dayton</b><br>Mike Wier | (513) 439-0470 | | Santa Ana<br>Bernie Brafman<br>Mike Vogel | (714) 543-8664<br>(714) 543-8664 | Jack Abbott<br>Russ French<br>Daniel Kinsella | (617) 875-7373<br>(617) 875-7373<br>(617) 875-7373 | Oregon Medford John Charles | (503) 779-8945 | | Florida<br>Longwood | | Bob Norling Minnesota | (617) 875-7373 | Texas | | | Jim McGrath | (305) 682-6708 | Edina<br>Alex Sherbanenko | (612) 829-7343 | Dallas Ray Gouldsberry Dennis Prestel Bob Rainwater | (214) 690-3812<br>(214) 690-3812<br>(214) 690-3812 | ## **Monolithic Memories Representatives** | U.S.A. | | Minnesota | | Tennessee | | |------------------------------------|-------------------|---------------------------------------|-------------------|----------------------------|----------------| | Alabama | | Edina | | Jefferson City | | | Huntsville | | Mel Foster Tech Sale | s (612) 941-9790 | REP, Inc. | (615) 475-9012 | | REP, Inc. | (205) 881-9270 | Missouri | | Texas | | | Arizona | | Ballwin | (044) 004 7074 | Austin | (E10) 4E4 0601 | | Scottsdale | (000) 000 4050 | Rush and West | (314) 394-7271 | West Associates Richardson | (512) 454-3681 | | Summit Sales | (602) 998-4850 | New Jersey<br>Haddonfield | | West Associates | (214) 680-2800 | | California | | Tritek Sales, Inc. | (609) 429-1551 | Houston | | | Canoga Park Bager Electronics | (818) 712-0011 | Teaneck | (300) 120 | West Associates | (713) 621-5983 | | Fountain Valley | (0.0)7.12.001. | Technical Marketing | | Utah | | | Bager Electronics | (714) 957-3367 | Group | (201) 692-0200 | Salt Lake City | | | San Diego | | New Mexico | | Waugaman Assoc. | (801) 261-0802 | | Littlefield & Smith | (619) 455-0055 | Albuquerque | | Washington | | | Santa Clara | (400) 000 0000 | BFA Corporation | (505) 292-1212 | Bellevue | (000) 455 5046 | | Criterion | (408) 988-6300 | New York | | Northwest Marketing | (206) 455-5846 | | Colorado | | East Rochester Tri-Tech Electronics. | | Wisconsin | | | Wheatridge<br>Waugaman Assoc. | (303) 423-1020 | Incorporated | (716) 385-6500 | Brookfield<br>Sumer | (414) 784-6641 | | Connecticut | (000) 420-1020 | Endwell | | | (414)704 0011 | | Wallingford | | Tri-Tech Electronics, | | CANADA | | | Comp Rep Associate | es (203) 269-1145 | Incorporated | (607) 754-1094 | British Columbia | | | Florida | | Fayetteville | | Vancouver | (604) 430-3680 | | Deerfield Beach | | Tri-Tech Electronics,<br>Incorporated | (315) 446-2881 | Davetek Marketing | (004) 430-3000 | | Sales Engineering | | Fishkill | (010) 440-2001 | Ontario<br>Brampton | | | Concepts Inc. | (305) 426-4601 | Tri-Tech Electronics, | | Cantec | (416) 791-5922 | | Altamonte Springs | | Incorporated | (914) 897-5611 | Ottawa | | | Sales Engineering<br>Concepts Inc. | (305) 682-4800 | Melville | | Cantec | (613) 725-3704 | | Georgia | (605),002 | Technical Marketing<br>Group | (516) 351-8833 | Quebec | | | Tucker | | | (510) 551-6655 | Dollard Des Ormeaux | | | REP, Inc. | (404) 938-4358 | North Carolina<br>Charlotte | | Cantec | (514) 683-6131 | | Illinois | | REP, Inc. | (704) 563-5554 | | | | Rolling Meadows | | Raleigh | (. 0 .) 000 000 . | | | | Sumer | (312) 991-8500 | REP, Inc. | (919) 851-3007 | | | | Indiana | | Ohio | | | | | Indianapolis | | Cincinnati | | | | | DeVoe Co. | (317) 842-3245 | Makin Associates | (513) 871-2424 | | | | lowa | | Columbus | (04.4) 404 0000 | | | | Cedar Rapids<br>S & O Sales | (319) 393-1845 | Makin Associates Solon | (614) 481-8898 | | | | Kansas | (0 10) 000- 1040 | Makin Associates | (216) 248-7370 | | | | Nansas<br>Olathe | | Oklahoma | (2.5)2707070 | | | | Rush and West | (913) 764-2700 | Tulsa | | | | | Maryland | | West Associates | (918) 665-3465 | | | | Baltimore | | Oregon | | | | | Coprov Salos | (201) 206 2444 | | | | | Northwest Marketing (503) 620-0441 Comp Rep Associates (809) 746-6550 Conroy Sales Massachusetts Westwood Grosse Point Park Greiner Associates Michigan (301) 296-2444 (313) 499-0188 Comp Rep Associates (617) 329-3454 **Portland** **Puerto Rico** Caguas ## **Monolithic Memories World-Wide Applications Support** | U.S.A. | | Massachusetts | | France | | |----------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------| | California Canoga Park Michael Sholklapper Granada Hills Mark Kovalik San Jose Shiri Kadambi | (818) 710-0664<br>(818) 341-7257<br>(408) 249-7766 | Framingham Gary Smith Bob Norling Mike Gridley Dan Kinsella New Jersey Steven Traum | (617) 875-7373<br>(617) 875-7373<br>(617) 875-7373<br>(617) 875-7373<br>(609) 751-1288<br>(609) 751-1288 | Jose Juntas Michel Rolland Marc Guyonnet Germany Peter Reidle Willy Voldan | 46-8734-62<br>46-8734-62<br>46-8734-62<br>49-89-984961 | | Joe Kotas<br>Masood Shakeel<br><b>Santa Ana</b><br>Scott Thomas<br>Bill McNamara | (408) 249-7766<br>(408) 249-7766<br>(714) 543-8664<br>(714) 543-8664 | Scott Dunlop<br>Paul J. Koep<br>Ohio<br>Dayton<br>Bill Hollon | (609) 751-1288<br>(609) 751-1288<br>(513) 866-8928 | Tokyo Tervo Saitoh Hide Imatomi Sakyo Nagashima Mitsvaki Ukiya | 81-3-207-3131<br>81-3-207-3131<br>81-3-207-3131<br>81-3-207-3131 | | Georgia Norcross Mark Reynolds Ian Scott | (404) 447-0006<br>(404) 447-0006 | Barry Seidner EUROPE England | (214) 690-3812 | Singapore<br>Ian Meikle | 65-225-7544 | | Illinois Naperville Chris Belanger | (312) 961-9200 | Harry Hughes<br>Steve Scard<br>Simon Moran-Smith | 44-252-517431<br>44-252-517431<br>44-252-517431 | | | ## **Monolithic Memories Franchised Distributors** | U.S.A. | | Tustin | 13 June 45 | Kansas | | |--------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------|--------------------------------|------------------| | Alabama | | Arrow Electronics | (714) 669-4524 | Lenexa | | | Huntsville | | Image Electronics | (714) 259-0900 | Arrow Electronics | (913) 541-9542 | | Marshall Electronics | | Kierulff Electronics | (714) 731-5711 | Marshall Electronics | 建设有税 机邻位 | | Group | (205) 881-9235 | Colorado | | Group | (913) 492-3121 | | Arrow Electronics | (205) 837-6955 | Aurora | | Maryland | | | Kierulff Electronics | (205) 883-6070 | Arrow Electronics | (303) 696-1111 | Columbia | and the second | | Arizona | | Englewood | | Arrow Electronics | (301) 995-0003 | | Phoenix | | Anthem Electronics | (303) 790-4500 | Lionex | (301) 964-0040 | | Kierulff Electronics | (602)437-0750 | Kierulff Electronics | (303) 790-4444 | Gaithersburg | | | | (002)431-0130 | Thornton | (333) | Marshall Electronics | | | Tempe | (600) 066 6600 | Marshall Electronics | | Group | (301) 840-9450 | | Anthem Electronics Arrow Electronics | (602) 966-6600<br>(602) 968-4800 | Group | (303) 451-8383 | Kierulff Electronics | (301) 840-1155 | | Marshall Electronics | (002) 300 4000 | Connecticut | | Linthicum | | | Group | (602) 968-6181 | | | Kierulff Electronics | (301) 636-5800 | | | (002) 000 0101 | Meriden | (000) 007 0000 | | (201), 500, 5000 | | California | | Lionex Corporation | (203) 237-2282 | Massachusetts | | | Agoura | | Wallingford | (000) 005 7744 | Billerica | (017) 007 0001 | | Image Electronics | (818) 707-0911 | Arrow Electronics | (203) 265-7741 | Kierulff Electronics | (617) 667-8331 | | Canoga Park | | Kierulff Electronics | (203) 265-1115 | Burlington | | | Marshall Electronics | | Marshall Electronics Group | (203) 265-3822 | Marshall Electronics | (047) 070 0000 | | Group | (818) 509-0001 | ang tanggar an | (203) 203-3622 | Group | (617) 272-8200 | | Chatsworth | | Florida | | Wilmington | · | | Anthem Electronics | (818) 700-1000 | Clearwater | | Lionex Corporation | (617) 657-5170 | | Arrow Electronics | (818) 701-7500 | Arrow Electronics | (813) 576-8995 | Woburn | | | Marshall Electronics | (040) 407 4400 | Deerfield Beach | | Arrow Electronics | (617) 933-8130 | | Group | (818) 407-4100 | Arrow Electronics | (305) 429-8200 | Michigan | | | Kierulff Electronics | (213) 725-0325 | Fort Lauderdale | | Ann Arbor | | | Cypress | | Kierulff Electronics | (305) 486-4004 | Arrow Electronics | (313) 971-8220 | | Kierulff Electronics | (714)220-6566 | Marshall Electronics | | Grand Rapids | | | El Monte | | Group | (305) 982-0661 | Arrow Electronics | (616) 243-0912 | | Marshall Electronics | | Orlando | | Livonia | | | Group | (818) 442-7204 | Marshall Electronics | | Marshall Electronics | | | Irvine | | Group | (305) 841-1878 | Group | (313) 525-5850 | | Marshall Electronics | | Palm Bav | | Minnesota | | | Group | (714) 458-5311 | Arrow Electronics | (305) 725-1480 | Edina | | | Anthem | (714) 768-4444 | St. Petersburg | | Arrow Electronics | (612) 830-1800 | | Milpitas | | Kierulff Electronics | (813)576-1966 | Kierulff Electronics | (612) 941-7500 | | Marshall Electronics | | Georgia | | | (012) 041-7000 | | Group | (408) 943-4600 | Norcross | | Plymouth Marshall Electronics | | | Hayward | | Arrow Electronics | (404) 449-8252 | Group | (612) 559-2211 | | Arrow Electronics | (415) 487-4600 | Kierulff Electronics | (404) 447-5252 | | (012) 000-2211 | | Sacramento | | Marshall Electronics | (404) 441-0202 | Missouri | | | Arrow Electronics | (916) 925-7456 | Group | (404) 923-5750 | St. Louis | (0.4.4) =0= 0000 | | Anthem | (916) 922-6800 | | (101)020 0100 | Arrow Electronics | (314) 567-6888 | | Rancho Cordova | | Illinois | | Kierulff Electronics | (314) 739-0855 | | Marshall Electronics | | Itasca | (040) 050 0500 | New Hampshire | | | Group | (916) 635-9700 | Kierulff Electronics | (312) 250-0500 | Manchester | | | San Diego | | Schaumburg | (0.4.0) 0.07 0.4.40 | Arrow Electronics | (603) 668-6968 | | Anthem Electronics | (619) 453-4871 | Arrow Electronics | (312) 397-3440 | New Jersey | | | Arrow Electronics | (619) 565-4800 | Marshall Electronics | (312) 400 0155 | Clifton | | | Kierulff Electronics | (619) 278-2112 | Group | (312) 490-0155 | Vantage Electronics | (201) 777-4100 | | Marshall Electronics | (040) 570 0000 | Indiana | | Fairfield | | | Group | (619) 578-9600 | Indianapolis | | Arrow Electronics | (201) 575-5300 | | San Jose | (100) 00= 105= | Arrow Electronics | (317) 243-9353 | Kierulff Electronics | (201) 575-6750 | | Anthem Electronics | (408) 295-4200 | Marshall Electronics | | Lionex | (201) 227-7960 | | Kierulff Electronics | (408) 971-2600 | Group | (317) 297-0483 | Marshall Electronics | | | Sunnyvale | //aa\=/ | | | Group | (201) 882-0320 | | Arrow Electronics | (408) 745-6600 | | | | | | Arrow Electronics | (514) 735-5511 | | | |--------------------------------|----------------|--|--| | Preico Electronics St. Laurent | (514) 389-8051 | | | | Zentronics Limited | (514) 737-9700 | | | (414) 784-8160 Waukesha Kierulff Electronics Kierulff Electronics Quality Components (918) 664-8812 (918) 252-7537 ## **Monolithic Memories Overseas Representatives and Distributors** #### **ARGENTINA** Electroquimica Delta Timoteo Gordillo 72 1408 Buenos Aires Argentina Phone: 9-011-641-3193 or 641-0449 Telex: 21212 AR EDELTA #### **AUSTRALIA** R & D Electronics Pty Ltd. 4 Florence St. Burwood, Vic. 3125 Phone: 61-3-288-8911 Telex: AA33288 Fax: 61-3-288-9168 #### R & D Electronics Pty Ltd. P.O. Box 57 Crows Nest, NSW 2065 Phone: 61-2-439-5488 Telex: AA25468 #### **AUSTRIA** Ing. Steiner Hummelgasse 14 1130 Wien Phone: 9-011-32-22-8274740 Telex: 135026 #### BELGIUM D & D Electronics PVBA 7E Olympiadelaan 93 2020 Antwerp Phone: 03-23-8277934 Telex: 73121 #### **BRAZIL** Itautec Componentes S.A. Largo de Arouche No. 24 9th Andar 01219 Sao Paulo Phone: 222-9200 Telex: 13087 Fax: 2783043 #### DENMARK C-88 Kokkedal Industripark 42A DK-2980 Kokkedal-Denmark Phone: 2-244888 Telex: 41198 CEIGTY DK #### **ENGLAND** Monolithic Memories Ltd. Monolithic House 1 Queens Road Farnborough Hampshire GU14 6DJ Phone: (0252) 517431 Telex: 858051 MONO UK G Fax: 44-252-521041 #### Analog Devices Ltd. Central Avenue East Molesey Surrey KT8 OSN Phone: 01-941-1066 Telex: 929962 ANALOGG #### Analog Devices Ltd. **Executive House** South Road Harlow Essex CM202BX Phone: 9-011-44-24-941-8611 Telex: 817169 #### Analog Devices Ltd. 5th Floor Hagley House Hagley Road Edgbaston Birmingham B168QG Phone: 021-455-9395 Telex: 339752 ANALOG G Macro Marketing Ltd. 396 Bath Road Slough Berkshire Phone: 9-011-44-6286-63011 Telex: 847083 #### Microlog Ltd. The Cornerstone The Broadway Woking Surrey GU21 5EZ Phone: (04862) 29551 Telex: 859219 ULOG G #### Rapid Recall Ltd. Rapid House Denmark Street High Wycombe **Bucks HP11 2ER** Phone 0494-26271 Telex: 837931 RAPIDG Fax: 21680 #### FINLAND Findip-Elektroniikka Instrumentarium Elektroniikka PO Roy 64 SF-02631-ESP00 Phone: 358-0-5281 Telex: 124426 HAVUL SF #### FRANCE Monolithic Memories France S.A.R.L. 8, Rue De L'Esterel SILIC 463 94613 Rungis Cedex Phone: 46-87-34-62 Telex: 45-60-57-25 #### Almex Zone industrielle d'Antony 48 rue de Aubepine B.P. 102 92164 Antony Cedex Phone: 9-011-(33)-1-46-66-21-12 Telex: 250067F Composants S.A. Avenue Gustave Eiffel B.P. 81 33605 Pessac Cedex Phone: (33) 56-36-40-40 Telex: 550696F FAX: (33) 56-07-64-41 Datadis S.A. 10-12 Rue Emile Landrin 92100 Boulogne Phone: 9-011-(33)-1-46-05-60-00 Telex: 201905F #### Dimel Le Marino Ave. Claude Farrere B.P. 1153 83058 Toulon Cedex Phone: (33) 94-41-49-63 Telex: 490093F Fax: (33)1-69-07-05-59 #### Generim Zone d'Activities de Courtaboeuf Avenue de la Baltique **B.P. Box 88** 91943 Les Ulis Cedex Phone: (33) 1-69-07-78-78 Telex: 691700F Fax: (33) 1-69-07-05-59 #### Generim 24 Avenue De La Houville Blanche B.P. 1-38170 Seyssinet Phone: 9-011-33-1-76-49-491449 Telex: 320000 #### Jermyn Zone Silic 585 73/79 Rue de Solets 94663 Rungis Cedex Phone: 9-011-(33)-45-60-04-00 Telex: 260967F Fax: (33)1-45-60-05-46 #### GERMANY Monolithic Memories, GmbH Mauerkircherstrasse 4/11 8000 Munich 80 Phone: 0-89-984961 Telex: 524385 MONO D Fax: 89-983162 ## Monolithic Memories Overseas Representatives and Distributors Astronic GmbH Winzerstrasse 47D 8000 Munich 80 Phone: 089-304011 Telex: 5216187 Dr. Dohrenberg Vertrießs & GmbH Bayreuther Strasse 3 1000 Berlin 30 Phone: 0-30-2138043 Telex: 184860 Electronic 2000 Vertrießs GmbH Neumarkter Strasse 57 8000 Munich 82 Phone: 089-434061 Telex: 522561 Nordelektronik GmbH KG Harksheiderweg 238-240 2085 Quickborn Phone: 04160-4031 Telex: 214299 Positron Bauelemente Vertriebs GmbH Benzstrasse 1 Postfach 1140 7016 Gerlingen-Stuttgart Phone: 07156-23051 Telex: 7245266 Mueller Wuppertal Vertrießs GmbH Vereinsstr. 17 5600 Wuppertal Phone: 0202-426016 Telex: 8591543 HONG KONG CET Ltd. 10/F Hua Hsia Bldg. 64-66 Gloucester Rd. Hong Kong Phone: 852-5-200922 Telex: 85148 CET HX Fax: 5-285764 INDIA Micro Aids India 26/1 Venkata Krishna Road **RA Puram** Madras 600028 Phone: 75757 Telex: 416517 TRUEIN Micro Aids International 501 D Vandell Way Campbell, CA 95008 Phone: (408) 866-7000 Telex: 499-3462 **IRELAND** Micro Marketing Ltd. Glenageary Office Park Glenageary County Dublin Fire Phone: 856325 Telex: 31584 (MMI EI) ISRAEL **Aviv Electronics** 12 Kehilat Venezia Tel Aviv 69101 Phone: 9-011-972-3-494450 Telex: 33572 MAVIVIL Fax: 3-494065 ITALY Comprel S.P.A. Viale Fulvio Testio 115 20092 Cinisello Balsamo (MI) Milano, Italy Phone: 2-6120641 Telex: 332484 JAPAN Monolithic Memories Japan KK Shinju Nomura Shoken Bldg SF 5-17-9 Shiniuku Shinjuku-Ku Tokyo 160 Phone: 81-3-207-3131 Telex: 232-3390 MMI KK J Fax: 81-3-207-3130 81-3-207-3139 Ado Electronic Industrial Co., Ltd. Bldg. Sasage 7F 4-6. Soto-Kanda, 2-chome Chiyoda-Ku, Tokyo, Japan 101 Phone: 03-257-1025 FAX: 03-257-1579 Comtecs Co., Ltd. 2-19-7 Higashi-Gotanda Shinagawa-Ku Tokyo 141 Phone: (03) 441-7100 Fax: (03) 441-7185 Internix Inc. Shinjuku Hamada Bldg. 7-4-7 Nishi-Shinjuku Shiniuku-Ku Tokyo 160 Phone: (03) 369-1101 Fax: (03) 366-8566 Nihon Denshikizai Co., Ltd. Sanyo Bldg. 15-22 Hiroshiba-Cho Suita-Shi Osaka 564 Phone: (06) 385-6707 Fax: (06) 330-6814 Synderdyne Inc. Ishibashi Bldg. 1-20-2 Dogenzaka Shibuva-Ku Tokyo 150 Phone: (03) 461-9311 Fax: (03) 461-9854 **Tokiwa & Company** 1-1-10 Omori Ohta-Ku Tokyo 143 Phone: (03) 766-6701 Fax: (03) 766-1300 Tokiwa & Company of Osaka 3-8-13 Emisu Naniwa-Ku Osaka 556 Phone: (06) 643-3521 Fax: (06) 631-6418 Tokyo Denshi Kagaku-Kizai Co., Ltd. Dempa Bldg, 3F 2-4-4 Soto Kanda Chiyoda-Ku Tokyo 101 Phone: (03) 257-1361 Fax: (03) 255-1978 **KOREA** Kortronics Enterprise Rm 307, 9-Dong, B-Block #604-I Guro-Dong, Guro-GU Seoul Phone: 635-1043 Telex: KORTRONK26759 Fax: 2-6750514 **NETHERLANDS** Alcom Electronics B.V. Postbus 358, 2900 AJ Capelle A. D. lissel Holland Esse Baan 1 Phone: 010-519533 Telex: 26160 NORWAY Henaco A/S P.O. Box 126 Kaldbakken Trondheimsveien 436 Ammerud Oslo 9 Phone: 02-162110 Telex: 76716 HENACO PORTUGAL Digicontrole Apartado 2-Sabugo 2715 Pero Pinheiro Phone: 35-1-292-3924 Telex: 62551 STUREP P. SINGAPORE MMI Integrated Circuits Pte. Ltd. 19 Keppel Road 11-06 Jit Poh Building Singapore 0208 Phone: 65-2257544 Telex: RS55650 MMI RS Fax: 65-2246113 ## **Monolithic Memories Overseas Representatives and Distributors** #### Dynamar Computer Systems (Pte) Ltd. 12 Lorong Bakar Batu #05-11 Kolam Ayer Industrial Park Singapore 1334 Phone: 65-7476188 Telex: RS26283 DYNAMA Fax: 65-747-2648 #### **SOUTH AFRICA** #### Promilect Pty Ltd. P.O. Box 1194 Randburg 2125 Phone: 9-011-27-11-886-2410 Telex: 424822 #### SOUTH AMERICA #### **Key Source** 637 East Arques Avenue Sunnyvale, CA 94086 Phone: 408-730-0607 ### **SPAIN** #### Amitron S.A. Avenida De Valladolid, 47A 28008 Madrid Phone: (34) 1-247-93-13 Telex: 45550 AMIT-E Fax: (34) 1-248-79-58 #### Sagitron Castello 25-2-E 28001 Madrid Phone: 1-402-6085 Telex: 43819 Fax: (34) 1-275-40-23 #### **SWEDEN** #### Naxab Box 4115 S 17104 Solna Phone: 08-985140 Telex: 17912 Fax: 08-7645451 #### **SWITZERLAND** #### Industrade AG Gemsenstrasse 2 CH 8021 Zurich Phone: 01-3632230 Telex: 56788 #### TAIWAN #### Sertek International, Inc. 3FL, #135 Chien Kuo N. Road, Sec 2 Taipei, Taiwan R.O.C. 10479 Phone: 886-2-501-0055 Telex: 23756 SERTEK Telex: 13579MSCGP Fax: 2-5012521 # Monolithic Mi Memories ## **Corporate Sales Offices** #### Americas Ionolithic Memodes, Inc. 2175 Mission College Blvd Santa Clara, CA 95054-159 Phone (408) 970-9700 TWX (910) 338-2374 TWX (910) 338-2376 TWX (910) 338-2405 #### France Monolithic Memories France S.A.R.L Silic 463 F. 94613 Rungis Cedex France Phone 46-87-34-62 Telex 202146 Fax 1-45-60-57-25 #### Japan Monolithic Memories Japan KK 5-17-9 Shinjuku-Ku Shinjuku Tokyo 160 Japan Phone 81-3-207-3131 Telex 232-3390 MMIKKJ Fax 81-3-207-3130 ## United Kingdom Monolithic Memories, Ltd. Monolithic House 1 Queens Road Farnborough, Hants England GU146DJ Phone 0252-517431 Telex 858051 MONO UKG Fax 44-252-521041 ## Singapore Monolithic Memories Singapore Pte., Ltd. 19 Kepple Road 11-06 Jit Poh Building Singapore 0208 Phone 65-2257544 Telex RS55650 MMI RS Fax 2246113 ## Germany Monolithic Memories, GmbH Mauerkircherstr 4 D 8000 Munich 80 West Germany Phone 89-984961 Telex 5-24385 MONO D Fax 983162 ## **Domestic Sales Offices** Monolithic Memories, Inc. 4040 Moorpark Avenue, No. 216 San Jose, CA 95117 (408) 249-7766 Monolithic Memories, Inc. 1800 East McFadden, No. 110 Santa Ana, CA 92705 (714) 543-8664 Monolithic Memories, Inc. One Energy Center, No. 250 300 East Shuman Blvd. Naperville, IL 60566 (312) 961-9200 #### Monolithic Memories, Inc. 12801 N. Central Exp., Suite No. 530, L.B. 35 Dallas, TX 75243 (214) 690-3812 #### Monolithic Memories, Inc. 40 Speen Street Framingham, MA 01701 (617) 875-7373 ## **Other Technical Support Offices** Canoga Park, CA — (818) 341-7257 Norcross, GA — (404) 447-0006 Cherry Hill, NJ — (609) 751-1288 Cincinatti, OH — (513) 866-8928 ## Technical Application Hotline: 800-222-9323 Applications for any integrated circuits contained in this publication are for illustration purposes only and Monolithic Memories makes no representation or warranty that such applications will be suitable for the use specified without further testing or modification. Devices sold by Monolithic Memories are covered by the warranty and patient indemnification provisions appearing in its devices from patient infringement in any described application or otherwise and no licenses of any kind are granted or implied under any patient or other right. Monolithic Memories makes no warranty of merchantability or fitness for any purposes. Monolithic Memories reserves the right to discontinue production and change specifications and prices at any time and without notice. Monolithic Memories is products are intended for use in normal commercial applications. Applications requiring extended temperature range, unusual environmental requirements, or high reliability applications, such as military, medical life-support or life-sustaining equipment are specifically NOT recommended without written Monolithic Memories' acceptance and additional merged, translated, stored, or used without the prior written consent of the copyright owner.