The origins of much of today's FPGA research are in work in the late 1960s and early 1970s on cellular arrays. This work was mainly concerned with improving the fault tolerance of logic structures, thus allowing larger silicon areas or whole wafers to be used to implement logic. The method proposed was to cover the wafer with a regular array of restructurable cells capable of implementing general logic functions. Both fuse- and flip-flop-programmed structures were proposed and investigated. Important early work in this area was done by Manning [Mann77], Minnick [Minn64], Wahlstrom [Wahl67], and Shoup [Shoup70]. A good survey article of the early research appears in [Minn67].
The first programmable two-level logic products were PROMs from Harris and Monolithic Memories. Monolithic Memories later introduced field-programmable logic-array (FPLA) devices based on bipolar fusible link technology, and later Birkner and Chua at Monolithic Memories invented the PAL architecture that was to dominate the marketplace, replacing TTL as the method of choice for implementing glue-logic functions.
The PAL concept was further improved with the introduction of GAL devices. These devices were erasable either electrically or by UV light and used low power CMOS rather than bipolar technology. The most popular of these devices, the 22V10 can emulate a wide variety of conventional PALs.
Structured PALs were introduced and popularized by Altera Corporation, which was founded in 1983 to provide a field-programmable alternative to mask-programmable gate arrays.
The Xilinx FPGA architecture was designed by Ross Freeman and introduced in a paper in the 1986 Custom Integrated Circuits Conference [Carter86].
The Actel FPGA architecture [Actel90] and antifuse technology was designed by a team led by Amr Mohsen and Abbas El Gamal, and was described in a series of papers early in 1988 [Mohsen88], [El-Ayat88].
The Algotronix CAL device [Algo91] was introduced in a paper presented at the Decennial Caltech Conference on VLSI in 1989 [Gray89], based on an architecture developed in 1985 as part of Tom Kean's Ph.D. research [Kean89]. Concurrent Logic [Conc91] introduced the CFA600 Series in 1991 as the result of long-term work on cellular arrays by its founder Fred Furtek. The Pilkington Microelectronics “sea of gates” architecture was designed by Kenneth Austin and licensed to GEC/Plessey as the electrically-reconfigurable architecture (ERA) [Pless91].
A more detailed but less current treatment of the VLSI design issues of FPGA architectures is presented in [Kean89]. Textbooks on CMOS design are [Weste85] and [Glass85]. These books also provide good introductory treatments of RAM cell design. A useful survey article of nonvolatile MOS memory technology, including newer flash memory technology, appeared in [Pash89].
The PLICE antifuse technology is described in [Osann88]. An antifuse allowing metal-to-metal connections with much lower resistance than the PLICE technology is the basis of a more recent FPGA family [QL91].
Studies on soft error rates in Xilinx FPGAs are contained in [Xilinx92]. A description of an FPGA that continually checks its control store is in [Felton91].
The first serious attempt to benchmark FPGA circuits against traditional gate arrays was done by Actel Corporation [Osann88]; [Wein91] gives a comparison of Xilinx and Actel devices over a set of benchmark circuits. Various academic groups have used benchmark circuits to evaluate commercial FPGAs and suggest architectural improvements [Rose92] or to support novel architectural ideas [Walkup92].
Let's assume that you have to select an FPGA for a new project and have received literature from about 20 possible contenders. Where do you go from here?
In this stage you should eliminate any architectures that cannot meet the following criteria (at this point you should believe manufacturers' claims since the objective is to weed out “no-hopers” before doing more detailed analysis).
Under exceptional circumstances (e.g., if only one supplier can offer a required feature) an architecture which fails here may go forward into the next round.
At this stage you should be left with at most five strong contenders, all of which are probably capable of doing the job. You should evaluate them based on the following criteria:
These questions are intended to bring out real-world issues covered in the chapter. There are no right or wrong answers. The material in the body of the chapter should be helpful in tackling the questions, but your own background knowledge and experience is equally important. Some of the questions are included because the writer would like to know the answers!
(a) Identify product die size and technology.
(b) Identify the largest and smallest macro that will fit in a single logic cell. Size is measured using a table of equivalent gates required to implement the macro in a gate array technology (e.g., XOR scores 3,2-input AND scores 1). Average the result to yield the average gate count per logic cell.
(c) Multiply the average gate count per cell by the number of cells per device.
(d) Derate the result by a utilization factor based on the percentage of cells whose functions can be used after placement and routing of a set of benchmark circuits.
Identify at least two critical failings of this methodology and comment on how it could be improved.
[Actel90] Actel Corporation, ACT Family Field Programmable Gate Array Data Book, Actel Corporation, Sunnyvale, Calif., 1990.
[Algo91] Algotronix Ltd., Configurable Array Logic User Manual, Algotronix Ltd., Edinburgh, UK, 1991.
[Altera87] Altera Corporation, ALTERA Data Book 1987, Altera Corporation, Santa Clara, Calif., 1987.
[Baker90] Baker, S., “Designers Want More from Next Generation of FPGAs,” Electronic Engineering Times, pp. 45-46, 48, 53, September 17, 1990.
[Brown92] Brown, S. D., Francis, R. J., Rose, J., Vranesic, Z. G., Field-Programmable Cate Arrays, Kluwer, 1992.
[Bursky91] Bursky, D., In-System Programmable Logic Keeps Delays Short, Lattice Semiconductor Corporation, Hillsboro, 1991.
[Bursky92] Bursky, D., “FPGA Advances Cut Delays, Add Flexibility," Electronic Design, pp. 35–43, October 1, 1992.
[Bursky92] Bursky, D., “RAM-Based Logic Arrays Up Density, Cut Delays,” Electronic Design, pp. 45–49, October 1, 1992.
[Byte87] BYTE, Theme Issue On Programmable Hardware, January 1987.
[Carter86] Carter, W„ et al., “A User Programmable Reconfigurable Gate Array,” paper presented at the IEEE 1986 Custom Integrated Circuits Conference.
[Chen82] Chen, X., Hurst, S. L., “A Comparison of Universal-Logic-Module Realizations and Their Application in the Synthesis of Combinatorial and Sequential Logic Networks,” IEEE Transactions on Computers, Vol. 31, No. 2, pp. 140-147, February 1982.
[Ebeling91] Ebeling, C., Borriello, G., Hauck, S. A., Song, D., Walkup, E. A., “TRIPTYCH: A New FPGA Architecture,” in FPGAs, pp. 75-90, (Moore, W„ Luk, W., eds.) Abingdon EE & CS Books, Abingdon, England, 1991.
[El-Ayat88] El-Ayat, K., et al., “A CMOS Electrically Configurable Gate Array,” paper presented at the International Solid State Circuits Conference, San Francisco, Calif., 1988.
[Felton91] Felton, B., Hastie, N., “Configuration Data Verification and the Integrity Checking of SRAM based FPGA's,” Proc. Oxford 1991 International Workshop on Field Programmable Logic and Applications Published as FPGA's, (Moore, W„ Luk, W. eds), Abingdon EE & CS Books, Abingdon, England, 1991.
[Glass85] Glasser, L. A., Dobberpuhl, D. W„ The Design and Analysis of VLSI Circuits, Addison-Wesley, 1985.
[Goering90] Goering, R., “A Quiet Takeover in FPGA Synthesis,” Electronic Engineering Times, p. 53, September 17, 1990.
[Gray89] Gray, J. P., Kean, T. A., “Configurable Hardware: A New Paradigm for Computation,” Proc. Decennial Caltech Conference on VLSI, Pasadena, Calif., March 1989.
[Guo92] Guo, R., Nguyen, H., Srinivasan, A., Verheyen, H., Cai, H., Law, S., Mohsen, A., “A 1024 Pin Universal Interconnect Array With Routing Architecture,” Proc. IEEE 1992 Custom Integrated Circuits Conference, pp. 4.5.1–4.5.4, 1992.
[Kean89] Kean, T., Configurable Logic: A Dynamically Programmable Cellular Architecture and its VLSI Implementation, Ph.D. Thesis CST-62-89, University of Edinburgh, Dept. Computer Science, 1989.
[Mann77] Manning, F. B., “An Approach to Highly Integrated Computer-Maintained Cellular Arrays,” IEEE Transactions on Computers, Vol. C-26, No. 6, pp. 536–552, June 1977.
[Marple92] Marple, D., “An MPGA-like FPGA,” IEEE Design & Test of Computers, pp. 51-60, December 1992.
[Minn64] Minnick, R. C., “Cutpoint Cellular Logic," IEEE Transactions on Electronic Computers, Vol. EC-13, pp. 685-698, December 1964.
[Minn67] Minnick, R. C., “A Survey of Microcellular Research,” Journal of the ACM, Vol. 14. No. 2, pp. 203–241, April 1967.
[MMI84] Monolithic Memories Inc. Programmable Logic Handbook, Monolithic Memories Inc., Santa Clara, Calif., 1984.
[Mohsen88] Mohsen, A., “Desktop-Configurable Channeled Gate Arrays,” VLSI Systems Design, pp. 24–33, August 1988.
[Mohsen93] Mohsen, A., “Programmable Interconnects Speed System Verification," in Circuits and Devices, pp. 37–42, IEEE Press, May 1993.
[Osann88] Osann, B„ Gamal, A. E., “Compare ASIC Capacities with Gate Array Benchmarks,” Electronic Design, October 13, 1988.
[Pash89] Pashley, R. D., Lai, S. K., “Flash Memories: The Best of Two Worlds,” IEEE Spectrum, December 1989.
[Pless91] GEC Plessey Semiconductors, ERA60100 Electrically Reconfigurable Array Data Sheet, GEC/Plessey, 1991.
[Prep93] Programmable Electronics Performance Corporation, PLD Benchmark Suite I, Version 1.2, 1993.
[QL91] QuickLogic, pASIC 1 Family, Very High Speed CMOS FPGA's Preliminary Data., QuickLogic Inc., Santa Clara, Calif., 1991.
[Rose92] Rose, J., Tseng, B., Brown, S., “Using Architectural and CAD Interactions to Improve FPGA Routing Architectures,” Proc. First International ACM/SIGDA Workshop on FPGA's, Berkeley, Calif., 1992.
[Savage76] Savage, J. E., The Complexity of Computing, Wiley, 1976.
[Shoup70] Shoup, R. G„ Programmable Cellular Logic Arrays. Ph.D. Thesis, Computer Science Dept., Camegie-Mellon University, March 1970.
[Trim94] Trimberger, S. M., “Field-Programmable Gate Array Technology,” Kluwer, 1994.
[Wahl67] Wahlstrom, S. E., “Programmable Logic Arrays," Electronics, Vol. 40, No. 25, pp. 90-95, December 11, 1967.
[Walkup92] Walkup, E., Huack, S., Bordello, G., Ebeling, C., “Routing Directed Placement for the TRIPTYCH FPGA,” Proc. First International ACM/SIGDA Workshop on FPGA's, Berkeley, Calif., 1992.
[Wein91] Weinmann, U., Kunzmann, A., Strohmeier, U., “Evaluation of FPGA Architectures,” Proc. Oxford 1991 International Workshop on Field Programmable Logic and Applications, Published as FPGA's, (Moore, W., Luk, W. eds), Abingdon EE & CS Books, Abingdon, England, 1991.
[Weste93] Weste, N., Eshraghian, K., Principles of CMOS VLSI Design, 2nd ed. Addison-Wesley, 1993.
[Xilinx92] Xilinx Inc., The Programmable Gate Array Data Book, Xilinx Inc., San Jose, Calif., 1992.
3.133.144.197