# **ELattice** ### T-46-19-13 GAL6001 High Performance E<sup>2</sup>CMOS FPLA Generic Array Logic™ ### **FEATURES** ### HIGH PERFORMANCE E<sup>2</sup>CMOS<sup>9</sup> TECHNOLOGY - 30ns Maximum Propagation Delay - 27MHz Maximum Frequency - 12ns Max. Clock to Output Delay - --- TTL Compatible 16mA Outputs - UltraMOS\* Advanced CMOS Technology ### LOW POWER CMOS - 90mA Typical Icc ### • E2 CELL TECHNOLOGY - Reconfigurable Logic - Reprogrammable Cells - 100% Tested/Guaranteed 100% Yields - High Speed Electrical Erasure (<100ms) - 20 Year Data Retention ### • UNPRECEDENTED FUNCTIONAL DENSITY - 78 x 64 x 36 FPLA Architecture - 10 Output Logic Macrocelis - 8 Buried Logic Macrocells - 20 Input and I/O Logic Macrocelis. ### HIGH-LEVEL DESIGN FLEXIBILITY - **Asynchronous or Synchronous Clocking** - Separate State Register and Input Clock Pins - Functional Superset of Existing 24-pin PAL® and FPLA Devices ### • APPLICATIONS INCLUDE: - Sequencers - **State Machine Control** - **Multiple PLD Device Integration** ### DESCRIPTION Using a high performance E2CMOS technology, Lattice Semiconductor has produced a next-generation programmable logic device, the GAL6001. Having an FPLA architecture, known for its superior flexibility in state-machine design, the GAL6001 offers a high degree of functional integration and flexibility in a 24pin, 300-mil package. The GAL6001 has 10 programmable Output Logic Macrocells (OLMC) and 8 programmable Buried Logic Macrocells (BLMC). In addition, there are 10 Input Logic Macrocells (ILMC) and 10 I/O Logic Macrocells (IOLMC). Two clock inputs are provided for independent control of the input and output macrocells. Advanced features that simplify programming and reduce test time, coupled with E2CMOS reprogrammable cells, enable 100% AC, DC, programmability, and functionality testing of each GAL6001 during manufacture. This allows Lattice to guarantee 100% performance to specifications. In addition, data retention of 20 years and a minimum of 100 erase/write cycles are quaranteed. ### MACROCELL NAMES | ILMC | INPUT LOGIC MACROCELL | |-------|------------------------| | IOLMC | I/O LOGIC MACROCELL | | BLMC | BURIED LOGIC MACROCELL | | OLMC | OUTPUT LOGIC MACROCELL | ### PIN NAMES | I <sub>0</sub> - I <sub>10</sub> | INPUT | I/O/Q | BIDIRECTIONAL | |----------------------------------|--------------|----------------|---------------| | ICLK | INPUT CLOCK | V <sub>∞</sub> | POWER (+5) | | OCLK | OUTPUT CLOCK | GND | GROUND | ### PIN CONFIGURATION Copyright ©1992 Lattice Semiconductor Corp. GAL, E\*CIMOS and UltraMOS are registered trademarks of Lattice Semiconductor Corp. Generic Array Logic is a trademark of Lattice Semiconductor Corp. PAL is a registered trademark of Advanced Micro Devices, inc. The specifications and information herein are subject to change without notice. ### **GAL6001 ORDERING INFORMATION** ### **Commercial Grade Specifications** | Tpd (ns) | Fcik (MHz) | lcc (mA) | Ordering # | Package | |----------|------------|----------|-------------|--------------------| | 30 | 27 | 150 | GAL6001-30P | 24-Pin Plastic DIP | | | | 150 | GAL6001-30J | 28-Lead PLCC | | 35 | 22.9 | 150 | GAL6001-35P | 24-Pin Plastic DIP | | | • | 150 | GAL6001-35J | 28-Lead PLCC | ### PART NUMBER DESCRIPTION ## INPUT LOGIC MACROCELL (ILMC) AND I/O LOGIC MACROCELL (IOLMC) The GAL6001 features two configurable input sections. The ILMC section corresponds to the dedicated input pins (2-11) and the IOLMC to the I/O pins (14-23). Each input section is configurable as a block for asynchronous, latched, or registered inputs. Pin 1 (ICLK) is used as an enable input for latched macrocells or as a clock input for registered macrocells. Configurable input blocks provide system designers with unparalleled design flexibility. With the GAL6001, external registers and latches are not necessary. Both the iLMC and the IOLMC are block configurable. However, the ILMC can be configured independently of the IOLMC. The three valid macrocell configurations are shown in the macrocell equivalent diagrams on the following pages. ### OUTPUT LOGIC MACROCELL (OLMC) AND BURIED LOGIC MACROCELL (BLMC) The outputs of the OR array feed two groups of macrocells. One group of eight macrocells is buried; its outputs feed back directly into the AND array rather than to device pins. These cells are called the Buried Logic Macrocells (BLMC), and are useful for building state machines. The second group of macrocells consists of 10 cells whose outputs, in addition to feeding back into the AND array, are available at the device pins. Cells in this group are known as Output Logic Macrocells (OLMC). The Output and Buried Logic Macrocells are configurable on a macrocell by macrocell basis. Buried and Output Logic Macrocells may be set to one of three configurations: combinational, "D-type register with sum term (asynchronous) clock", or "D/E-type register." Output macrocells always have I/O capability, with directional control provided by the 10 output enable (OE) product terms. Additionally, the polarity of each OLMC output is selected through the "D" XOR. Polarity selection is available for BLMCs, since both the true and complemented forms of their outputs are available in the AND array. Polarity of all "E" sum terms is selected through the "E" XOR. When the macrocell is configured as a "D/E type registered", the register is clocked from the common OCLK and the register clock enable input is controlled by the associated "E" sum term. This configuration is useful for building counters and state-machines with state hold functions. When the macrocell is configured as a "D type register with a sum term clock", the register is always enabled and its "E" sum term is routed directly to the clock input. This permits asynchronous programmable clocking, selected on a register-by-register basis. Registers in both the Output and Buried Logic Macrocells feature a common RESET product term. This active high product term allows the registers to be asynchronously reset. Registers are reset to a logic zero. If connected to an output pin, a logic one will occur because of the inverting output buffer. There are two possible feedback paths from each OLMC. The first path is directly from the OLMC (this feedback is before the output buffer and always present). When the OLMC is used as an output, the second feedback path is through the IOLMC. With this dual feedback arrangement, the OLMC can be permanently buried (the associated OLMC pin is an input), or dynamically buried with the use of the output enable product term. The D/E registers used in this device offer the designer the ultimate in flexibility and utility. The D/E register architecture can emulate RS-, JK-, and T-type registers with the same efficiency as a dedicated RS-, JK-, or T-register. The three macrocell configurations are shown in the macrocell equivalent diagrams on the following pages. 5/92 ## ILMC AND IOLMC CONFIGURATIONS ILMC/IOLMC Generic Logic Block Diagram ### ILMC (Input Logic Macrocell) **JEDEC Fuse Numbers** | ISYN | LATCH | |------|-------| | 8218 | 8219 | ### IOLMC (I/O Logic Macrocell) **JEDEC Fuse Numbers** | ISYN | LATCH | |------|-------| | 8220 | 8221 | Lattice # Specifications GAL6001 ### ILMC AND IOLMC CONFIGURATIONS ### **Asynchronous Input** | ISYN | LATCH | |------|-------| | 1 | 1 | ### **Latched Input** | ISYN | LATCH | |------|-------| | 0 | 0 | ### **Registered Input** | ISYN | LATCH | |------|-------| | 0 | 1 | ### OLMC AND BLMC CONFIGURATIONS ### OLMC/BLMC Generic Logic Block Diagram ### **OLMC (Output Logic Macrocell) JEDEC Fuse Numbers** | OLMC | OCLK | OSYN | XORD | XORE | |------|------|------|------|------| | 0 | 8178 | 8179 | 8180 | 8181 | | 1 | 8182 | 8183 | 8184 | 8185 | | 2 | 8186 | 8187 | 8188 | 8189 | | 3 | 8190 | 8191 | 8192 | 8193 | | 4 | 8194 | 8195 | 8196 | 8197 | | 5 | 8198 | 8199 | 8200 | 8201 | | 6 | 8202 | 8203 | 8204 | 8205 | | 7 | 8206 | 8207 | 8208 | 8209 | | 8 | 8210 | 8211 | 8212 | 8213 | | 9 | 8214 | 8215 | 8216 | 8217 | ### **BLMC (Buried Logic Macrocell) JEDEC Fuse Numbers** | BLMC | OCLK | OSYN | XORE | |------|------|------|------| | 7 | 8175 | 8176 | 8177 | | 6 | 8172 | 8173 | 8174 | | 5 | 8169 | 8170 | 8171 | | 4 | 8166 | 8167 | 8168 | | 3 | 8163 | 8164 | 8165 | | 2 | 8160 | 8161 | 8162 | | 1 | 8157 | 8158 | 8159 | | 0 | 8154 | 8155 | 8156 | ### **OLMC AND BLMC CONFIGURATIONS** D/E Type Registered | OSYN(i) | OCKS(i) | |---------|---------| | 0 | 1 | Combinatorial | OSYN(i) | OCKS(i) | |---------|---------| | 1 | 0 | **D Type Register** with Sum Term **Asynchronous Clock** | OSYN(i) | OCKS(i) | |---------|---------| | 0 | 0 | **GAL6001 LOGIC DIAGRAM** T-46-19-13 # Lattice ### ••••• # Specifications GAL6001 # Specifications **GAL6001**Commercial ### ABSOLUTE MAXIMUM RATINGS(1) | Supply voltage V <sub>cc</sub> | 0.5 to +7V | |----------------------------------|------------| | Input voltage applied | | | Off-state output voltage applied | | | Storage Temperature | ~~ | | Ambient Temperature with | | Power Applied ......55 to 125°C 1.Stresses above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress only ratings and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied (while programming, follow the programming specifications). ### RECOMMENDED OPERATING COND. | Commercial Devices: | T-46-19-13 | |---------------------------------------|-----------------| | Ambient Temperature (T <sub>4</sub> ) | 0 to 75°C | | Supply voltage (V <sub>cc</sub> ) | | | with Respect to Ground | +4.75 to +5.25V | ### DC ELECTRICAL CHARACTERISTICS Over Recommended Operating Conditions (Unless Otherwise Specified) | 0/44501 | | Spending Conditions Consess Official Alex | i i | TYP.2 | MAY | UNITS | |-------------|-----------------------------------|-----------------------------------------------------------------------------------------|-----------|-------|-------|-------| | SYMBOL | PARAMETER | CONDITION | MIN. | I TP. | MAX. | UNITS | | VIL | Input Low Voltage | | Vss ~ 0.5 | _ | 0.8 | ٧ | | ViH | Input High Voltage | | 2.0 | _ | Vcc+1 | V | | liL. | Input or I/O Low Leakage Current | OV ≤ Vin ≤ Vil (MAX.) | | _ | -10 | μА | | Iн | Input or I/O High Leakage Current | V <sub>IH</sub> ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | _ | 10 | μА | | <b>V</b> OL | Output Low Voltage | IOL = MAX. Vin = VIL or VIH | | _ | 0.5 | V | | <b>V</b> он | Output High Voltage | IOH = MAX. Vin = VIL or VIH | 2.4 | _ | _ | V | | IOL | Low Level Output Current | | | _ | 16 | mA | | Юн | High Level Output Current | | - | - | -3.2 | mA | | los¹ | Output Short Circuit Current | Vcc = 5V | -30 | _ | -130 | mA | | Icc | Operating Power Supply Current | V <sub>IL</sub> = 0.5V V <sub>IH</sub> = 3.0V ftoggle = 15MHz<br>Outputs Open (no load) | - | 90 | 150 | mA | <sup>1)</sup> One output at a time for a maximum duration of one second. Vout = 0.5V was selected to avoid test problems caused by tester ground degradation. Guaranteed but not 100% tested. ### CAPACITANCE ( $T_a = 25$ C, f = 1.0 MHz) | SYMBOL | PARAMETER | MAXIMUM* | UNITS | TEST CONDITIONS | |------------------|-------------------|----------|-------|-----------------------------------| | C <sub>i</sub> | Input Capacitance | 8 | pF | $V_{\infty} = 5.0V, V_{i} = 2.0V$ | | C <sub>ivo</sub> | I/O Capacitance | 10 | pF | $V_{cc} = 5.0V, V_{po} = 2.0V$ | <sup>\*</sup>Guaranteed but not 100% tested. <sup>2)</sup> Typical values are at Vcc = 5V and TA = 25 °C # Lattice # Specifications **GAL6001 Commercial** ### **AC SWITCHING CHARACTERISTICS** T-46-19-13 ### **Over Recommended Operating Conditions** 47E D | | TEST | DESCRIPTION | ~ | 30 | ~ | 5 | UNITS | |--------------|----------------|----------------------------------------------------------|----------|----------|------|----------|-------| | PARAMETER | COND'. | DESCRIPTION | MIN. | MAX. | MIN. | MAX. | UNIIS | | <b>t</b> pd1 | 1 | Combinatorial Input to Combinatorial Output | _ | 30 | _ | 35 | ns | | <b>t</b> pd2 | 1 | Feedback or I/O to Combinatorial Output | | 30 | _ | 35 | ns | | <b>t</b> pd3 | 1 | Transparent Latch Input to Combinatorial Output | | 35 | | 40 | ns | | <b>t</b> co1 | 1 | Input Latch ICLK to Combinatorial Output Delay | | 35 | _ | 40 | ns | | tco2 | 1 | Input Reg. ICLK to Combinatorial Output Delay | | 35 | | 40 | ns | | tco3 | 1 | Output D/E Reg. OCLK to Output Delay | <u> </u> | 12 | | 13.5 | ns | | tco4 | 1 | Output D Reg. Sum Term CLK to Output Delay | | 35 | | 40 | ns | | <b>t</b> su1 | | Setup Time, Input before Input Latch ICLK | 2.5 | | 3.5 | _ | ns | | <b>t</b> su2 | _ | Setup Time, Input before Input Reg. ICLK | 2.5 | <u> </u> | 3.5 | | ns | | <b>t</b> su3 | | Setup Time, Input or Feedback before D/E Reg. OCLK | 25 | <u> </u> | 30 | | ns | | tsu4 | _ | Setup Time, Input or Feedback before D Reg. Sum Term CLK | 7.5 | <u> </u> | 10 | | ns | | <b>t</b> su5 | _ | Setup Time, Input Reg. ICLK before D/E Reg. OCLK | 30 | | 35 | _ | ns | | <b>t</b> su6 | _ | Setup Time, Input Reg. ICLK before D Reg. Sum Term CLK | 15 | _ | 17 | _ | ns | | <b>t</b> h1 | _ | Hold Time, Input after Input Latch ICLK | 5 | T - | 5 | _ | ns | | th2 | _ | Hold Time, Input after Input Reg. ICLK | 5 | | 5 | _ | ns | | <b>t</b> h3 | _ | Hold Time, Input or Feedback after D/E Reg. OCLK | -5 | | -5 | _ | ns | | <b>t</b> h4 | | Hold Time, Input or Feedback after D Reg. Sum Term CLK | 10 | | 12.5 | | ns | | fmax | _ | Maximum Clock Frequency, OCLK | 27 | | 22.9 | | MHz | | twh1 | _ | ICLK or OCLK Pulse Duration, High | 10 | _ | 10 | _ | ns | | twh2 | | Sum Term CLK Pulse Duration, High | 15 | | 15 | - | ns | | tw11 | _ | ICLK or OCLK Pulse Duration, Low | 10 | _ | 10 | | ns | | twi2 | | Sum Term CLK Pulse Duration, Low | 15 | | 15 | | ns | | tarw | | Reset Pulse Duration | 15 | | 15 | <u> </u> | ns | | <b>t</b> en | 2 | Input or I/O to Output Enabled | _ | 25 | | 30 | ns | | tdis | 3 | Input or I/O to Output Disabled | | 25 | _ | 30 | ns | | tar | 1 | Input or I/O to Asynchronous Reg. Reset | _ | 35 | _ | 35 | ns | | tarr1 | _ | Asynchronous Reset to OCLK Recovery Time | 20 | - | 20 | - | ns | | tarr2 | <del> -</del> | Asynchronous Reset to Sum Term CLK Recovery Time | 10 | - | 10 | - | ns | <sup>1)</sup> Refer to Switching Test Conditions section. ### **SWITCHING TEST CONDITIONS** T-46-19-13 | Input Pulse Levels | GND to 3.0V | |--------------------------------|---------------| | Input Rise and Fall Times | 3ns 10% - 90% | | input Timing Reference Levels | 1.5V | | Output Timing Reference Levels | 1.5V | | Output Load | See Figure | 3-state levels are measured 0.5V from steady-state active level. ### **Output Load Conditions (see figure)** | Test Condition | | Rı | R <sub>2</sub> | CL | |----------------|-------------|------|----------------|------| | | | 300Ω | 390Ω | 50pF | | 2 | Active High | ∞ | 390Ω | 50pF | | | Active Low | 300Ω | 390Ω | 50pF | | 3 | Active High | 00 | 390Ω | 5pF | | | Active Low | 300Ω | 390Ω | 5pF | C.L. INCLUDES JIG AND PROBE TOTAL CAPACITANCE T-46-19-13 ### ARRAY DESCRIPTION The GAL6001 contains two E<sup>2</sup> reprogrammable arrays. The first is an AND array and the second is an OR array. These arrays are described in detail below. ### **AND ARRAY** The AND array is organized as 78 inputs by 75 product term outputs. The 10 ILMCs, 10 IOLMCs, 8 BLMC feedbacks, 10 OLMC feedbacks, and ICLK comprise the 39 inputs to this array (each available in true and complement forms). 64 product terms serve as inputs to the OR array. The RESET product terms generates the RESET signal described in the Output and Buried Logic Macrocells section. There are 10 output enable product terms which allow device pins 14-23 to be bi-directional or tri-state. ### **OR ARRAY** The OR array is organized as 64 inputs by 36 sum term outputs. 64 product terms from the AND array serve as the inputs to the OR array. Of the 36 sum term outputs, 18 are data ("D") terms and 18 are enable/clock ("E") terms. These terms feed into the 10 OLMCs and 8 BLMCs, one "D" term and one "E" term to each. The programmable OR array offers unparalleled versatility in product term usage. This programmability allows from 1 to 64 product terms to be connected to a single sum term. A programmable OR array is more flexible than a fixed, shared, or variable product term architecture. ### **ELECTRONIC SIGNATURE WORD** An electronic signature (ES) is provided with every GAL6001 device. It contains 72 bits of reprogrammable memory that can contain user defined data. Some uses include user ID codes, revision numbers, or inventory control. The signature data is always available to the user independent of the state of the security cell. NOTE: The ES is included in checksum calculations. Changing the ES will alter the checksum. ### SECURITY CELL A security cell is provided with every GAL6001 device as a deterrent to unauthorized copying of the array patterns. Once programmed, this cell prevents further read access to the AND and OR arrays. This cell can be erased only during a bulk erase cycle, so the original configuration can never be examined once this cell is programmed. The Electronic Signature is always available to the user, regardless of the state of this control cell. ### **BULK ERASE** Before writing a new pattern into a previously programmed part, the old pattern must first be erased. This erasure is done automatically by the programming hardware as part of the programming cycle and takes only 50 milliseconds. ### **REGISTER PRELOAD** When testing state machine designs, all possible states and state transitions must be verified, not just those required during normal operations. This is because in system operation, certain events may occur that cause the logic to assume an illegal state: power-up, brown out, line voltage glitches, etc. To test a design for proper treatment of these conditions, a method must be provided to break the feedback paths and force any desired state (i.e., illegal) into the registers. Then the machine can be sequenced and the outputs tested for correct next state generation. All of the registers in the GAL6001 can be preloaded, including the ILMC, IOLMC, OLMC, and BLMC registers. In addition, the contents of the state and output registers can be examined in a special diagnostics mode. Programming hardware takes care of all preload timing and voltage requirements. ### LATCH-UP PROTECTION GAL6001 devices are designed with an on-board charge pump to negatively bias the substrate. The negative bias is of sufficient magnitude to prevent input undershoots from causing the circuitry to latch. Additionally, outputs are designed with n-channel pullups instead of the traditional p-channel pull-ups to eliminate any possibility of SCR induced latching. ### INPUT BUFFERS GAL devices are designed with TTL level compatible input buffers. These buffers, with their characteristically high impedance, load driving logic much less than traditional bipolar devices. This allows for a greater fan out from the driving logic. GAL6001 devices do not possess active pull-ups within their input structures. As a result, Lattice recommends that all unused inputs and tri-stated I/O pins be connected to another active input, $V_{cc}$ , or GND. Doing this will tend to improve noise immunity and reduce $I_{cc}$ for the device. # Lattice ## Specifications GAL6001 ### POWER-UP RESET T-46-19-13 Circuitry within the GAL6001 provides a reset signal to all registers during power-up. All internal registers will have their Q outputs set low after a specified time (tpr, 1µs MAX). As a result, the state on the registered output pins (if they are enabled) will always be high on power-up, regardless of the programmed polarity of the output pins. This feature can greatly simplify state machine design by providing a known state on power-up. The timing diagram for power-up is shown below. Because of the asynchronous nature of system power-up, some conditions must be met to quarantee a valid power-up reset of the GAL6001. First, the Vcc rise must be monotonic. Second, the clock input must be at static TTL level as shown in the diagram during power up. The registers will reset within a maximum of tpr time. As in normal system operation. avoid clocking the device until all input and feedback path setup times have been met. The clock must also meet the minimum pulse width requirements. ### DIFFERENTIAL PRODUCT TERM SWITCHING (DPTS) APPLICATIONS The number of Differential Product Term Switching (DPTS) for a given design is calculated by subtracting the total number of product terms that are switching from a Logical HI to a Logical LO from those switching from a Logical LO to a Logical HI within a 5ns period. After subtracting take the absolute value. DPTS restricts the number of product terms that can be switched simultaneously - there is no limit on the number of product terms that can be used. A software utility is available from Lattice Applications Engineering that will perform this calculation on any GAL6001 JEDEC file. This program, DPTS, and additional information may be obtained from your local Lattice representative or by contacting Lattice Applications Engineering Dept. (Tel: 503-681-0118 or 800-FASTGAL: FAX: 681-3037).