The present invention relates to the field of integrated circuit, and more particularly to configurable gate array.
A configurable gate array is a semi-custom integrated circuit designed to be configured by a customer after manufacturing. U.S. Pat. No. 4,870,302 issued to Freeman on Sep. 26, 1989 (hereinafter referred to as Freeman) discloses a configurable gate array. It contains an array of configurable logic elements (also known as configurable logic blocks) and a hierarchy of configurable interconnects (also known as programmable interconnects) that allow the configurable logic elements to be wired together. Each configurable logic element in the array is in itself capable of realizing any one of a plurality of logic functions (e.g. shift, logic NOT, logic AND, logic OR, logic NOR, logic NAND, logic XOR, arithmetic addition “+”, arithmetic subtraction “−”, etc.) depending upon a first configuration signal. Each configurable interconnect can selectively couple or de-couple interconnect lines depending upon a second configuration signal.
Complex math functions are widely used in various applications. A complex math function has multiple independent variables and can be expressed as a combination of basic math functions. On the other hand, a basic function has a single or few independent variables. Exemplary basic functions include transcendental functions, such as exponential function (exp), logarithmic function (log), trigonometric functions (sin, cos, tan, a tan) and others. To meet the speed requirements, many high-performance applications require that these complex math functions be implemented in hardware. In conventional configurable gate arrays, complex math functions are implemented in fixed computing elements, which are portions of hard blocks and not configurable, i.e. the circuits implementing these complex math functions are fixedly connected and are not subject to change by programming. Apparently, fixed computing elements would limit further applications of the configurable gate array. To overcome this difficulty, the present invention expands the original concept of the configurable gate array by making the fixed computing elements configurable. In other words, besides configurable logic elements, the configurable gate array comprises configurable computing elements, which can realize any one of a plurality of math functions.
It is a principle object of the present invention to extend the applications of a configurable gate array to the field of complex math computation.
It is a further object of the present invention to provide a configurable computing array where not only logic functions can be customized, but also math functions.
It is a further object of the present invention to provide a configurable computing array with a small size.
It is a further object of the present invention to provide a configurable computing array with a fast computational speed.
In accordance with these and other objects of the present invention, the present invention discloses a configurable computing array using two-sided integration.
The present invention discloses a configurable computing array. It is a monolithic integrated circuit comprising an array of configurable computing elements and an array of configurable logic elements, which are formed on different sides of a semiconductor substrate. Each configurable computing element comprises at least a writable-memory array, which is electrically programmable and can be loaded with a look-up table (LUT) for a math function. Being electrically programmable, the math functions that can be realized by a writable-memory array are essentially boundless. The preferred configurable computing array further comprises a plurality of configurable interconnect, which are formed on both sides of the semiconductor substrate.
The usage cycle of the configurable computing element comprises two stages: a configuration stage and a computation stage. In the configuration stage, the LUT for a desired math function is loaded into the writable-memory array. In the computation stage, a selected portion of the LUT for the desired math function is read out from the writable-memory array. For a rewritable-memory array, a configurable computing element can be re-configured to realize different math functions at different time.
Besides configurable computing elements, the preferred configurable computing array further comprises configurable logic elements and configurable interconnects. During operation, a complex math function is first decomposed into a combination of basic math functions. Each basic math function is realized by programming the associated configurable computing element. The complex math function is then realized by programming the appropriate configurable logic elements and configurable interconnects.
Accordingly, the present invention discloses a configurable computing array, comprising: a semiconductor substrate having a first side and a second side; at least a configurable computing element formed on said first side of said semiconductor substrate for storing at least a portion of a look-up table (LUT) for a math function; at least a configurable logic element formed on said second side of said semiconductor substrate for selectively realizing a logic function from a logic library; a plurality of through-substrate vias through said semiconductor substrate for coupling said configurable computing element and said configurable logic element; wherein said configurable computing array realizes a math function by programming said configurable computing element and said configurable logic element.
The present invention further discloses another configurable computing array, comprising: a semiconductor substrate having a first side and a second side; at least a configurable computing element formed on said first side of said semiconductor substrate for storing at least a portion of a look-up table (LUT) for a math function; at least a configurable logic element formed on said second side of said semiconductor substrate for selectively realizing a logic function from a logic library; a plurality of through-substrate vias through said semiconductor substrate for coupling said configurable computing element and said configurable logic element; at least a configurable interconnect for selectively realizing an interconnect from an interconnect library; wherein said configurable computing array realizes a math function by programming said configurable computing element, said configurable logic element and said configurable interconnect.
It should be noted that all the drawings are schematic and not drawn to scale. Relative dimensions and proportions of parts of the device structures in the figures have been shown exaggerated or reduced in size for the sake of clarity and convenience in the drawings. The same reference symbols are generally used to refer to corresponding or similar features in the different embodiments. In the present invention, the terms “write”, “program” and “configure” are used interchangeably. The phrase “a circuit is formed on a substrate” means that the active elements (e.g. diodes/transistors) of the circuit are formed on the substrate, i.e. at least a portion of the active element (e.g. channel/source/drain) is formed in the substrate. The symbol “/” means a relationship of “and” or “or”.
Those of ordinary skills in the art will realize that the following description of the present invention is illustrative only and is not intended to be in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons from an examination of the within disclosure.
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
This type of integration, i.e. forming the configurable logic elements 100AA-100BB and the configurable computing elements 200AA-200BB on different sides of the substrate, is referred to as two-sided integration. The two-sided integration can improve computational density and computational complexity. With the conventional 2-D integration, the die size of configurable computing array is the sum of those of the configurable computing elements and the configurable logic elements. With the two-side integration, the configurable computing elements are moved from aside to the other side. This leads to a smaller die size and a higher computational density. In addition, because the memory transistors in the configurable computing elements and the logic transistors in the configurable logic elements are formed on different sides of the substrate, their manufacturing processes can be optimized separately.
The preferred configurable computing arrays shown in the figures are field-programmable computing array (FPCA). For an FPCA, all manufacturing processes are finished in factory. The function of the FPCA can be electrically defined in the field of use. The concept of FPCA can be extended to mask-programmed computing array (MPCA). For a MPCA, wafers containing the configurable computing elements and the configurable logic elements are prefabricated and stockpiled in factory. However, certain interconnects on these wafers are not fabricated until the function of the MPCA is finally defined.
While illustrative embodiments have been shown and described, it would be apparent to those skilled in the art that many more modifications than that have been mentioned above are possible without departing from the inventive concepts set forth therein. The invention, therefore, is not to be limited except in the spirit of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2016 1 0125227 | Mar 2016 | CN | national |
2016 1 0307102 | May 2016 | CN | national |
2017 1 0980967 | Oct 2017 | CN | national |
2017 1 0980989 | Oct 2017 | CN | national |
2017 1 0981043 | Oct 2017 | CN | national |
This application is a continuation-in-part of U.S. patent application Ser. No. 15/450,049, filed Mar. 6, 2017, which is a continuation-in-part of U.S. patent application Ser. No. 15/450,017, filed Mar. 5, 2017. These patent applications claim priorities from Chinese Patent Application No. 201610125227.8, filed Mar. 5, 2016; Chinese Patent Application No. 201610307102.7, filed May 10, 2016, in the State Intellectual Property Office of the People's Republic of China (CN). This application also claims priorities from Chinese Patent Application No. 201710980967.4, filed Oct. 20, 2016; Chinese Patent Application No. 201710981043.6, filed Oct. 20, 2016; Chinese Patent Application No. 201710980989.0, filed Oct. 20, 2016, in the State Intellectual Property Office of the People's Republic of China (CN), the disclosure of which are incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
4870302 | Freeman | Sep 1989 | A |
5046038 | Briggs et al. | Sep 1991 | A |
5424245 | Gurtler | Jun 1995 | A |
5835396 | Zhang | Nov 1998 | A |
5954787 | Eun | Sep 1999 | A |
7472149 | Endo | Dec 2008 | B2 |
7512647 | Wilson et al. | Mar 2009 | B2 |
8564070 | Zhang | Oct 2013 | B2 |
9207910 | Azadet et al. | Dec 2015 | B2 |
9225501 | Azadet | Dec 2015 | B2 |
20140222883 | Pineiro | Aug 2014 | A1 |
Entry |
---|
Paul et al., “Reconfigurable Computing Using Content Addressable Memory for Improved Performance and Resource Usage”, Design Automation Conference (DAC), pp. 786-791, 2008. |
Karam et al, “Emerging Trends in Design and Applications of Memory-Based Computing and Content-Addressable Memories”, Proceedings of the IEEE, vol. 103, issue 8, pp. 1311-1330, 2015. |
Number | Date | Country | |
---|---|---|---|
20180048316 A1 | Feb 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15450049 | Mar 2017 | US |
Child | 15793933 | US | |
Parent | 15450017 | Mar 2017 | US |
Child | 15450049 | US |