US20040263205A1 - Mask-programmable logic devices with programmable gate array sites - Google Patents

Mask-programmable logic devices with programmable gate array sites Download PDF

Info

Publication number
US20040263205A1
US20040263205A1 US10/817,766 US81776604A US2004263205A1 US 20040263205 A1 US20040263205 A1 US 20040263205A1 US 81776604 A US81776604 A US 81776604A US 2004263205 A1 US2004263205 A1 US 2004263205A1
Authority
US
United States
Prior art keywords
gate array
mask
programmable logic
programmable
logic
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US10/817,766
Inventor
Jonathan Park
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Altera Corp
Original Assignee
Altera Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Altera Corp filed Critical Altera Corp
Priority to US10/817,766 priority Critical patent/US20040263205A1/en
Publication of US20040263205A1 publication Critical patent/US20040263205A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/177Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
    • H03K19/17748Structural details of configuration resources
    • H03K19/17764Structural details of configuration resources for reliability
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/1733Controllable logic circuits
    • H03K19/1735Controllable logic circuits by wiring, e.g. uncommitted logic arrays
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/177Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
    • H03K19/17736Structural details of routing resources
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/177Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
    • H03K19/1778Structural details for adapting physical parameters
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/177Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
    • H03K19/1778Structural details for adapting physical parameters
    • H03K19/17796Structural details for adapting physical parameters for physical disposition of blocks

Definitions

  • the present invention relates to mask programmable logic devices, and more particularly, to mask programmable logic devices that include gate array sites.
  • Programmable logic devices are well known. Early programmable logic devices were one-time configurable. For example, configuration may have been achieved by “blowing”—i.e., opening—fusible links. Alternatively, the configuration may have been stored in a programmable read-only memory. These devices generally provided the user with the ability to configure the devices for “sum-of-products” (or “P-TERM”) logic operations. Later, such programmable logic devices incorporating erasable programmable read-only memory (EPROM) for configuration became available, allowing the devices to be reconfigured.
  • EPROM erasable programmable read-only memory
  • SRAM static random access memory
  • the user provides the manufacturer of the mask-programmable logic device with the specifications of a desired device, which may be the configuration file for programming a comparable conventional programmable logic device.
  • the manufacturer uses that information to add metallization layers to the partial device described above. Those additional layers program the logic elements by making certain connections within those elements, and also add interconnect routing between the logic elements.
  • Mask-programmable logic devices can also be provided with embedded random access memory blocks, as described above in connection with conventional programmable logic devices. In such mask-programmable logic devices, if the embedded memory is configured as read-only memory or P-TERM logic, that configuration also is accomplished using the additional metallization layers.
  • a conventional programmable logic device invariably includes resources that may not be used for a particular design.
  • resources that may not be used for a particular design.
  • conventional programmable logic devices grow ever larger as more functionality is built into them, increasing the size and power consumption of such devices. The routing of signals through the various switching elements as they travel from one routing and interconnect resource to another also slows down signals.
  • mask-programmable logic devices do not contain predefined routing resources. Therefore, the task of creating the customized interconnect for each design falls to the manufacturer in migrating the user's programmable device design to a mask-programmable device. This task is time consuming, and significantly slows down the process of migrating the design.
  • the migration process is further complicated by the fact that certain implementation-related problems such as timing and testability violations and signal attenuation are not apparent until after an initial mask-programmable device is fabricated and tested. Fixing such problems often requires redesign of the custom interconnect and/or reallocation of logic resources on the base device. This solution, however, often requires the fabrication of multiple devices to prove a given design and is therefore costly and time consuming.
  • configurable gate array sites are disposed in various locations throughout the device to correct buffering and timing violations that may result from the streamlining of a device's interconnection and logic resources.
  • Such gate array sites may be fabricated on a device substrate and each site may include a plurality of circuit elements (e.g., transistors) for forming fundamental logic gates.
  • a gate array cell that provides the desired function may be formed on a gate array site proximal to the point in the device where the violation manifests itself. This cell may be formed by interconnecting certain circuit elements found in the gate array site to obtain the desired logic function.
  • each gate array site may have some or all of its interconnections and contact points coupled to the substrate in order to reduce the cost of adding an additional contact layer mask.
  • FIG. 1 is a block diagram representation of the layout of a preferred embodiment of a mask-programmable logic device in accordance with the present invention
  • FIG. 2 is a cross-sectional view of the substrate and mask metallization layers of a mask-programmed device according to the present invention, incorporating the device of FIG. 1;
  • FIG. 3 is a block diagram illustrating one possible gate array arrangement in accordance with the present invention.
  • FIG. 4 is a block diagram illustrating another possible gate array arrangement in accordance with the present invention.
  • FIG. 5 is a block diagram illustrating another possible gate array arrangement in accordance with the present invention.
  • FIG. 6 is a block diagram illustrating one possible physical layout of a gate array site constructed in accordance with the principles of the present invention
  • FIG. 7 is a schematic diagram of the logic resources shown in FIG. 6;
  • FIG. 8 is an interconnection diagram illustrating one way of interconnecting the gate array site of FIG. 6 to obtain a two input NAND gate
  • FIG. 9 is a schematic diagram of the gate array site shown in FIG. 8.
  • FIG. 10 is a logic symbol representation of the gate array site shown in FIGS. 8 and 9;
  • FIG. 11 is an interconnection diagram illustrating one way of interconnecting the gate array site of FIG. 6 to obtain a two input NOR gate
  • FIG. 12 is a schematic diagram of the gate array site shown in FIG. 11;
  • FIG. 13 is a logic symbol representation of the gate array site shown in FIGS. 11 and 12;
  • FIG. 14 is a simplified block diagram of a mask-programmable logic device in accordance with the present invention illustrating programmed gate array sites interposed between certain logic resources on the mask-programmable logic device;
  • FIG. 15 is a simplified block diagram of an illustrative system employing a programmable device in accordance with the invention.
  • the present invention reduces the amount of time, cost, and effort required to produce a mask-programmable logic device by providing configurable gate array sites at various locations within the device.
  • the gate array sites may be used to correct various implementation problems that may arise during the migration of a circuit design previously implemented on another integrated circuit which may have contained different interconnection and logic resources.
  • one embodiment of a mask-programmable logic device 10 constructed in accordance with the present invention includes an array of logic regions similar to those found in the APEX ® family of programmable logic devices sold by Altera Corporation, of San Jose, Calif., the assignee hereof. Although an APEX® type architecture is shown, it will be understood that any type of PLD, CPLD (complex programmable logic device) or similar device may serve as a model for the base portion of the mask-programmable device, if desired.
  • the logic regions include, at the most basic level, “logic elements” (LEs) 11 , which may be, for example, look-up table-based logic regions having four inputs and the ability to have registered or unregistered outputs.
  • Logic elements 11 may be grouped into “logic array blocks” (LABs) 12 .
  • each LAB 12 includes ten LEs 11 , although other numbers of LEs 11 could be grouped into each LAB 12 .
  • the LABs may further be grouped into “groups of LABs′ (GOLs) 13 .
  • each GOL 13 includes seventeen LABs 12 , although other numbers of LABs 12 could be grouped into each GOL 13 .
  • Each GOL 13 preferably also includes an embedded memory block (referred to in the embodiment shown as an “embedded system block” or ESB) 14 .
  • Each GOL 13 also includes a plurality of gate array sites 15 , which may be used, e.g., for buffering or routing particular signals (described in more detail below).
  • GOLs 13 preferably are arranged in an orthogonal array, in rows and columns.
  • I/O elements preferably are located in regions 16 around the periphery of the array.
  • Other auxiliary circuits such as phase-locked loops (“PLLs”) for timing, etc., preferably are provided at convenient locations within the array, such as in region 17 , shown in about the center of the array.
  • PLLs phase-locked loops
  • FIG. 2 shows a cross section of mask-programmable or “base” device 10 after programming i.e., after it has become a “mask-programmed” device 20 , in which the substrate and other layers that make up the unprogrammed base device 10 are shown collectively at 21 (one transistor 25 is shown as representative). Additional layers of metallization 22 and dielectric 23 are used to program device 20 and create the custom interconnection networks that connect the components included in base device 10 . Commonly, an encapsulation layer 24 is provided to protect metallization and dielectric layers 22 and 23 .
  • Gate array sites 15 which are configurable to perform desired logic functions, may be disposed in a variety of ways throughout a mask programmable logic device to correct implementation problems while minimizing device size.
  • FIG. 3 is a block diagram illustrating how a plurality of gate array sites 15 may be physically disposed throughout GOL 13 of device 10 . As shown, gate array sites 15 are disposed in two rows running horizontally along the lower edge of GOL 13 . It will be appreciated that this arrangement is merely illustrative, and that many other arrangements are possible. For example, one or more columns of gate array sites 15 may be placed along the periphery of GOL 13 if desired. As shown in FIG. 4, these columns may be disposed along the leftmost LAB of GOL 13 .
  • FIG. 5 illustrates gate array sites 15 being placed throughout GOL 13 in both rows and columns. Gate array sites may also be placed between the boudary of LABs 12 and ESB 14 and/or I/O blocks 16 (not shown). Gate array sites 15 may also be randomly or uniformly placed throughout GOL 13 in patterns other than rows and columns if desired, e.g., in a checkerboard pattern (not shown).
  • the particular pattern of gate array sites used may be based on the type of interconnections needed to implement a specified circuit design. For example, if the circuit implementation requires a considerable number of interconnections between adjacent GOLs, then the majority of gate array sites 15 may be placed along the boundaries between the GOLs. In some embodiments, this may be done so that sites 15 favor a certain interconnection direction (e.g., two rows of sites 15 in the vertical direction and only one in the horizontal direction, etc.). On the other hand, if the specified circuit design requires significant amount of interconnections within the GOLs, then the majority of gate array sites may be placed between the LABs of that GOL with a reduced number around the periphery. Other embodiments may use a combination of these approaches to provide interconnection both between and within the GOLs on device 10 .
  • FIG. 6 a diagram illustrating one possible layout of gate array site 15 is shown.
  • This site may contain a plurality of circuit elements (e.g., N-well and P-well sites) suitable for constructing transistors.
  • Gate array site 15 may also include power supply pins. It will be understood that this embodiment is merely illustrative, and that many other arrangements with more or less circuit elements are possible. It will also be appreciated that other gate array site arrangements may have more, less, or no power supply pins at all, and that circuitry within the site may be powered by external sources.
  • Gate array site 15 may be considered to be “programmable” to the extent that interconnection conductors may be coupled to contact pins connected to the circuit elements within the site.
  • Such programmability allows a generic gate array site 15 to form a gate array cell with a specific function.
  • the actual contents of each individual gate array site may vary depending on the type of implementation problems it is intended to correct.
  • several different types of gate array sites 15 i.e., those with different contents may be disposed throughout base device 10 to provide optimal error correction.
  • FIG. 7 The equivalent circuitry that corresponds to the general layout of gate array site 15 in FIG. 6 is shown in FIG. 7. As shown, two P-channel type field effect transistors 30 and 40 , and two N-channel type field effect transistors 50 and 60 may be included in gate array site 15 . Transistors 30 and 40 each have drain terminals 32 and 42 , source terminals 34 and 44 , and gate terminals 36 and 46 , respectively. Transistors 50 and 60 each have drain terminals 52 and 62 , source terminals 54 and 64 , and gate terminals 56 and 66 , respectively. These elements are marked in FIG. 6 to clearly illustrate how each gate array site 15 may be constructed.
  • Vds and Vss are shown to have contact pins 70 and 80 , respectively. These power supplies may be used to provide bias voltages to the circuitry within the gate array site. It will be appreciated that the orientation of each of these pins with respect to gate array site 15 and the other pins is merely illustrative, and that many other arrangements are possible. For example, transistors 30 - 60 may be oriented linearly, as opposed to the box-like shape shown. Furthermore, power supply pins 70 and 80 need not necessarily be considered part of the gate array site. Power may be provided to gate array site 15 by external sources.
  • gate array site 15 may be interconnected to obtain a gate array cell with a desired function.
  • a gate array cell is a programmed (configured) gate array site.
  • FIG. 8 shows a particular arrangement of interconnections suitable for forming a two-input NAND gate from a gate array site 15 (illustrated as gate array cell 100 ).
  • gate array cell 100 has all of the same pins as gate array site 15 .
  • two input pins 180 and 182 designated as “I” pins
  • an output pin 184 designated as an “O” pin
  • I/O pins 180 , 182 , and 184 may provide and receive signals accordingly and may be individually coupled to any number of the aforementioned interconnections of gate array site 15 .
  • I/O pins are not shown in FIGS. 6 or 7 , however, because they are usually external from the site (i.e., the cell).
  • the I/O pins are usually coupled to gate array site 15 when forming a gate array cell 100 to perform a specific function using the signals supplied by the I/O pins.
  • interconnection segment 190 provides bias voltage to the cell by connecting Vds pin 70 to drain terminals 32 and 42 .
  • Interconnection segment 191 connects Vss pin 80 to source terminal 64 thereby connecting the drain of transistor 60 to the power plane (Vss may also be a ground plane in certain embodiments).
  • Interconnection segment 192 connects source terminals 34 and 44 to the drain terminal of transistor 50 (terminal 52 ).
  • Source terminal 54 is connected to drain terminal 62 by interconnection segment 193 to complete the circuit.
  • interconnection segment 194 connects gate terminals 36 and 56
  • interconnection segment 195 connects gate terminals 46 and 66 .
  • This arrangement allows gate array site 15 to form gate array cell 100 with the desired function of a two-input NAND gate by coupling input pin 180 to interconnection segment 194 , input pin 182 to interconnection segment 195 , and output pin 184 to interconnection segment 192 .
  • FIG. 9 is a schematic representation of gate array cell 100 shown in FIG. 8. Interconnection segments 190 - 195 are included in the schematic to clearly illustrate the interconnection of circuit elements within gate array cell 100 .
  • FIG. 10 is a logic block representation of the two-input NAND gate shown in FIG. 9. Included are I/O pins 180 , 182 , and 184 , and interconnections 192 , 194 , and 195 .
  • gate array site 15 may be configured to form a wide range of logic gates including, but not limited to, AND gates, OR gates, inverters, buffers, NOR gates, XOR gates, exclusive NOR gates, etc.
  • multiple logic array sites 15 may be combined together to produce more advanced logic circuits such as flip-flops, registers, counters, delay elements, adders, and the like.
  • FIG. 11 An example of another basic logic gate that may be constructed with gate array site 15 is shown in FIG. 11.
  • the interconnection arrangement shown is suitable for making a two-input NOR gate array cell (cell 200 ).
  • Different cells i.e., cells 100 and 200
  • interconnection segment 290 provides bias voltage to the cell by connecting Vds pin 70 to drain terminal 32 .
  • Interconnection segment 291 connects Vss pin 80 to source terminals 54 and 64 thereby connecting the drain of transistors 50 and 60 to the power plane (Vss may also be a ground plane in certain embodiments).
  • Interconnection segment 292 connects drain terminals 52 and 62 to the source terminal of transistor 40 (terminal 44 ).
  • Source terminal 34 is connected to drain terminal 42 by interconnection segment 293 to complete the circuit.
  • interconnection segment 294 connects gate terminals 36 and 56
  • interconnection segment 295 connects gate terminals 46 and 66 .
  • This arrangement allows gate array site 15 to form gate array cell 200 with the desired function of a two-input NOR gate by coupling input pin 280 to interconnection segment 294 , input pin 282 to interconnection segment 295 , and output pin 284 to interconnection segment 292 .
  • FIG. 12 is a schematic representation of gate array cell 200 shown in FIG. 11. Interconnection segments 290 - 295 are included in the schematic to clearly illustrate the interconnection of circuit elements within gate array cell 200 .
  • FIG. 13 is a logic block representation of the two-input NOR gate shown in FIG. 12. Included are I/O pins 280 , 282 , and 284 , and interconnections 292 , 294 , and 295 .
  • gate array sites 15 Another aspect of the present invention involves the physical interconnection of circuit elements within gate array sites 15 .
  • the drain, source, and gate contact points (i.e., pins) of transistors 30 - 60 are preferably fixed (shown generally in FIG. 2 as transistor 25 ) and extend into the metal 1 layer directly above the gate array site.
  • gate array sites 15 may be programmed by merely adding interconnect segments to the metal 1 layer to form a desired gate array cell. This approach is desirable because it eliminates the need to recreate multiple mask layers to interconnect the gate array sites. However, in certain embodiments having complicated circuit designs, it may be desirable to use multiple mask layers to interconnect the gate array sites.
  • gate array sites 15 may be used to correct a variety of problems including signal attenuation, routing errors, set up or hold time violations, testability violations, antenna violations etc.
  • gate array sites 15 may be programmed to function as buffers to amplify signals that have become attenuated due to long distance connections or excessive fanout.
  • some gate array sites 15 are configured as buffers that are connected to specific interconnection segments in the mask-programmed interconnect to interpose buffers between the desired portions of device 20 .
  • FIG. 14 shows gate array sites 15 configured as buffers 90 interposed between various logic elements 11 .
  • Gate array sites 15 may also be used to optimize interconnection paths to increase signal speed (a set-up time violation) or to act as delay elements in the case of a hold-time violation. To increase signal speed, gate array sites 15 may be connected to various interconnection segments in the mask-programmed interconnect to optimize routing thereby increasing signal speed (buffers may also be used to increase signal speed, slew rate, etc., if desired). In the case of hold time violations, gate array sites 15 configured as delay elements may be connected to specific interconnection segments in the mask-programmed interconnect to interpose the desired signal delay between the desired portions of device 10 .
  • Gate array sites 15 may also be used to provide visibility into the circuit design for testing purposes.
  • gate array sites 15 may be configured so that during testing feedback loops are eliminated and synchronous resets are disabled so that substantially all the nodes within device 10 are both controllable and visible through I/O portions 16 . This may be done for example, by configuring some gate array sites 15 to function as multiplexers and coupling them to certain dedicated I/O pins (not shown).
  • Mask-programmed logic device 20 based on mask-programmable device 10 described above may be used as part of a data processing system 300 shown in FIG. 15.
  • Data processing system 300 may include one or more of the following components: a processor 301 ; memory 302 ; I/O circuitry 303 ; and peripheral devices 304 . These components are coupled together by a system bus 305 and are populated on a circuit board 306 which is contained in an end-user system 307 .
  • System 300 can be used in a wide variety of applications, such as computer networking, data networking, instrumentation, video processing, digital signal processing, or any other application where the advantage of using mask-programmable logic is desirable.
  • Mask-programmed logic device 20 can be configured to perform a variety of different logic functions.
  • mask-programmed logic device 20 can be configured as a processor or controller that works in cooperation with processor 301 .
  • Mask-programmed logic device 20 may also be used as an arbiter for arbitrating access to a shared resource in system 300 .
  • mask-programmed logic device 20 can be configured as an interface between processor 301 and one of the other components in system 300 . It should be noted that system 300 is only exemplary, and that the true scope and spirit of the invention should be indicated by the following claims.
  • FIG. 10 Various technologies can be used to implement mask-programmable logic devices 10 as described above according to this invention.
  • gate array sites have been described herein as mask-programmable, other one-time programmable technologies may also be used to program gate array sites 15 (e.g., fuse-programmable technologies).

Abstract

A mask-programmable logic device that includes programmable gate array sites is provided. The gate array sites contain circuit elements that may be programmed to perform certain logic functions that correct problems associated with implementing a preexisting circuit design in mask-programmable device.

Description

  • This application is a continuation of application Ser. No. 10/113,324, filed Mar. 29, 2002, which is hereby incorporated by reference herein in its entirety.[0001]
  • BACKGROUND OF THE INVENTION
  • The present invention relates to mask programmable logic devices, and more particularly, to mask programmable logic devices that include gate array sites. [0002]
  • Programmable logic devices are well known. Early programmable logic devices were one-time configurable. For example, configuration may have been achieved by “blowing”—i.e., opening—fusible links. Alternatively, the configuration may have been stored in a programmable read-only memory. These devices generally provided the user with the ability to configure the devices for “sum-of-products” (or “P-TERM”) logic operations. Later, such programmable logic devices incorporating erasable programmable read-only memory (EPROM) for configuration became available, allowing the devices to be reconfigured. [0003]
  • Still later, programmable logic devices incorporating static random access memory (SRAM) elements for configuration became available. These devices, which also can be reconfigured, store their configuration information in a nonvolatile memory such as an EPROM, from which the configuration is loaded into the SRAM elements when the device is powered up. These devices generally provide the user with the ability to configure the devices for look-up table-type logic operations. At some point, such devices began to be provided with embedded blocks of random access memory that could be configured by the user to act as random access memory, read-only memory, or logic (such as P-TERM logic). [0004]
  • In all of the foregoing programmable logic devices, both the logic functions of particular logic elements in the device, and the interconnect for routing of signals between the logic elements, were programmable. Another variant is a mask-programmable logic device. With mask-programmable logic devices, instead of selling all users the same device, the manufacturer produces a partial device with a standardized arrangement of logic resources whose functions are not programmable by the user, and which lacks any routing or interconnect resources. [0005]
  • The user provides the manufacturer of the mask-programmable logic device with the specifications of a desired device, which may be the configuration file for programming a comparable conventional programmable logic device. The manufacturer uses that information to add metallization layers to the partial device described above. Those additional layers program the logic elements by making certain connections within those elements, and also add interconnect routing between the logic elements. Mask-programmable logic devices can also be provided with embedded random access memory blocks, as described above in connection with conventional programmable logic devices. In such mask-programmable logic devices, if the embedded memory is configured as read-only memory or P-TERM logic, that configuration also is accomplished using the additional metallization layers. [0006]
  • While conventional programmable logic devices allow a user to easily design a device to perform a desired function, a conventional programmable logic device invariably includes resources that may not be used for a particular design. Moreover, in order to accommodate general purpose routing and interconnect resources, and the switching resources that allow signals from any logic element to reach any desired routing and interconnect resource, conventional programmable logic devices grow ever larger as more functionality is built into them, increasing the size and power consumption of such devices. The routing of signals through the various switching elements as they travel from one routing and interconnect resource to another also slows down signals. [0007]
  • The advent of mask-programmable logic devices has allowed users to prove a design in a conventional programmable logic device, but to commit the production version to a mask-programmable logic device which, for the same functionality, can be significantly smaller and use significantly less power, because the only interconnect and routing resources are those actually needed for the particular design. In addition, there are no general purpose switching elements consuming space or power, or slowing down signals. [0008]
  • However, mask-programmable logic devices do not contain predefined routing resources. Therefore, the task of creating the customized interconnect for each design falls to the manufacturer in migrating the user's programmable device design to a mask-programmable device. This task is time consuming, and significantly slows down the process of migrating the design. The migration process is further complicated by the fact that certain implementation-related problems such as timing and testability violations and signal attenuation are not apparent until after an initial mask-programmable device is fabricated and tested. Fixing such problems often requires redesign of the custom interconnect and/or reallocation of logic resources on the base device. This solution, however, often requires the fabrication of multiple devices to prove a given design and is therefore costly and time consuming. [0009]
  • Accordingly, it would be desirable to provide a way to quickly and effectively solve implementation problems by providing resources that allow some modifications to be made to the original mask design that do not involve the costly or time consuming tasks of reallocating logic resources or redesigning the customized interconnect. [0010]
  • SUMMARY OF THE INVENTION
  • It is therefore an object of the present invention to provide a way to quickly and effectively solve implementation problems by providing resources that allow modifications to be made to the original mask design that do not involve the costly or time consuming tasks of reallocating logic resources or redesigning the customized interconnect. [0011]
  • This and other objects of the invention are accomplished in accordance with the principles of the present invention by providing configurable gate array sites disposed on an integrated circuit for correcting implementation problems. [0012]
  • In one embodiment of the present invention, configurable gate array sites are disposed in various locations throughout the device to correct buffering and timing violations that may result from the streamlining of a device's interconnection and logic resources. Such gate array sites may be fabricated on a device substrate and each site may include a plurality of circuit elements (e.g., transistors) for forming fundamental logic gates. To correct a particular problem, a gate array cell that provides the desired function may be formed on a gate array site proximal to the point in the device where the violation manifests itself. This cell may be formed by interconnecting certain circuit elements found in the gate array site to obtain the desired logic function. [0013]
  • In another aspect of the invention, each gate array site may have some or all of its interconnections and contact points coupled to the substrate in order to reduce the cost of adding an additional contact layer mask. [0014]
  • Further features of the invention, its nature and various advantages will be more apparent from the accompanying drawings and the following detailed description. [0015]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram representation of the layout of a preferred embodiment of a mask-programmable logic device in accordance with the present invention; [0016]
  • FIG. 2 is a cross-sectional view of the substrate and mask metallization layers of a mask-programmed device according to the present invention, incorporating the device of FIG. 1; [0017]
  • FIG. 3 is a block diagram illustrating one possible gate array arrangement in accordance with the present invention; [0018]
  • FIG. 4 is a block diagram illustrating another possible gate array arrangement in accordance with the present invention; [0019]
  • FIG. 5 is a block diagram illustrating another possible gate array arrangement in accordance with the present invention; [0020]
  • FIG. 6 is a block diagram illustrating one possible physical layout of a gate array site constructed in accordance with the principles of the present invention; [0021]
  • FIG. 7 is a schematic diagram of the logic resources shown in FIG. 6; [0022]
  • FIG. 8 is an interconnection diagram illustrating one way of interconnecting the gate array site of FIG. 6 to obtain a two input NAND gate; [0023]
  • FIG. 9 is a schematic diagram of the gate array site shown in FIG. 8; [0024]
  • FIG. 10 is a logic symbol representation of the gate array site shown in FIGS. 8 and 9; [0025]
  • FIG. 11 is an interconnection diagram illustrating one way of interconnecting the gate array site of FIG. 6 to obtain a two input NOR gate; [0026]
  • FIG. 12 is a schematic diagram of the gate array site shown in FIG. 11; [0027]
  • FIG. 13 is a logic symbol representation of the gate array site shown in FIGS. 11 and 12; [0028]
  • FIG. 14 is a simplified block diagram of a mask-programmable logic device in accordance with the present invention illustrating programmed gate array sites interposed between certain logic resources on the mask-programmable logic device; and [0029]
  • FIG. 15 is a simplified block diagram of an illustrative system employing a programmable device in accordance with the invention.[0030]
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • The present invention reduces the amount of time, cost, and effort required to produce a mask-programmable logic device by providing configurable gate array sites at various locations within the device. The gate array sites may be used to correct various implementation problems that may arise during the migration of a circuit design previously implemented on another integrated circuit which may have contained different interconnection and logic resources. [0031]
  • As seen in FIG. 1, one embodiment of a mask-[0032] programmable logic device 10 constructed in accordance with the present invention includes an array of logic regions similar to those found in the APEX ® family of programmable logic devices sold by Altera Corporation, of San Jose, Calif., the assignee hereof. Although an APEX® type architecture is shown, it will be understood that any type of PLD, CPLD (complex programmable logic device) or similar device may serve as a model for the base portion of the mask-programmable device, if desired.
  • As shown in FIG. 1, the logic regions include, at the most basic level, “logic elements” (LEs) [0033] 11, which may be, for example, look-up table-based logic regions having four inputs and the ability to have registered or unregistered outputs. Logic elements 11 may be grouped into “logic array blocks” (LABs) 12. In the embodiment shown, each LAB 12 includes ten LEs 11, although other numbers of LEs 11 could be grouped into each LAB 12. The LABs may further be grouped into “groups of LABs′ (GOLs) 13. In the embodiment shown, each GOL 13 includes seventeen LABs 12, although other numbers of LABs 12 could be grouped into each GOL 13. Each GOL 13 preferably also includes an embedded memory block (referred to in the embodiment shown as an “embedded system block” or ESB) 14. Each GOL 13 also includes a plurality of gate array sites 15, which may be used, e.g., for buffering or routing particular signals (described in more detail below).
  • As shown, [0034] GOLs 13 preferably are arranged in an orthogonal array, in rows and columns. Input/output (“I/O”) elements preferably are located in regions 16 around the periphery of the array. Other auxiliary circuits, such as phase-locked loops (“PLLs”) for timing, etc., preferably are provided at convenient locations within the array, such as in region 17, shown in about the center of the array.
  • FIG. 2 shows a cross section of mask-programmable or “base” [0035] device 10 after programming i.e., after it has become a “mask-programmed” device 20, in which the substrate and other layers that make up the unprogrammed base device 10 are shown collectively at 21 (one transistor 25 is shown as representative). Additional layers of metallization 22 and dielectric 23 are used to program device 20 and create the custom interconnection networks that connect the components included in base device 10. Commonly, an encapsulation layer 24 is provided to protect metallization and dielectric layers 22 and 23.
  • [0036] Gate array sites 15, which are configurable to perform desired logic functions, may be disposed in a variety of ways throughout a mask programmable logic device to correct implementation problems while minimizing device size. FIG. 3 is a block diagram illustrating how a plurality of gate array sites 15 may be physically disposed throughout GOL 13 of device 10. As shown, gate array sites 15 are disposed in two rows running horizontally along the lower edge of GOL 13. It will be appreciated that this arrangement is merely illustrative, and that many other arrangements are possible. For example, one or more columns of gate array sites 15 may be placed along the periphery of GOL 13 if desired. As shown in FIG. 4, these columns may be disposed along the leftmost LAB of GOL 13.
  • In yet another possible embodiment, FIG. 5 illustrates [0037] gate array sites 15 being placed throughout GOL 13 in both rows and columns. Gate array sites may also be placed between the boudary of LABs 12 and ESB 14 and/or I/O blocks 16 (not shown). Gate array sites 15 may also be randomly or uniformly placed throughout GOL 13 in patterns other than rows and columns if desired, e.g., in a checkerboard pattern (not shown).
  • The particular pattern of gate array sites used may be based on the type of interconnections needed to implement a specified circuit design. For example, if the circuit implementation requires a considerable number of interconnections between adjacent GOLs, then the majority of [0038] gate array sites 15 may be placed along the boundaries between the GOLs. In some embodiments, this may be done so that sites 15 favor a certain interconnection direction (e.g., two rows of sites 15 in the vertical direction and only one in the horizontal direction, etc.). On the other hand, if the specified circuit design requires significant amount of interconnections within the GOLs, then the majority of gate array sites may be placed between the LABs of that GOL with a reduced number around the periphery. Other embodiments may use a combination of these approaches to provide interconnection both between and within the GOLs on device 10.
  • In FIG. 6, a diagram illustrating one possible layout of [0039] gate array site 15 is shown. This site may contain a plurality of circuit elements (e.g., N-well and P-well sites) suitable for constructing transistors. Gate array site 15 may also include power supply pins. It will be understood that this embodiment is merely illustrative, and that many other arrangements with more or less circuit elements are possible. It will also be appreciated that other gate array site arrangements may have more, less, or no power supply pins at all, and that circuitry within the site may be powered by external sources. Gate array site 15 may be considered to be “programmable” to the extent that interconnection conductors may be coupled to contact pins connected to the circuit elements within the site. Such programmability allows a generic gate array site 15 to form a gate array cell with a specific function. The actual contents of each individual gate array site may vary depending on the type of implementation problems it is intended to correct. Furthermore, it will be understood that several different types of gate array sites 15 (i.e., those with different contents) may be disposed throughout base device 10 to provide optimal error correction.
  • The equivalent circuitry that corresponds to the general layout of [0040] gate array site 15 in FIG. 6 is shown in FIG. 7. As shown, two P-channel type field effect transistors 30 and 40, and two N-channel type field effect transistors 50 and 60 may be included in gate array site 15. Transistors 30 and 40 each have drain terminals 32 and 42, source terminals 34 and 44, and gate terminals 36 and 46, respectively. Transistors 50 and 60 each have drain terminals 52 and 62, source terminals 54 and 64, and gate terminals 56 and 66, respectively. These elements are marked in FIG. 6 to clearly illustrate how each gate array site 15 may be constructed.
  • In FIG. 7, two power supplies, Vds and Vss are shown to have [0041] contact pins 70 and 80, respectively. These power supplies may be used to provide bias voltages to the circuitry within the gate array site. It will be appreciated that the orientation of each of these pins with respect to gate array site 15 and the other pins is merely illustrative, and that many other arrangements are possible. For example, transistors 30-60 may be oriented linearly, as opposed to the box-like shape shown. Furthermore, power supply pins 70 and 80 need not necessarily be considered part of the gate array site. Power may be provided to gate array site 15 by external sources.
  • The contact points of [0042] gate array site 15 may be interconnected to obtain a gate array cell with a desired function. Generally speaking, a gate array cell is a programmed (configured) gate array site. FIG. 8 shows a particular arrangement of interconnections suitable for forming a two-input NAND gate from a gate array site 15 (illustrated as gate array cell 100). As depicted, gate array cell 100 has all of the same pins as gate array site 15. In this embodiment, two input pins 180 and 182 (designated as “I” pins) and an output pin 184 (designated as an “O” pin) are included. Input/Output (“I/O”) pins 180, 182, and 184 may provide and receive signals accordingly and may be individually coupled to any number of the aforementioned interconnections of gate array site 15. These I/O pins are not shown in FIGS. 6 or 7, however, because they are usually external from the site (i.e., the cell). The I/O pins are usually coupled to gate array site 15 when forming a gate array cell 100 to perform a specific function using the signals supplied by the I/O pins.
  • As shown in FIG. 8, [0043] interconnection segment 190 provides bias voltage to the cell by connecting Vds pin 70 to drain terminals 32 and 42. Interconnection segment 191 connects Vss pin 80 to source terminal 64 thereby connecting the drain of transistor 60 to the power plane (Vss may also be a ground plane in certain embodiments). Interconnection segment 192 connects source terminals 34 and 44 to the drain terminal of transistor 50 (terminal 52). Source terminal 54 is connected to drain terminal 62 by interconnection segment 193 to complete the circuit. Finally, interconnection segment 194 connects gate terminals 36 and 56, and interconnection segment 195 connects gate terminals 46 and 66. This arrangement allows gate array site 15 to form gate array cell 100 with the desired function of a two-input NAND gate by coupling input pin 180 to interconnection segment 194, input pin 182 to interconnection segment 195, and output pin 184 to interconnection segment 192.
  • FIG. 9 is a schematic representation of [0044] gate array cell 100 shown in FIG. 8. Interconnection segments 190-195 are included in the schematic to clearly illustrate the interconnection of circuit elements within gate array cell 100.
  • FIG. 10 is a logic block representation of the two-input NAND gate shown in FIG. 9. Included are I/O pins [0045] 180, 182, and 184, and interconnections 192, 194, and 195.
  • It will be appreciated that the interconnection arrangement shown in FIGS. 8 and 9 are merely illustrative, and that other arrangements, which may produce many other fundamental logic gates, are possible. For example, [0046] gate array site 15 may be configured to form a wide range of logic gates including, but not limited to, AND gates, OR gates, inverters, buffers, NOR gates, XOR gates, exclusive NOR gates, etc. Moreover it will be understood that multiple logic array sites 15 (or cell sites 100) may be combined together to produce more advanced logic circuits such as flip-flops, registers, counters, delay elements, adders, and the like.
  • An example of another basic logic gate that may be constructed with [0047] gate array site 15 is shown in FIG. 11. The interconnection arrangement shown is suitable for making a two-input NOR gate array cell (cell 200). Different cells (i.e., cells 100 and 200) may vary from one another only with respect to the interconnections used and the I/O pins that are coupled to these interconnections.
  • As shown in FIG. 11, [0048] interconnection segment 290 provides bias voltage to the cell by connecting Vds pin 70 to drain terminal 32. Interconnection segment 291 connects Vss pin 80 to source terminals 54 and 64 thereby connecting the drain of transistors 50 and 60 to the power plane (Vss may also be a ground plane in certain embodiments). Interconnection segment 292 connects drain terminals 52 and 62 to the source terminal of transistor 40 (terminal 44). Source terminal 34 is connected to drain terminal 42 by interconnection segment 293 to complete the circuit. Finally, interconnection segment 294 connects gate terminals 36 and 56, and interconnection segment 295 connects gate terminals 46 and 66. This arrangement allows gate array site 15 to form gate array cell 200 with the desired function of a two-input NOR gate by coupling input pin 280 to interconnection segment 294, input pin 282 to interconnection segment 295, and output pin 284 to interconnection segment 292.
  • FIG. 12 is a schematic representation of [0049] gate array cell 200 shown in FIG. 11. Interconnection segments 290-295 are included in the schematic to clearly illustrate the interconnection of circuit elements within gate array cell 200.
  • FIG. 13 is a logic block representation of the two-input NOR gate shown in FIG. 12. Included are I/O pins [0050] 280, 282, and 284, and interconnections 292, 294, and 295.
  • Another aspect of the present invention involves the physical interconnection of circuit elements within [0051] gate array sites 15. Referring to FIG. 8, the drain, source, and gate contact points (i.e., pins) of transistors 30-60 are preferably fixed (shown generally in FIG. 2 as transistor 25) and extend into the metal 1 layer directly above the gate array site. With this implementation, gate array sites 15 may be programmed by merely adding interconnect segments to the metal 1 layer to form a desired gate array cell. This approach is desirable because it eliminates the need to recreate multiple mask layers to interconnect the gate array sites. However, in certain embodiments having complicated circuit designs, it may be desirable to use multiple mask layers to interconnect the gate array sites.
  • As mentioned above, [0052] gate array sites 15 may be used to correct a variety of problems including signal attenuation, routing errors, set up or hold time violations, testability violations, antenna violations etc. For example, gate array sites 15 may be programmed to function as buffers to amplify signals that have become attenuated due to long distance connections or excessive fanout. In this case, some gate array sites 15 are configured as buffers that are connected to specific interconnection segments in the mask-programmed interconnect to interpose buffers between the desired portions of device 20. FIG. 14 shows gate array sites 15 configured as buffers 90 interposed between various logic elements 11.
  • [0053] Gate array sites 15 may also be used to optimize interconnection paths to increase signal speed (a set-up time violation) or to act as delay elements in the case of a hold-time violation. To increase signal speed, gate array sites 15 may be connected to various interconnection segments in the mask-programmed interconnect to optimize routing thereby increasing signal speed (buffers may also be used to increase signal speed, slew rate, etc., if desired). In the case of hold time violations, gate array sites 15 configured as delay elements may be connected to specific interconnection segments in the mask-programmed interconnect to interpose the desired signal delay between the desired portions of device 10.
  • [0054] Gate array sites 15 may also be used to provide visibility into the circuit design for testing purposes. For example, gate array sites 15 may be configured so that during testing feedback loops are eliminated and synchronous resets are disabled so that substantially all the nodes within device 10 are both controllable and visible through I/O portions 16. This may be done for example, by configuring some gate array sites 15 to function as multiplexers and coupling them to certain dedicated I/O pins (not shown).
  • Mask-programmed [0055] logic device 20 based on mask-programmable device 10 described above may be used as part of a data processing system 300 shown in FIG. 15. Data processing system 300 may include one or more of the following components: a processor 301; memory 302; I/O circuitry 303; and peripheral devices 304. These components are coupled together by a system bus 305 and are populated on a circuit board 306 which is contained in an end-user system 307.
  • [0056] System 300 can be used in a wide variety of applications, such as computer networking, data networking, instrumentation, video processing, digital signal processing, or any other application where the advantage of using mask-programmable logic is desirable. Mask-programmed logic device 20 can be configured to perform a variety of different logic functions. For example, mask-programmed logic device 20 can be configured as a processor or controller that works in cooperation with processor 301. Mask-programmed logic device 20 may also be used as an arbiter for arbitrating access to a shared resource in system 300. In yet another example, mask-programmed logic device 20 can be configured as an interface between processor 301 and one of the other components in system 300. It should be noted that system 300 is only exemplary, and that the true scope and spirit of the invention should be indicated by the following claims.
  • Various technologies can be used to implement mask-[0057] programmable logic devices 10 as described above according to this invention. For example, although gate array sites have been described herein as mask-programmable, other one-time programmable technologies may also be used to program gate array sites 15 (e.g., fuse-programmable technologies).
  • It will be understood that the foregoing is only illustrative of the principles of the invention, and that various modifications can be made by those skilled in the art without departing from the scope and spirit of the invention, and the present invention is limited only by the claims that follow. [0058]

Claims (1)

What is claimed is:
1. A mask-programmable logic device disposed on an integrated circuit comprising:
a plurality of mask-programmable logic regions disposed on a substrate of the integrated circuit;
a plurality of interconnection conductors coupled to the mask-programmable logic regions and disposed above the substrate for interconnecting the mask-programmable logic regions; and
a plurality of gate array sites disposed on the substrate, the gate array sites being programmable to perform at least one function that facilitates implementation of a circuit design on the mask programmable logic device.
US10/817,766 2002-03-29 2004-04-01 Mask-programmable logic devices with programmable gate array sites Abandoned US20040263205A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/817,766 US20040263205A1 (en) 2002-03-29 2004-04-01 Mask-programmable logic devices with programmable gate array sites

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/113,324 US6742172B2 (en) 2002-03-29 2002-03-29 Mask-programmable logic devices with programmable gate array sites
US10/817,766 US20040263205A1 (en) 2002-03-29 2004-04-01 Mask-programmable logic devices with programmable gate array sites

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/113,324 Continuation US6742172B2 (en) 2002-03-29 2002-03-29 Mask-programmable logic devices with programmable gate array sites

Publications (1)

Publication Number Publication Date
US20040263205A1 true US20040263205A1 (en) 2004-12-30

Family

ID=27804445

Family Applications (2)

Application Number Title Priority Date Filing Date
US10/113,324 Expired - Lifetime US6742172B2 (en) 2002-03-29 2002-03-29 Mask-programmable logic devices with programmable gate array sites
US10/817,766 Abandoned US20040263205A1 (en) 2002-03-29 2004-04-01 Mask-programmable logic devices with programmable gate array sites

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US10/113,324 Expired - Lifetime US6742172B2 (en) 2002-03-29 2002-03-29 Mask-programmable logic devices with programmable gate array sites

Country Status (3)

Country Link
US (2) US6742172B2 (en)
EP (1) EP1349282A3 (en)
JP (2) JP5051963B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9112495B1 (en) * 2013-03-15 2015-08-18 Mie Fujitsu Semiconductor Limited Integrated circuit device body bias circuits and methods

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6605962B2 (en) 2001-05-06 2003-08-12 Altera Corporation PLD architecture for flexible placement of IP function blocks
US6742172B2 (en) * 2002-03-29 2004-05-25 Altera Corporation Mask-programmable logic devices with programmable gate array sites
US7373567B2 (en) * 2004-05-26 2008-05-13 International Business Machines Corporation System and method of providing error detection and correction capability in an integrated circuit using redundant logic cells of an embedded FPGA
US7165230B2 (en) * 2004-06-02 2007-01-16 Altera Corporation Switch methodology for mask-programmable logic devices
BRPI0513689A (en) * 2004-07-27 2008-05-13 Easic Corp semiconductor devices, logic assemblies and semiconductor wafers
EP2996248B1 (en) 2007-12-29 2021-03-24 France Brevets Flexible layout for integrated mask-programmable logic devices and manufacturing process thereof

Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US526278A (en) * 1894-09-18 Sash-fastener
US5068603A (en) * 1987-10-07 1991-11-26 Xilinx, Inc. Structure and method for producing mask-programmed integrated circuits which are pin compatible substitutes for memory-configured logic arrays
US5212652A (en) * 1989-08-15 1993-05-18 Advanced Micro Devices, Inc. Programmable gate array with improved interconnect structure
US5550839A (en) * 1993-03-12 1996-08-27 Xilinx, Inc. Mask-programmed integrated circuits having timing and logic compatibility to user-configured logic arrays
US5815405A (en) * 1996-03-12 1998-09-29 Xilinx, Inc. Method and apparatus for converting a programmable logic device representation of a circuit into a second representation of the circuit
US5825202A (en) * 1996-09-26 1998-10-20 Xilinx, Inc. Integrated circuit with field programmable and application specific logic areas
US5874834A (en) * 1997-03-04 1999-02-23 Xilinx, Inc. Field programmable gate array with distributed gate-array functionality
US6118299A (en) * 1996-06-26 2000-09-12 Cypress Semiconductor Corp. Method and apparatus to generate mask programmable device
US6177844B1 (en) * 1999-01-08 2001-01-23 Altera Corporation Phase-locked loop or delay-locked loop circuitry for programmable logic devices
US6311316B1 (en) * 1998-12-14 2001-10-30 Clear Logic, Inc. Designing integrated circuit gate arrays using programmable logic device bitstreams
US6331790B1 (en) * 2000-03-10 2001-12-18 Easic Corporation Customizable and programmable cell array
US6490707B1 (en) * 2000-07-13 2002-12-03 Xilinx, Inc. Method for converting programmable logic devices into standard cell devices
US6515509B1 (en) * 2000-07-13 2003-02-04 Xilinx, Inc. Programmable logic device structures in standard cell devices
US6526563B1 (en) * 2000-07-13 2003-02-25 Xilinx, Inc. Method for improving area in reduced programmable logic devices
US6742172B2 (en) * 2002-03-29 2004-05-25 Altera Corporation Mask-programmable logic devices with programmable gate array sites

Family Cites Families (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS60177651A (en) * 1984-02-23 1985-09-11 Toshiba Corp Semiconductor device and manufacture thereof
JPS6124250A (en) * 1984-07-13 1986-02-01 Nippon Gakki Seizo Kk Semiconductor integrated circuit device
JPH02177364A (en) * 1988-10-14 1990-07-10 Nec Corp Semiconductor integrated circuit
JPH02191361A (en) * 1988-10-28 1990-07-27 Matsushita Electric Ind Co Ltd Integrated circuit
JPH05267457A (en) * 1992-03-24 1993-10-15 Kawasaki Steel Corp Semiconductor integrated circuit
JPH06125067A (en) * 1992-10-12 1994-05-06 Mitsubishi Electric Corp Semiconductor integrated circuit and designing method therefor
JPH07160757A (en) * 1993-12-13 1995-06-23 Nec Corp Fpga timing automatic adjustment system
TW396312B (en) * 1993-12-30 2000-07-01 At & T Corp Method and apparatus for converting field-programmable gate array implementations into mask-programmable logic cell implementations
JPH07168803A (en) * 1994-07-25 1995-07-04 Seiko Epson Corp Semiconductor device
JPH08221473A (en) * 1994-08-03 1996-08-30 Matsushita Electric Ind Co Ltd Semiconductor integrated circuit and its layout design method
US5892249A (en) * 1996-02-23 1999-04-06 National Semiconductor Corporation Integrated circuit having reprogramming cell
JP3420694B2 (en) * 1996-12-27 2003-06-30 株式会社東芝 Standard cell integrated circuit
US6075381A (en) * 1998-01-21 2000-06-13 Micron Electronics, Inc. Programmable logic block in an integrated circuit
US6404226B1 (en) * 1999-09-21 2002-06-11 Lattice Semiconductor Corporation Integrated circuit with standard cell logic and spare gates
US6774671B2 (en) * 1999-10-15 2004-08-10 Agilent Technologies, Inc. Multi-purpose transistor array
JP2002032423A (en) * 2000-07-13 2002-01-31 Hitachi Ltd Method and system for logic synthesis taking test easiness into account

Patent Citations (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US526278A (en) * 1894-09-18 Sash-fastener
US5068603A (en) * 1987-10-07 1991-11-26 Xilinx, Inc. Structure and method for producing mask-programmed integrated circuits which are pin compatible substitutes for memory-configured logic arrays
US5212652A (en) * 1989-08-15 1993-05-18 Advanced Micro Devices, Inc. Programmable gate array with improved interconnect structure
US5550839A (en) * 1993-03-12 1996-08-27 Xilinx, Inc. Mask-programmed integrated circuits having timing and logic compatibility to user-configured logic arrays
US5815405A (en) * 1996-03-12 1998-09-29 Xilinx, Inc. Method and apparatus for converting a programmable logic device representation of a circuit into a second representation of the circuit
US6118299A (en) * 1996-06-26 2000-09-12 Cypress Semiconductor Corp. Method and apparatus to generate mask programmable device
US6094065A (en) * 1996-09-26 2000-07-25 Xilinx, Inc. Integrated circuit with field programmable and application specific logic areas
US5825202A (en) * 1996-09-26 1998-10-20 Xilinx, Inc. Integrated circuit with field programmable and application specific logic areas
US6091262A (en) * 1997-03-04 2000-07-18 Xilinx, Inc. Field programmable gate array with mask programmable I/O drivers
US5874834A (en) * 1997-03-04 1999-02-23 Xilinx, Inc. Field programmable gate array with distributed gate-array functionality
US6242945B1 (en) * 1997-03-04 2001-06-05 Xilinx, Inc. Field programmable gate array with mask programmable I/O drivers
US6311316B1 (en) * 1998-12-14 2001-10-30 Clear Logic, Inc. Designing integrated circuit gate arrays using programmable logic device bitstreams
US6177844B1 (en) * 1999-01-08 2001-01-23 Altera Corporation Phase-locked loop or delay-locked loop circuitry for programmable logic devices
US6331790B1 (en) * 2000-03-10 2001-12-18 Easic Corporation Customizable and programmable cell array
US6490707B1 (en) * 2000-07-13 2002-12-03 Xilinx, Inc. Method for converting programmable logic devices into standard cell devices
US6515509B1 (en) * 2000-07-13 2003-02-04 Xilinx, Inc. Programmable logic device structures in standard cell devices
US6526563B1 (en) * 2000-07-13 2003-02-25 Xilinx, Inc. Method for improving area in reduced programmable logic devices
US6742172B2 (en) * 2002-03-29 2004-05-25 Altera Corporation Mask-programmable logic devices with programmable gate array sites

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9112495B1 (en) * 2013-03-15 2015-08-18 Mie Fujitsu Semiconductor Limited Integrated circuit device body bias circuits and methods
US9548086B2 (en) 2013-03-15 2017-01-17 Mie Fujitsu Semiconductor Limited Integrated circuit device body bias circuits and methods
US9853019B2 (en) 2013-03-15 2017-12-26 Mie Fujitsu Semiconductor Limited Integrated circuit device body bias circuits and methods

Also Published As

Publication number Publication date
JP2012143000A (en) 2012-07-26
US6742172B2 (en) 2004-05-25
JP5051963B2 (en) 2012-10-17
US20030188287A1 (en) 2003-10-02
EP1349282A2 (en) 2003-10-01
EP1349282A3 (en) 2005-08-10
JP2004040081A (en) 2004-02-05

Similar Documents

Publication Publication Date Title
US10339245B2 (en) Timing exact design conversions from FPGA to ASIC
US5825202A (en) Integrated circuit with field programmable and application specific logic areas
US7285982B2 (en) Configuration circuits for programmable logic devices
USRE45110E1 (en) MPGA products based on a prototype FPGA
US6747478B2 (en) Field programmable gate array with convertibility to application specific integrated circuit
US6888375B2 (en) Tileable field-programmable gate array architecture
US7342416B2 (en) Tileable field-programmable gate array architecture
EP1603240A2 (en) Switch methodology for mask-programmable logic devices
US6988258B2 (en) Mask-programmable logic device with building block architecture
JP2012143000A (en) Mask-programmable logic device with programmable gate array site
US7358766B2 (en) Mask-programmable logic device with programmable portions
US6701500B2 (en) Logic circuit module, method for designing a semiconductor integrated circuit using the same, and semiconductor integrated circuit

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION