A three dimensional semiconductor device, comprising: a substrate including a plurality of circuits; a plurality of pads, each pad coupled to a circuit; and a memory array positioned above or below the substrate and coupled to a circuit to program the memory array.
| 
 | 8.  A method, comprising:
 forming a plurality of layers of a hard-wired device by using a first plurality of masks in common with a programmable device fabrication process, wherein said forming a plurality of layers includes:
 forming a programmable layer; and forming a pad layer; and forming a hard-wire layer of the hard-wired device by using a second plurality of masks omitted from the programmable device fabrication process, wherein the hard-wire layer is operable to hard-wire the programmable layer with a logical functionality. 1.  A method, comprising:
 forming a programmable layer of a hard-wired device by using a plurality of first masks in common with a programmable device fabrication process; forming a hard-wire layer of the hard-wired device by using a plurality of second masks omitted from the programmable device fabrication process, wherein the hard-wire layer is operable to hard-wire the programmable layer with a logical functionality; and forming a pad layer of the hard-wired device by using a plurality of third masks in common with the programmable device fabrication process. 15.  A method, comprising:
 forming a hard-wired device operable to provide a logical functionality in common with a programmable device fabrication process, wherein said forming a hard-wired device includes:
 using a plurality of first masks in common with the programmable device fabrication process to form a programmable layer; using a plurality of second masks omitted from the programmable device fabrication process to form a hard-wire layer operable to hard-wire the programmable layer with the logical functionality; and using a plurality of third masks in common with the programmable device fabrication process to form a pad layer. 2.  The method of  forming an interconnect layer of the hard-wired device by using a plurality of fourth masks in common with the programmable device fabrication process. 3.  The method of  forming an interconnect layer of the hard-wired device by using a plurality of masks that modify a characteristic associated with the programmable device fabrication process. 4.  The method of  5.  The method of  using a first semiconductor die to perform said forming a programmable layer; using a second semiconductor die to perform said forming a hard-wire layer; flipping the second semiconductor die to couple a top side of the second semiconductor die to the first semiconductor die to form a stacked arrangement; and using the stacked arrangement to perform said forming a pad layer. 6.  The method of  bonding the top side of the second semiconductor die to a top side of the first semiconductor die; or gluing the top side of the second semiconductor die to the top side of the first semiconductor die. 7.  The method of  9.  The method of  forming an interconnect layer of the hard-wired device by using a third plurality of masks in common with the programmable device fabrication process. 10.  The method of  forming an interconnect layer of the hard-wired device by using a plurality of masks that modify a characteristic associated with the programmable device fabrication process. 11.  The method of  12.  The method of  using a first semiconductor die to perform said forming a programmable layer; using a second semiconductor die to perform said forming a hard-wire layer; flipping the second semiconductor die to couple a top side of the second semiconductor die to the first semiconductor die to form a stacked arrangement; and using the stacked arrangement to perform said forming a pad layer. 13.  The method of  bonding the top side of the second semiconductor die to a top side of the first semiconductor die; or gluing the top side of the second semiconductor die to the top side of the first semiconductor die. 14.  The method of  16.  The method of  using a plurality of fourth masks in common with the programmable device fabrication process to form an interconnect layer. 17.  The method of  using a plurality of masks that modify a characteristic associated with the programmable device fabrication process to form an interconnect layer. 18.  The method of  19.  The method of  using a first semiconductor die to form the programmable layer; using a second semiconductor die to form the hard-wire layer; flipping the second semiconductor die to couple a top side of the second semiconductor die to the first semiconductor die to form a stacked arrangement; and using the stacked arrangement to form the pad layer. 20.  The method of  bonding the top side of the second semiconductor die to a top side of the first semiconductor die; or gluing the top side of the second semiconductor die to the top side of the first semiconductor die. | |||||||||||||||||||||||||||||
This application is a Continuation of and claims priority to U.S. patent application Ser. No. 15/620,142, filed on June 12, 2017, which is a Continuation of and claims priority to U.S. patent application Ser. No. 14/715,375, filed on May 18, 2015 (now U.S. Pat. No. 9,679,914), which is a Continuation of and claims priority to U.S. patent application Ser. No. 14/147,881, filed on Jan. 6, 2014 (now U.S. Pat. No. 9,070,668), which is a Continuation of and claims priority to U.S. patent application Ser. No. 11/986,023, filed on Nov. 19, 2007 (now U.S. Pat. No. 8,643,162), which all are hereby incorporated by reference in their entirety. This application is related to U.S. patent application Ser. No. 10/267,484, filed on Oct. 8, 2002 (now abandoned), U.S. patent application Ser. No. 10/267,511, filed on Oct. 8, 2002 (now U.S. Pat. No. 6,747,478), U.S. patent application Ser. No. 10/267,483, filed on Oct. 8, 2002 (now abandoned), U.S. patent application Ser. No. 10/762,627, filed on Jan. 23, 2004 (now U.S. Pat. No. 7,018,875), U.S. patent application Ser. No. 10/413,809, filed on Apr. 14, 2003 (now U.S. Pat. No. 6,855,988), U.S. patent application Ser. No. 10/413,810, filed on Apr. 14, 2003 (now U.S. Pat. No. 6,828,689), and U.S. patent application Ser. No. 11/986,024, filed on Nov. 19, 2007 (now U.S. Pat. No. 7,812,458), which all are hereby incorporated by reference in their entirety.
Embodiments relate to pads & pin-outs for multi-dimensional integrated circuits.
Integrated circuits (ICs) comprise complex circuit blocks, each circuit block further comprising a plurality of transistors. The transistors are normally constructed on a semiconductor substrate. Metal interconnects couple transistors. Pad structures are formed within the IC to couple the IC to external devices. A pad structure includes a metal pad to facilitate bonding of the IC in a printed-circuit-board (PCB). Within the IC, the metal pad couples to one or more circuits, typically input circuits or output circuits, to facilitate coupling of the external device to the IC. Thus a pad in a first IC couples to a pad in a second IC. Pad structures occupy a significant silicon area as each pad structure includes a metal pad, input or output buffers, electro-static-discharge (ESD) circuits, control circuits, clock circuits, registers, etc. Metal pads itself is very large to facilitate bonding. Thus the pad cost for a given plurality of ICs required in a reference system design is significant. Furthermore as pads couple between IC's, the I/O characteristics are extremely important to interface devices.
Traditionally, integrated circuit (IC) devices such as custom, semi-custom, or application specific integrated circuit (ASIC) devices have been used in electronic products to reduce cost, enhance performance or meet space constraints. However, the design and fabrication of custom or semi-custom ICs can be time consuming and expensive. The customization involves a lengthy design cycle during the product definition phase and high Non Recurring Engineering (NRE) costs during manufacturing phase. Further, should bugs exist in the custom or semi-custom ICs, the design/fabrication cycle has to be repeated, further aggravating the time to market and engineering cost. As a result, ASICs serve only specific applications and are custom built for high volume and low cost applications.
Another type of semi custom device called a Gate Array customizes modular blocks at a reduced NRE cost by synthesizing the design using a software model similar to the ASIC. The missing silicon level design verification results in multiple spins and lengthy design iterations.
In recent years there has been a move away from custom or semi-custom ICs towards field programmable components whose function is determined not when the integrated circuit is fabricated, but by an end user “in the field” prior to use. Off the shelf, generic Programmable Logic Device (PLD) or Field Programmable Gate Array (FPGA) products greatly simplify the design cycle. These products offer user-friendly software to fit custom logic into the device through programmability, and the capability to tweak and optimize designs to optimize silicon performance. The flexibility of this programmability is expensive in terms of silicon real estate, but reduces design cycle and upfront NRE cost to the designer. Most FPGA solutions mandate an external memory (boot-ROM) to store configuration data, thus exacerbating the solution cost. The FPGA to memory interface is via high silicon consuming pad structures.
FPGAs offer the advantages of low non-recurring engineering costs, fast turnaround (designs can be placed and routed on an FPGA in typically a few minutes), and low risk since designs can be easily amended late en in the product design cycle. It is only for high volume production runs that there is a cost benefit in using the more traditional approaches. However, the conversion from an FPGA implementation to an ASIC implementation typically requires a complete redesign. Such redesign is undesirable in that the FPGA design effort is wasted. An ASIC does not require configuration data and does not interface with a boot-ROM.
Compared to PLD and FPGA, an ASIC has hard-wired logic connections, identified during the chip design phase, and need no configuration memory cells. This is a large chip area and cost saving for the ASIC. Smaller ASIC die sizes lead to better performance. A full custom ASIC also has customized logic functions which take less gate counts compared to PLD and FPGA configurations of the same functions. Thus, an ASIC is significantly smaller, faster, cheaper and more reliable than an equivalent gate-count PLD or FPGA. The trade-off is between time-to-market (PLD and FPGA advantage) versus low cost and better reliability (ASIC advantage).
There is no convenient migration path from a PLD or FPGA used as a design verification and prototyping vehicle to the lower die size ASIC. All of the SRAM or Anti-fuse configuration bits and programming circuitry has no value to the ASIC. Programmable module removal from the PLD or FPGA and the ensuing layout and design customization is time consuming with severe timing variations from the original design. The pad structures play a major role in FPGA I/O interface characteristics, and matching those in a design conversion is not a simple exercise.
In one aspect, a pad system is provided for a three-dimensional semiconductor device includes a first module layer having a plurality of circuit blocks; and a second module layer positioned substantially above the first module layer, including a plurality of configuration circuits to control a portion of the circuit blocks.
In another aspect, a three dimensional semiconductor device comprises: a substrate including a plurality of circuits; a plurality of pads, each pad coupled to a said circuit; and a memory array positioned above or below the substrate coupled to a said circuit to program the memory array.
In yet another aspect, a semiconductor device includes a plurality of pads; a first layer including a memory array; and a second layer including input/output circuits coupled to the pads and positioned above or below the first layer, the second layer including one or more circuits coupled to the memory array to program the memory array.
Implementations of the above aspect may include one or more of the following. The memory array includes a memory element coupled to one or more programmable logic circuits on the second layer to configure the programmable logic circuits. The memory array comprises one of: random access memory to form an FPGA, a metal mask to form an ASIC. The pads are coupled to a ball grid array. The pads are coupled to leads in a package. The pads are positioned along a perimeter of a device. The pads are positioned on the top or bottom surface on a device. The pads have a predetermined position within the device. The second layer includes an input buffer to receive data from the pad to configure the memory array. The memory array can include fuses, antifuses, SRAM cells, DRAM cells, metal optional links, EPROMs, EEPROMs, flash, resistance modulating elements, magneto-electric elements, photo-electric elements and ferro-electric elements. The memory array controls a plurality of logic circuits positioned in a predetermined position. The area of the memory array substantially overlaps the area of one or more programmable logic circuits. The area of the memory array substantially under-laps the area of one or more programmable logic circuits. The memory array and the pads are positioned substantially above the programmable logic circuits. The memory array and the pads are positioned substantially below the programmable logic circuits. The second layer includes drivers to write data to the memory array. The first layer comprises drivers to write data to the memory array. The first layer can have sense amplifiers to read data from the memory array. The second layer can also have sense amplifiers to read data from the memory array. A driver circuit can be connected to the memory array to configure the memory array. The memory array can include one or more memory elements each coupled to one or more programmable logic elements to configure the programmable logic element.
In yet another aspect, a method for fabricating a 3D device includes forming a first layer having a memory array; forming a second layer above or below the first layer, the second layer including one or more circuits coupled to the memory array to configure the memory array; and forming a plurality of pads, wherein one or more pads are coupled to the second layer to provide input/output for the 3D device to program the memory array.
Implementations of the method may include one or more of the following. The memory array can be replaced by a metal pattern to convert an FPGA to an ASIC. The memory array can be programmed with a driver on the first layer. One or more programmable logic elements can be configured with configuration data stored in the memory array. The process includes depositing thin film transistors on the first layer. The process also includes depositing the first layer above a substrate. The second layer can be deposited above a substrate.
Other implementations may include one or more of the following. The configuration circuits can be memory elements. Each memory element can be a transistor or a diode or a group of electronic devices. The memory elements can be thin film devices such as thin film transistors (TFT) or diodes. The memory element can be selected from the group consisting of volatile or non volatile memory elements. The memory element can also be selected from the group of fuses, antifuses, SRAM cells, DRAM cells, metal optional links, EPROMs, EEPROMs, flash, resistance modulating elements, magneto-electric elements, photo-electric elements and ferro-electric elements. One or more redundant memory cells can be provided for controlling the same circuit block. A third module layer can be formed substantially above the first and second module layer, wherein interconnect and routing signals are formed to connect the circuit blocks within the first and second module layers. The third module layer can be formed substantially below the first and second module layer. Alternatively, third and fourth module layers, wherein interconnect and routing signals are formed can be positioned above and below the second module layer respectively. The circuit block can contain a programmable logic block which responds to input data signals and develops corresponding complete or partial output logic signals, and registers to store the logic signals and either outputting them to output terminals or returning them as inputs to additional programmable logic blocks. The programmable logic blocks can contain pass gate logic, multiplexer logic, truth table logic, or AND/OR logic blocks.
Implementations of the above aspect may further include one or more of the following. The memory can be implemented using a TFT process technology that contains one or more of replaceable Fuses, Anti-fuses and SRAM elements. The process implementation is possible with any process technology where EPROM, EEPROM, Flash, Ferro-Electric or any other programmable element is vertically integrated.
In a second aspect, a multi-dimensional semiconductor device includes a first module layer having a plurality of circuit blocks formed on a first plane; and a second module layer formed on a second plane, including a plurality of configuration circuits formed to control a portion of the circuit blocks.
In a third aspect, a system includes a processor; data storage devices coupled to the processor; and a three-dimensional semiconductor device coupled to the processor, the 3D semiconductor device having a first module layer having a plurality of circuit blocks formed on a first plane and a second module layer formed on a second plane, including a plurality of configuration circuits formed to control a portion of the circuit blocks.
In a fourth aspect, a multi-dimensional semiconductor device includes a plurality of circuit blocks formed on a substrate; and a plurality of configuration circuits formed substantially above the substrate to control at least one circuit block.
Implementation of the fourth aspect may include one or more of the following. The configuration circuit includes a predetermined conductive pattern to control the circuit blocks. The configuration circuits can be memory elements with one device selected from the following: diode, transistor, thin film device, thin film resistor, thin film capacitor, thin film transistor (TFT). The memory element can be selected from the group consisting of volatile or non volatile memory elements. The memory element can also be selected from a group of fuse links, antifuse capacitors, SRAM cells, DRAM cells, metal optional links, EPROM cells, EEPROM cells, flash cells, resistance modulating elements, magneto-electric elements, photo-electric elements and ferro-electric elements.
Implementations of the above aspects may include one or more of the following. The IC product is re-programmable in its initial stage with turnkey conversion to an ASIC. The IC has the end ASIC cost structure and FPGA re-programmability. The IC product offering occurs in two phases: the first stage is a generic FPGA that has re-programmability containing a programmable module, and the second stage is an ASIC with the entire programmable module replaced by 1 to 2 customized hard-wire masks. There is no change to pads and circuits coupled to pads in the change from FPGA to ASIC—thus no I/O characteristics are altered. Peripheral devices couple to FPGA and ASIC canonicals without changes in interface properties.
A series product families can be provided with a modularized programmable element in an FPGA version followed by a turnkey custom ASIC with the same base die with 1-2 custom masks. The vertically integrated programmable module does not consume valuable silicon real estate of a base die. Furthermore, the design and layout of these product families adhere to removable module concept: ensuring the functionality and timing of the product in its FPGA and ASIC canonicals. These IC products can replace existing PLD and FPGA products and compete with existing Gate Arrays and ASIC's in cost and performance.
Advantages of the IC may include one or more of the following. An easy turnkey customization of an ASIC from an original smaller PLD or FPGA would greatly enhance time to market, performance, low cost and better reliability.
In the following detailed description of the invention, reference is made to the accompanying drawings which form a part hereof, and in which is shown, by way of illustration, specific embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention. Other embodiments may be utilized and structural, logical, and electrical changes may be made without departing from the scope of the present invention.
Definitions: The terms “wafer” and “substrate” used in the following description include any structure having an exposed surface with which to form the integrated circuit (IC) structure of the invention. The term substrate is understood to include semiconductor wafers. The term substrate is also used to refer to semiconductor structures during processing, and may include other layers that have been fabricated thereupon. Both wafer and substrate include doped and undoped semiconductors, epitaxial semiconductor layers supported by a base semiconductor or insulator, SOI material as well as other semiconductor structures well known to one skilled in the art. The term “conductor” is understood to include semiconductors, and the term “insulator” is defined to include any material that is less electrically conductive than the materials referred to as conductors. Thus every IC includes a substrate.
The term “module layer” includes a structure that is fabricated using a series of predetermined process steps. The boundary of the structure is defined by a first process step, one or more intermediate process steps, and a final process step. The resulting structure is formed on a substrate. A cross-section of a semiconductor device may be used to identify module layer boundaries. It is understood that some processing steps such as resist patterning and cleans do not leave structural imprints to a module layer. It is further understood that some processing steps such deposition and etching leave structural imprints in a module layer. Thus a module layer includes processing steps that may or may not make a structural imprint.
The term “pass-gate” and “switch” refers to a structure that can pass a signal when on, and block signal passage when off A pass-gate connects two points when on, and disconnects two points when off. A pass-gate couples two points when on, and decouples two points when off. A pass-gate can be a floating-gate transistor, an NMOS transistor, a PMOS transistor or a CMOS transistor pair. The gate electrode of transistors determines the state of the connection. A CMOS pass-gate requires complementary signals coupled to NMOS and PMOS gate electrodes. A control logic signal is connected to gate electrode of a transistor for programmable logic. A pass-gate can be a conductivity modulating element. The conductivity may be made to change between a sufficiently conductive state and a sufficiently nonconductive state by a configuration means. The configurable element may comprise a chemical, magnetic, electrical, optical, and ferroelectric or any other property that allows the element to change its conductivity between said two states.
The term “configuration circuit” includes one or more configurable elements and connections that can be programmed for controlling one or more circuit blocks in accordance with a predetermined user-desired functionality. The configuration circuit includes the memory element and the access circuitry, herewith called memory circuitry, to modify said memory element. A memory element in the configuration circuit is coupled to a programmable circuit block to configure the circuit block. Thus a configuration circuit is different from traditional circuits in memory devices. Configuration circuit does not include the logic pass-gate controlled by said memory element. In one embodiment, the configuration circuit includes a plurality of memory elements to store instructions to configure an FPGA. In another embodiment, the configuration circuit includes a first selectable configuration where a plurality of memory elements is formed to store instructions to control one or more circuit blocks. The configuration circuit includes a second selectable configuration with a predetermined conductive pattern formed in lieu of the memory circuit to control substantially the same circuit blocks. The memory circuit includes elements such as diode, transistor, resistor, capacitor, metal link, among others. The memory circuit also includes thin film elements. In yet another embodiment, the configuration circuit includes a predetermined conductive pattern comprising one or more of via, resistor, capacitor or other suitable ROM circuits in lieu of RAM circuits to control circuit blocks. Configuration circuit should not be confused with memory circuits in memory devices.
The term “horizontal” as used in this application is defined as a plane parallel to the conventional plane or surface of a wafer or substrate, regardless of the orientation of the wafer or substrate. The term “vertical” refers to a direction perpendicular to the horizontal direction as defined above. Prepositions, such as “on”, “side”, “higher”, “lower”, “over” and “under” are defined with respect to the conventional plane or surface being on the top surface of the wafer or substrate, regardless of the orientation of the wafer or substrate.
Fabrication of the IC shown in 
Fabrication of the IC shown in 
During the customization from FPGA to ASIC, the base die and the data in those remaining mask layers do not change making the logistics associated with chip manufacture simple. Removal of the SRAM (or any other memory) module provides a low cost standard logic process for the final ASIC construction with the added benefit of a smaller die size. In a first embodiment, the design timing is unaffected by this migration as lateral metal routing and silicon transistors are untouched. In a second embodiment the ASIC timing is deliberately made faster by reducing wire loading and resistances associated with metal traces. In a third embodiment the metal trace loading and resistance is reduced to obtain a significant power reduction in the ASIC migration. In all cases, software verification and the original FPGA design methodology provide a guaranteed final ASIC solution to the user. A full disclosure of the ASIC migration from the original FPGA is in the co-pending incorporated by reference applications discussed above.
In yet another embodiment of a programmable multi-dimensional semiconductor device, a first module layer is fabricated having a plurality of circuit blocks formed on a first plane. The programmable multi-dimensional semiconductor device also includes a second module layer formed on a second plane. A plurality of configuration circuits is then formed to store instructions to control a portion of the circuit blocks.
Next, details of the circuit blocks 204, the configuration circuit 208, and the wiring and/or routing circuit 524 in 
A variety of digital or analog circuits can be used in circuit blocks 204. These circuit blocks include programmable logic blocks to allow user customization of logic. In one embodiment, programmable logic blocks are provided to respond to input data signals. The programmable logic blocks develop corresponding complete or partial output logic signals. Registers are used to store the output logic signals and either outputting them to output terminals or returning them as inputs to additional programmable logic blocks. The registers themselves can be programmable, allowing those to be configured such as T flip-flops, JK flip-flops, or any other register. The logic blocks may contain no registers, or the registers may be programmed to be by-passed to facilitate combinational logic implementation. The programmable logic block can be selected from one of a pass gate logic, a multiplexer logic, a truth table logic, or an AND/OR logic. 
In yet other embodiments, the circuit block 204 contains a RAM/ROM logic block consisting of “logic element tree” or “P-Term logic array” blocks that perform logic functions. 
F=/A*/B*S0+/A*B*S1+A*/B*S2+A*B*S3 (/A means not A).
The truth table logic (LUT) values are represented by S0, S1, S2 and S3. The realization is done through six inverters collectively designated 840 and eight pass transistors collectively designated 830. Logic values are stored in 4 programmable registers. These programmable registers are contained in the configuration circuits as part of configuration memory.
In another embodiment, the programmable logic block can be a programmable microprocessor block. The microprocessor can be selected from third party IP cores such as: 8051, Z80, 68000, MIPS, ARM, and PowerPC. These microprocessor architectures include superscalar, Fine Grain Multi-Threading (FGMT) and Simultaneous Multi-Threading (SMT) that support Application Specific Packet Processing (ASPP) routines. To handle Programmable Network Interface (PNI) the processor can contain hardware and software configurability. Hardware upgradeability can be greatly enhanced in microprocessors embedded in PLD's by making use of the available logic content of the PLD device. Programmable features can include varying processor speed, cache memory system and processor configuration, enhancing the degree of Instruction Level Parallelism (ILP), enhancing Thread level parallelism (TLP). Such enhancements allow the user to optimize the core processor to their specific application. Cache parameters such as access latency, memory bandwidth, interleaving and partitioning are also programmable to further optimize processor performance and minimize cache hit miss rates. Additionally, the processor block can be a Very Long Instruction Word (VLIW) processor to handle multimedia applications. The processor block can include a cache controller to implement a large capacity cache as compared with an internal cache.
While a PLD can be configured to do DSP functions, the programmable logic block can also contain a digital signal processor (DSP), which is a special purpose processor designed to optimize performance for very high speed digital signal processing encountered in wireless and fiber-optic networks. The DSP applications can include programmable content for cache partitioning, digital filters, image processing and speech recognition blocks. These real-time DSP applications contain high interrupt rates and intensive numeric computations best handled by hardware blocks. In addition, the applications tend to be intensive in memory access operations, which may require the input and output of large quantities of data. The DSP cache memory may be configured to have a “Harvard” architecture with separate, independent program and data memories so that the two memories may be accessed simultaneously. This architecture permits an instruction and an operand to be fetched from memory in a single clock cycle. A modified Harvard architecture utilizes the program memory for storing both instructions and operands to achieve full memory utilization. The program and data memories are often interconnected with the core processor by separate program and data buses. When both instructions and operands (data) are stored in a single program memory, conflicts may arise in fetching data with the next instruction. Such conflicts have been resolved in prior art for DSP's by providing an instruction cache to store conflicting instructions for subsequent program execution.
In yet another embodiment, programmable logic block can contain software programmability. These software functions are executed in DSP, ARM, or MIPS type inserted IP cores, or an external host CPU. Accelerators connected by a configurable SRAM switching matrix enhance the computation power of the processors. The microprocessor has local permanent SRAM memory to swap, read, and write data. The switch matrix is pre-designed to offer both hard-wire and programmable options in the final ASIC. In this situation, the circuit block 104 can be a functional block that performs well-defined, commonly-needed function, such as special D/A or A/D converter, standard bus interface, or such block that implements special algorithms such as MPEG decode. The special algorithms implemented can be hardware versions of software. For example, algorithms relating to digital radio or cellular telephone such as WCDMA signal processing can be implemented by the functional block. Other functional blocks include PCI, mini-PCI, USB, UART blocks that can be configured by specifying the SRAM logic blocks.
In yet another embodiment, the circuit block 204 can be memory such as a register file, cache memory, static memory, or dynamic memory. A register file is an array of latches that operate at high speed. This register length counter may be programmable by the user. A cache memory has a high access throughput, short access latency and a smaller capacity as compared with main memory. The cache memory may be programmable to partition between the different requirements of the system design. One such need is the division between L1 and L2 cache requirements for networking applications. The memory can also be static random access memory or (SRAM) device with an array of single port, or multi-port addressable memory cells. Each cell includes a four transistor flip-flop and access transistors that are coupled to input/output nodes of the flip-flop. Data is written to the memory cell by applying a high or low logic level to one of the input/output nodes of the flip-flop through one of the access transistors. When the logic level is removed from the access transistor, the flip-flop retains this logic level at the input/output node. Data is read out from the flip-flop by turning on the access transistor. The memory can also be dynamic random access memory (DRAM). Generally, a DRAM cell consists of one transistor and a capacitor. A word line turns on/off the transistor at the time of reading/writing data stored in the capacitor, and the bit line is a data input/output path. DRAM data is destroyed during read, and refresh circuitry is used to continually refresh the data. Due to the low component count per bit, a high density memory device is achieved.
In another embodiment, the circuit block 204 can be an intellectual property (“IP”) core which is reusable for licensing from other companies or which is taken from the same/previous design. In core-based design, individual cores may be developed and verified independently as stand-alone modules, particularly when IP core is licensed from external design source. These functions are provided to the user as IP blocks as special hardware blocks or pre-configured programmable logic blocks. The IP blocks connect via a programmable switching matrix to each other and other programmable logic. The hardware logic block insertion to any position in a logic sequence is done through the configurable logic matrix. These hardware logic blocks offer a significant gate count reduction on high gate count frequently used logic functions, and the user does not require generic “logic element” customization. In both cases, the user saves simulation time, minimize logic gate count, improve performance, reduce power consumption and reduce product cost with pre-defined IP blocks. The switch matrix is replaced by hard-wires in the final ASIC.
The circuit blocks 204 can also be an array of programmable analog blocks. In one embodiment, the analog blocks include programmable PLL, DLL, ADC and DAC. In another embodiment, each block contains an operational amplifier, multiple programmable capacitors, and switching arrangements for connecting the capacitors in such as a way as to perform the desired function. Switched capacitor filters can also be used to achieve an accurate filter specification through a ratio of capacitors and an accurate control of the frequency of a sampling clock. Multiple PLL's can be programmed to run at different frequencies on the same chip to facilitate SoC applications requiring more than one clock frequency.
The circuit blocks 204 also contain data fetch and data write circuitry required to configure the configuration circuits 208. This operation may be executed by a host CPU residing in the system, or the PLD device itself. During power up, these circuits initialize and read the configuration data from an outside source, either in serial mode or in parallel mode. The data is stored in a predefined word length locally and written to the configurability allocation. The programmed configuration data is verified against the locally stored data and a programming error flag is generated if there is a mismatch. These circuits are redundant in the conversion of the PLD to an ASIC. However, these circuits are used in both FPGA and ASIC for test purposes, and has no cost penalty. A pin-out option has a “disable” feature to disconnect them for the customer use in the FPGA and ASIC.
Configuration circuits 208 provide active circuit control over digital circuits 204. One embodiment of the configuration circuit includes an array of memory elements. The user configuration of this memory amounts to a specific bitmap of the programmable memory in a software representation.
Suitable memory elements include volatile or non volatile memory elements. In non-volatile memory (NVM) based products, configurable data is held in one of metal link fuse, anti-fuse, EPROM, Flash, EEPROM memory element, or ferro-electric elements, resistance modulating elements, photo-electric elements, magneto-electric elements or any other property altering element. Some memory elements are one time programmable (OTP), while others can be programmed multiple times. An EPROM requires UV light to erase data. Flash & EEPROM's lend to in-system programmability (ISP). In volatile products, the configurable data storage can be SRAM cells or DRAM cells. With DRAM cells, the data requires constant refresh to prevent losses from leakages. Additionally, one or more redundant memory cells controlling the same circuit block can be used to enhance device yield.
The components of the memory element array can be a resistor, capacitor, transistor or a diode. In another embodiment of the configuration circuit, a memory element can be formed using thin film deposition. The memory element can be a thin film resistor, thin film capacitor, thin film transistor (TFT) or a thin film diode or a group of thin film devices connected to form an SRAM cell.
This discussion is mostly on SRAM elements and can easily extend to include all other programmable elements. In all cases, the design needs to adhere to rules that allow programmable module elimination, with no changes to the base die, a concept not used in PLD, FPGA, Gate Array and ASIC products today.
An exemplary 6T SRAM cell, shown in 
Pass gate transistor logic 1160 controlled by SRAM is shown in 
Similarly, 
The P-Term logic builds the core of PLD's and complex PLD's (CPLD's) that use AND-OR blocks 202-204 (or equivalent NAND-NOR type logic functions) as shown in the block diagram of 
The length of input and output wires, and the drive on NMOS pass gates and logic gate delays determine the overall PLD delay timing, independent of the SRAM cell parameters. By moving SRAM cell to TFT upper layers, the chip X,Y dimensions are reduced over 20% to 50% compared to traditional SRAM FPGA's, providing a faster logic evaluation time. In addition, removal of SRAM cell later does not alter lateral wire length, wire loading and NMOS pass gate characteristic. The vertical dimension change in eliminating the memory module is negligible compared to the lateral dimension of the ASIC, and has no impact on timing. This allows maintaining identical timing between the FPGA and ASIC implementations with and without the SRAM cells. The final ASIC with smaller die size and no SRAM elements have superior reliability, similar to an ASIC, leading to lower board level burn-in and field failures compared to PLD's and FPGA's in use today.
Next, the wiring and/or routing circuit 522 in 
One embodiment of a switch matrix is a 6×5 programmable switch-matrix with 30 SRAM bits (or 30 Anti-fuses, or 30 fuses), shown in 
Another embodiment provides short interconnect segments that could be joined to each other and to input and output terminals of the logic blocks at programmable interconnection points. In another embodiment, direct connections to adjacent logic blocks can be used to increase speed. For global signals that traverse long distances, longer lines are used. Segmented interconnect structures with routing lines of varied lengths can be used. In yet other embodiments, a hierarchical interconnect structure provides lines of short lengths connectable at boundaries to lines of longer lengths extending between the boundaries, and larger boundaries with lines of even longer length extending between those boundaries. The routing circuit can connect adjacent logic blocks in two different hierarchical blocks differently than adjacent logic blocks in the same hierarchical block. Alternatively, a tile-based interconnect structure can be used where lines of varying lengths in which each tile in a rectangular array may be identical to each other tile. In yet another implementation, the interconnect lines can be separated from the logic block inputs by way of a routing matrix, which gives each interconnect line more flexible access to the logic block inputs. In another embodiment, interconnect routing is driven by programmable buffers. Long wire lengths can be sub-divided into smaller length segments with smaller buffers to achieve a net reduction in the overall wire delay, and to obtain predictable timing in the logic routing of the PLD.
Next, a brief description of the manufacturing process is discussed. During one embodiment of manufacturing, one or more digital circuits can be formed on a substrate. Next, the process selectively fabricates either a memory circuit or a conductive pattern substantially above the digital circuits to control portion of digital circuits. Finally, the process fabricates interconnects and routing wires substantially above the digital circuits and memory circuits to connect digital circuits and one of the memory circuit or the conductive pattern. In another embodiment of manufacturing, one or more digital circuits can be formed on a substrate. Next, the process fabricates interconnects and routing wires substantially above the digital circuits, further providing connection points for configuration circuits to couple into digital circuits. Then, the process selectively fabricates either a memory circuit or a conductive pattern substantially above interconnects to control a portion of digital circuits. Either the memory or the conductive pattern programs the FPGA or the ASIC respectively.
The process can be modified to fabricate a generic field programmable gate array (FPGA) with the constructed memory circuit or an application specific integrated circuit (ASIC) with the constructed conductive pattern. Multiple ASICs can be fabricated with different variations of conductive patterns. The memory circuit and the conductive pattern have one or more substantially matching circuit characteristics. In this case, timing characteristics substantially unchanged by the circuit control option. The process thus fabricates a programmable logic device by constructing digital circuits on a substrate; and constructing a non-planar circuit on the substrate after constructing the digital circuits, the non-planar circuit being either a memory deposited to store data to configure the digital circuits to form a field programmable gate array (FPGA) or a conductive pattern deposited to hard-wire the digital circuits to form an application specific integrated circuit (ASIC), wherein the deposited memory and the conductive pattern have substantially matching timing characteristics. In another embodiment, the hard-wire ASIC option may be incorporated into the digital circuit layer 102. In another embodiment, the hard-wire ASIC option is incorporated into the routing layer 110.
Although an illustrative embodiment of the present invention, and various modifications thereof, have been described in detail herein with reference to the accompanying drawings, it is to be understood that the invention is not limited to this precise embodiment and the described modifications, and that various changes and further modifications may be effected therein by one skilled in the art without departing from the scope or spirit of the invention as defined in the appended claims.
| Patent | Priority | Assignee | Title | 
| Patent | Priority | Assignee | Title | 
| 4207556, | Dec 14 1976 | Nippon Telegraph & Telephone Corporation | Programmable logic array arrangement | 
| 4609986, | Jun 14 1984 | ALTERA CORPORATION, A DELAWARE CORPORATION | Programmable logic array device using EPROM technology | 
| 4646266, | Sep 28 1984 | ENERGY CONVERSION DEVICES, INC | Programmable semiconductor structures and methods for using the same | 
| 4706216, | Feb 27 1985 | XILINX, Inc.; XILINX, INC , A CA CORP | Configurable logic element | 
| 4761768, | Mar 04 1985 | Lattice Semiconductor Corporation; LATTICE SEMICONDUCTOR CORPORATION, 10300 S W GREENBURG ROAD, PORTLAND, OREGON, 97223, | Programmable logic device | 
| 4831573, | Mar 06 1987 | ALTERA CORPORATION, A DELAWARE CORPORATION | Programmable integrated circuit micro-sequencer device | 
| 4864161, | May 05 1988 | ALTERA CORPORATION A CORPORATION OF DELAWARE | Multifunction flip-flop-type circuit | 
| 4870302, | Mar 12 1984 | XILINX, Inc. | Configurable electrical circuit having configurable logic elements and configurable interconnects | 
| 4873459, | Sep 19 1986 | Actel Corporation | Programmable interconnect architecture | 
| 5164612, | Apr 16 1992 | SAMSUNG ELECTRONICS CO , LTD ; CECIL H KAPLINSKY BYPASS TRUST DATED NOVEMBER 11, 1999, THE; VESSELINA KAPLINSKY MARITAL TRUST DATED NOVEMBER 11, 1999, THE | Programmable CMOS flip-flop emptying multiplexers | 
| 5166556, | Jan 22 1991 | Fei Company | Programmable antifuse structure, process, logic cell and architecture for programmable integrated circuits | 
| 5191241, | Aug 01 1990 | Actel Corporation | Programmable interconnect architecture | 
| 5216636, | Sep 16 1991 | Advanced Micro Devices, Inc. | CMOS memory cell | 
| 5301696, | Jan 06 1993 | Decorative pony tail holder and method of using | |
| 5343406, | Jul 28 1989 | XILINX, Inc.; XILINX, INC , A CORP OF CA | Distributed memory architecture for a configurable logic array and method for using distributed memory | 
| 5347519, | Dec 03 1991 | Crosspoint Solutions Inc. | Preprogramming testing in a field programmable gate array | 
| 5457410, | Aug 03 1993 | Actel Corporation | Architecture and interconnect scheme for programmable logic circuits | 
| 5488316, | Jul 28 1989 | XILINX, Inc. | Circuit for selecting a bit in a look-up table | 
| 5488317, | Oct 22 1993 | Texas Instruments Incorporated | Wired logic functions on FPGA's | 
| 5502333, | Mar 30 1994 | GLOBALFOUNDRIES Inc | Semiconductor stack structures and fabrication/sparing methods utilizing programmable spare circuit | 
| 5510730, | |||
| 5563526, | Jan 03 1994 | Texas Instruments Incorporated | Programmable mixed-mode integrated circuit architecture | 
| 5581501, | Aug 17 1995 | ALTERA CORPORATION, A DELAWARE CORPORATION | Nonvolatile SRAM cells and cell arrays | 
| 5612631, | Mar 29 1985 | Lattice Semiconductor Corporation | An I/O macrocell for a programmable logic device | 
| 5625221, | Mar 03 1994 | SAMSUNG ELECTRONIC CO , LTD | Semiconductor assembly for a three-dimensional integrated circuit package | 
| 5629637, | Aug 18 1995 | XILINX, Inc.; Xilinx, Inc | Method of time multiplexing a programmable logic device | 
| 5646878, | Jun 02 1995 | Motorola, Inc | Content addressable memory system | 
| 5679967, | Jan 20 1985 | Chip Express (Israel) Ltd. | Customizable three metal layer gate array devices | 
| 5684744, | Dec 11 1995 | Agilent Technologies Inc | Configurable multifunction flip-flop | 
| 5701233, | Jan 23 1995 | APROLASE DEVELOPMENT CO , LLC | Stackable modules and multimodular assemblies | 
| 5737235, | May 02 1995 | Xilinx, Inc | FPGA with parallel and serial user interfaces | 
| 5754826, | Aug 04 1995 | ARM, INC | CAD and simulation system for targeting IC designs to multiple fabrication processes | 
| 5781031, | Nov 21 1995 | International Business Machines Corporation | Programmable logic array | 
| 5793115, | Sep 30 1993 | ALANZOR RESEARCH A B LLC | Three dimensional processor using transferred thin film circuits | 
| 5818728, | Nov 21 1994 | Chip Express (Israel) Ltd. | Mapping of gate arrays | 
| 5835405, | Dec 13 1993 | Lattice Semiconductor Corporation | Application specific modules in a programmable logic device | 
| 5844422, | Nov 13 1996 | XILINX, Inc. | State saving and restoration in reprogrammable FPGAs | 
| 5880598, | Jan 10 1997 | XILINX, Inc.; Xilinx, Inc | Tile-based modular routing resources for high density programmable logic device | 
| 5925920, | Jun 12 1996 | Cypress Semiconductor Corporation | Techniques and circuits for high yield improvements in programmable devices using redundant routing resources | 
| 5926035, | Jun 26 1996 | MORGAN STANLEY SENIOR FUNDING, INC | Method and apparatus to generate mask programmable device | 
| 5943574, | Feb 23 1998 | Freescale Semiconductor, Inc | Method of fabricating 3D multilayer semiconductor circuits | 
| 5949710, | Apr 10 1996 | ALTERA CORPORATION, A DELAWARE CORPORATION | Programmable interconnect junction | 
| 5949719, | Dec 20 1995 | GLOBALFOUNDRIES Inc | Field programmable memory array | 
| 5959466, | Jan 31 1997 | MICROSEMI SOC CORP | Field programmable gate array with mask programmed input and output buffers | 
| 6005806, | Mar 14 1996 | ALTERA CORPORATION, A CORP OF DELAWARE | Nonvolatile configuration cells and cell arrays | 
| 6018476, | Mar 14 1996 | Altera Corporation | Nonvolatile configuration cells and cell arrays | 
| 6020755, | Sep 26 1997 | Lattice Semiconductor Corporation | Hybrid programmable gate arrays | 
| 6054827, | Jan 23 1997 | Mitsubishi Denki Kabushiki Kaisha | Controller for motor-driven power steering | 
| 6066960, | May 22 1997 | Altera Corporation | Programmable logic device having combinational logic at inputs to logic elements within logic array blocks | 
| 6091263, | Dec 12 1997 | XILINX, Inc.; Xilinx, Inc | Rapidly reconfigurable FPGA having a multiple region architecture with reconfiguration caches useable as data RAM | 
| 6097211, | Jul 18 1996 | Altera Corporation | Configuration memory integrated circuit | 
| 6134171, | Jun 02 1994 | VACHELLIA, LLC | Semiconductor integrated circuit device having hierarchical power source arrangement | 
| 6134173, | Sep 03 1991 | Altera Corporation | Programmable logic array integrated circuits | 
| 6150839, | Dec 12 1997 | XILINX, Inc. | Rapidly reconfigurable FPGA having a multiple region architecture with reconfiguration caches useable as data RAM | 
| 6169416, | Sep 01 1998 | QuickLogic Corporation | Programming architecture for field programmable gate array | 
| 6191614, | Apr 05 1999 | XILINX, Inc.; Xilinx, Inc | FPGA configuration circuit including bus-based CRC register | 
| 6211697, | May 25 1999 | MICROSEMI SOC CORP | Integrated circuit that includes a field-programmable gate array and a hard gate array having the same underlying structure | 
| 6236229, | May 13 1999 | Intel Corporation | Integrated circuits which employ look up tables to provide highly efficient logic cells and logic functionalities | 
| 6239613, | Jan 10 1996 | EDENDERRY AGGREGATES LTD | Tristate structures for programmable logic devices | 
| 6242767, | Nov 10 1997 | HANGER SOLUTIONS, LLC | Asic routing architecture | 
| 6242945, | Mar 04 1997 | XILINX, Inc. | Field programmable gate array with mask programmable I/O drivers | 
| 6255848, | Apr 05 1999 | XILINX, Inc.; Xilinx, Inc | Method and structure for reading, modifying and writing selected configuration memory cells of an FPGA | 
| 6259271, | Jul 18 1996 | Altera Corporation | Configuration memory integrated circuit | 
| 6262596, | Apr 05 1999 | XILINX, Inc.; Xilinx, Inc | Configuration bus interface circuit for FPGAS | 
| 6271542, | Dec 08 1997 | GLOBALFOUNDRIES Inc | Merged logic and memory combining thin film and bulk Si transistors | 
| 6275064, | Dec 22 1997 | Lattice Semiconductor Corporation | Symmetrical, extended and fast direct connections between variable grain blocks in FPGA integrated circuits | 
| 6275065, | Apr 09 1996 | Altera Corporation | Programmable logic integrated circuit architecture incorporating a lonely register | 
| 6326651, | Mar 08 1999 | Matsushita Electric Industrial Co., Ltd. | Field-programmable gate array with ferroelectric thin film | 
| 6331784, | Jul 28 2000 | Atmel Corporation | Secure programmable logic device | 
| 6331789, | May 13 1999 | Intel Corporation | Semiconductor device | 
| 6331790, | Sep 11 2000 | Intel Corporation | Customizable and programmable cell array | 
| 6337579, | Mar 05 1999 | ACHLYS TECHNOLOGIES INC | Multichip semiconductor device | 
| 6340830, | Jun 09 1992 | Semiconductor Energy Laboratory Co., Ltd. | Semiconductor device and method for forming the same | 
| 6346824, | Apr 09 1996 | XILINX, Inc. | Dedicated function fabric for use in field programmable gate arrays | 
| 6353562, | Feb 09 2000 | Polaris Innovations Limited | Integrated semiconductor memory with redundant units for memory cells | 
| 6404226, | Sep 21 1999 | Lattice Semiconductor Corporation | Integrated circuit with standard cell logic and spare gates | 
| 6420925, | Jan 09 2001 | CAVIUM INTERNATIONAL; MARVELL ASIA PTE, LTD | Programmable latch device with integrated programmable element | 
| 6421817, | May 29 1997 | XILINX, Inc.; Xilinx, Inc | System and method of computation in a programmable logic device using virtual instructions | 
| 6424011, | Apr 14 1997 | GLOBALFOUNDRIES Inc | Mixed memory integration with NVRAM, dram and sram cell structures on same substrate | 
| 6426649, | Dec 29 2000 | QuickLogic Corporation | Architecture for field programmable gate array | 
| 6445065, | Jun 06 2000 | Synopsys, Inc | Routing driven, metal programmable integrated circuit architecture with multiple types of core cells | 
| 6448808, | Feb 26 1997 | XILINX, Inc. | Interconnect structure for a programmable logic device | 
| 6462363, | Dec 30 1999 | Intel Corp | Compact, all-layers-programmable integrated circuit arrangements | 
| 6480027, | Mar 04 1999 | Altera Corporation | Driver circuitry for programmable logic devices | 
| 6480954, | Aug 18 1995 | Xilinx Inc. | Method of time multiplexing a programmable logic device | 
| 6483736, | Nov 16 1998 | SanDisk Technologies LLC | Vertically stacked field programmable nonvolatile memory and method of fabrication | 
| 6486703, | Aug 04 1998 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Programmable logic array with vertical transistors | 
| 6496887, | Mar 16 1998 | Actel Corporation | SRAM bus architecture and interconnect to an FPGA | 
| 6504398, | May 25 1999 | Actel Corporation | Integrated circuit that includes a field-programmable gate array and a hard gate array having the same underlying structure | 
| 6504742, | Oct 31 2001 | SAMSUNG ELECTRONICS CO , LTD | 3-D memory device for large storage capacity | 
| 6510548, | Aug 03 2001 | XILINX, Inc.; Xilinx, Inc | Method for providing pre-designed modules for programmable logic devices | 
| 6515510, | Aug 04 1998 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Programmable logic array with vertical transistors | 
| 6515511, | Feb 17 2000 | NEC Corporation | Semiconductor integrated circuit and semiconductor integrated circuit device | 
| 6515551, | Mar 24 1999 | MONTEREY RESEARCH, LLC | Programmable oscillator scheme | 
| 6525953, | Aug 13 2001 | SanDisk Technologies LLC | Vertically-stacked, field-programmable, nonvolatile memory and method of fabrication | 
| 6526559, | Apr 13 2001 | SRA INTERNATIONAL, INC | Method for creating circuit redundancy in programmable logic devices | 
| 6551857, | Apr 04 1997 | Elm Technology Corporation; ELM 3DS INNOVATONS, LLC | Three dimensional structure integrated circuits | 
| 6582980, | Jan 30 2001 | Global Oled Technology LLC | System for integrating digital control with common substrate display devices | 
| 6611153, | Sep 02 2000 | Actel Corporation | Tileable field-programmable gate array architecture | 
| 6613611, | Dec 22 2000 | CALLAHAN CELLULAR L L C | ASIC routing architecture with variable number of custom masks | 
| 6614259, | Jul 18 1996 | Altera Corporation | Configuration memory integrated circuit | 
| 6617621, | Jun 06 2000 | Synopsys, Inc | Gate array architecture using elevated metal levels for customization | 
| 6620659, | Dec 08 1997 | GLOBALFOUNDRIES Inc | Merged logic and memory combining thin film and bulk Si transistors | 
| 6621296, | May 05 2000 | XILINX, Inc. | FPGA lookup table with high speed read decorder | 
| 6627985, | Dec 05 2001 | ARBOR GLOBAL STRATEGIES, LLC | Reconfigurable processor module comprising hybrid stacked integrated circuit die elements | 
| 6633181, | Dec 30 1999 | Xilinx, Inc | Multi-scale programmable array | 
| 6633182, | Sep 05 2001 | Carnegie Mellon University | Programmable gate array based on configurable metal interconnect vias | 
| 6689644, | Aug 13 2001 | SanDisk Technologies LLC | Vertically-stacked, field-programmable, nonvolatile memory and method of fabrication | 
| 6737675, | Jun 27 2002 | SanDisk Technologies LLC | High density 3D rail stack arrays | 
| 6738962, | Jun 12 2000 | Altera Corporation | Configuration and/or reconfiguration of integrated circuit devices that include programmable logic and microprocessor circuitry | 
| 6747478, | Jul 08 2002 | LIBERTY PATENTS LLC | Field programmable gate array with convertibility to application specific integrated circuit | 
| 6748456, | Sep 29 2000 | MONTEREY RESEARCH, LLC | PLD configuration port architecture and logic | 
| 6781226, | Dec 05 2001 | ARBOR GLOBAL STRATEGIES, LLC | Reconfigurable processor module comprising hybrid stacked integrated circuit die elements | 
| 6781409, | Oct 10 2001 | Altera Corporation | Apparatus and methods for silicon-on-insulator transistors in programmable logic devices | 
| 6784517, | Apr 28 2000 | SanDisk Technologies LLC | Three-dimensional memory array incorporating serial chain diode stack | 
| 6798240, | Jan 24 2003 | TAHOE RESEARCH, LTD | Logic circuitry with shared lookup table | 
| 6812731, | May 16 2002 | XILINX, Inc. | Quintuple modular redundancy for high reliability circuits implemented in programmable logic devices | 
| 6828689, | Jul 08 2002 | LIBERTY PATENTS LLC | Semiconductor latches and SRAM devices | 
| 6851047, | Oct 15 1999 | Xilinx, Inc | Configuration in a configurable system on a chip | 
| 6855988, | Jul 08 2002 | LIBERTY PATENTS LLC | Semiconductor switching devices | 
| 6888750, | Apr 28 2000 | SanDisk Technologies LLC | Nonvolatile memory on SOI and compound semiconductor substrates and method of fabrication | 
| 6903571, | Nov 18 2003 | XILINX, Inc. | Programmable systems and devices with multiplexer circuits providing enhanced capabilities for triple modular redundancy | 
| 6911730, | Mar 03 2003 | XILINX, Inc. | Multi-chip module including embedded transistors within the substrate | 
| 6917219, | Mar 12 2003 | XILINX, Inc. | Multi-chip programmable logic device having configurable logic circuitry and configuration data storage on different dice | 
| 6938236, | Mar 29 2002 | Altera Corporation | Method of creating a mask-programmed logic device from a pre-existing circuit design | 
| 6946330, | Oct 11 2001 | Semiconductor Energy Laboratory Co., Ltd. | Designing method and manufacturing method for semiconductor display device | 
| 6954084, | Feb 11 2002 | Seiko Epson Corporation | Logic circuits using polycrystalline semiconductor thin film transistors | 
| 6961810, | Oct 30 1997 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Synchronous content addressable memory | 
| 6992503, | Jul 08 2002 | LIBERTY PATENTS LLC | Programmable devices with convertibility to customizable devices | 
| 6998722, | Jul 08 2002 | LIBERTY PATENTS LLC | Semiconductor latches and SRAM devices | 
| 7019557, | Dec 24 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Look-up table based logic macro-cells | 
| 7019999, | Oct 08 2003 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Content addressable memory with latching sense amplifier | 
| 7030651, | Dec 04 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Programmable structured arrays | 
| 7064018, | Jul 08 2002 | LIBERTY PATENTS LLC | Methods for fabricating three dimensional integrated circuits | 
| 7064579, | Jul 08 2002 | LIBERTY PATENTS LLC | Alterable application specific integrated circuit (ASIC) | 
| 7084666, | Oct 21 2002 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Programmable interconnect structures | 
| 7093225, | Jul 17 2002 | CHARTOLEAUX KG LIMITED LIABILITY COMPANY | FPGA with hybrid interconnect | 
| 7112994, | Jul 08 2002 | LIBERTY PATENTS LLC | Three dimensional integrated circuits | 
| 7176713, | Jan 05 2004 | YAKIMISHU CO LTD , LLC | Integrated circuits with RAM and ROM fabrication options | 
| 7190190, | Jan 09 2004 | TAHOE RESEARCH, LTD | Programmable logic device with on-chip nonvolatile user memory | 
| 7205589, | Jul 08 2002 | LIBERTY PATENTS LLC | Semiconductor devices fabricated with different processing options | 
| 7253659, | Dec 04 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Field programmable structured arrays | 
| 7268580, | Jul 08 2002 | LIBERTY PATENTS LLC | Configuration circuits for three dimensional programmable logic devices | 
| 7312109, | Jul 08 2002 | LIBERTY PATENTS LLC | Methods for fabricating fuse programmable three dimensional integrated circuits | 
| 7323905, | Dec 04 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Programmable structured arrays | 
| 7356797, | Jun 14 2005 | Meta Platforms, Inc | Logic transformation and gate placement to avoid routing congestion | 
| 7365398, | Feb 11 2004 | Cornell Research Foundation, Inc | Compact SRAMs and other multiple transistor structures | 
| 7627848, | Jul 08 2002 | LIBERTY PATENTS LLC | Bit stream compatible FPGA to MPGA conversions | 
| 7777319, | Jul 08 2002 | LIBERTY PATENTS LLC | Three dimensional integrated circuits | 
| 8274309, | Dec 04 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , LLC | Programmable structured arrays | 
| 8810276, | Dec 04 2003 | CALLAHAN CELLULAR L L C ; YAKIMISHU CO LTD , L L C | Programmable structured arrays | 
| 9547736, | Jul 08 2002 | LIBERTY PATENTS LLC | Timing exact design conversions from FPGA to ASIC | 
| 9679914, | Nov 19 2007 | LIBERTY PATENTS LLC | Pads and pin-outs in three dimensional integrated circuits | 
| 9882567, | Dec 04 2003 | Callahan Cellular L.L.C. | Programmable structured arrays | 
| 9912336, | Jul 08 2002 | LIBERTY PATENTS LLC | Three dimensional integrated circuits | 
| 9978773, | Nov 19 2007 | LIBERTY PATENTS LLC | Pads and pin-outs in three dimensional integrated circuits | 
| 20010003428, | |||
| 20010009032, | |||
| 20010015450, | |||
| 20010019155, | |||
| 20010028059, | |||
| 20010039646, | |||
| 20010047509, | |||
| 20020027793, | |||
| 20020073380, | |||
| 20020094661, | |||
| 20020147898, | |||
| 20020177260, | |||
| 20020186044, | |||
| 20030001615, | |||
| 20030023762, | |||
| 20030036248, | |||
| 20030085733, | |||
| 20030102495, | |||
| 20030227056, | |||
| 20040004239, | |||
| 20040004251, | |||
| 20040004496, | |||
| 20040018711, | |||
| 20040178819, | |||
| 20040183564, | |||
| 20040196065, | |||
| 20040212395, | |||
| 20040222817, | |||
| 20040261052, | |||
| 20040268286, | |||
| 20050023656, | |||
| 20050034094, | |||
| 20050040850, | |||
| 20050063373, | |||
| 20050071787, | |||
| 20050102646, | |||
| 20050121789, | |||
| 20050146352, | |||
| 20050229141, | |||
| 20060195729, | |||
| 20080054491, | |||
| 20080094102, | |||
| 20090146189, | |||
| 20110074464, | |||
| 20110076810, | |||
| 20120001654, | |||
| 20120319728, | |||
| 20150243886, | |||
| 20150263069, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Jul 24 2011 | Tier Logic, Inc | YAKIMISHU CO LTD , L L C | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045906/ | 0453 | |
| Aug 27 2015 | YAKIMISHU CO LTD , L L C | CALLAHAN CELLULAR L L C | MERGER SEE DOCUMENT FOR DETAILS | 046245/ | 0573 | |
| May 21 2018 | Callahan Cellular L.L.C. | (assignment on the face of the patent) | / | |||
| Dec 23 2019 | CALLAHAN CELLULAR L L C | INTELLECTUAL VENTURES ASSETS 154 LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 051464/ | 0389 | |
| Dec 30 2019 | INTELLECTUAL VENTURES ASSETS 154 LLC | LIBERTY PATENTS LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 051709/ | 0805 | |
| Jan 19 2023 | RPX Corporation | BARINGS FINANCE LLC, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 063503/ | 0742 | 
| Date | Maintenance Fee Events | 
| May 21 2018 | BIG: Entity status set to Undiscounted (note the period is included in the code). | 
| Jan 16 2023 | REM: Maintenance Fee Reminder Mailed. | 
| Jul 03 2023 | EXP: Patent Expired for Failure to Pay Maintenance Fees. | 
| Date | Maintenance Schedule | 
| May 28 2022 | 4 years fee payment window open | 
| Nov 28 2022 | 6 months grace period start (w surcharge) | 
| May 28 2023 | patent expiry (for year 4) | 
| May 28 2025 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| May 28 2026 | 8 years fee payment window open | 
| Nov 28 2026 | 6 months grace period start (w surcharge) | 
| May 28 2027 | patent expiry (for year 8) | 
| May 28 2029 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| May 28 2030 | 12 years fee payment window open | 
| Nov 28 2030 | 6 months grace period start (w surcharge) | 
| May 28 2031 | patent expiry (for year 12) | 
| May 28 2033 | 2 years to revive unintentionally abandoned end. (for year 12) |