CA2409161A1 - Method and apparatus for incorporating a multiplier into an fpga - Google Patents
Method and apparatus for incorporating a multiplier into an fpga Download PDFInfo
- Publication number
- CA2409161A1 CA2409161A1 CA002409161A CA2409161A CA2409161A1 CA 2409161 A1 CA2409161 A1 CA 2409161A1 CA 002409161 A CA002409161 A CA 002409161A CA 2409161 A CA2409161 A CA 2409161A CA 2409161 A1 CA2409161 A1 CA 2409161A1
- Authority
- CA
- Canada
- Prior art keywords
- bus
- output
- ram
- data
- multiplier
- 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.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/76—Architectures of general purpose stored program computers
- G06F15/78—Architectures of general purpose stored program computers comprising a single central processing unit
- G06F15/7867—Architectures of general purpose stored program computers comprising a single central processing unit with reconfigurable architecture
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/34—Circuit design for reconfigurable circuits, e.g. field programmable gate arrays [FPGA] or programmable logic devices [PLD]
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K19/00—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
- H03K19/02—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
- H03K19/173—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
- H03K19/177—Logic 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/17724—Structural details of logic blocks
- H03K19/17732—Macroblocks
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K19/00—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
- H03K19/02—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
- H03K19/173—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
- H03K19/177—Logic 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/17748—Structural details of configuration resources
- H03K19/1776—Structural details of configuration resources for memories
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/38—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
- G06F7/48—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
- G06F7/52—Multiplying; Dividing
- G06F7/523—Multiplying only
Abstract
One or more columns of multi-function tiles are positioned between CLB tiles of the FPGA array. Each multi-function tile includes multiple function elements that share routing resources. In one embodiment, a multi-function tile includes a configurable, dual-ported RAM and a multiplier that share routing resources of the multi-function tile. The RAM includes first and second input ports coupled to first and second input data buses, respectively, and includes first and second output ports coupled to first and second output data buses, respectively. The multiplier includes first and second operand ports coupled to receive operands from the first and second input data buses, and in response thereto provides a product. In one embodiment, the most significant bits (MSBs) of the product are selectively provided to the first output data bus using bus multiplexer logic, and the least significant bits (LSBs) of the product are selectively provided to the second output data bus using bus multiplexer logic.
Claims (7)
1. A field programmable gate array (FPGA), comprising:
one or more columns of mufti-function tiles, each mufti-function tile comprising:
a programmable switch to provide programmable interconnections'to other tiles and other mufti-function blocks, the programmable switch including input (IMUX) and output (OMUX) multiplexers;
an input data bus coupled to the IMUX;
an output data bus coupled to the OMUX;
a memory having an input port coupled to the input data bus and an output port coupled to the output data bus; and a multiplier having an input port coupled to the input data bus and an output port coupled to the output data bus, wherein the first and second function blocks share routing resources of the mufti-function block.
one or more columns of mufti-function tiles, each mufti-function tile comprising:
a programmable switch to provide programmable interconnections'to other tiles and other mufti-function blocks, the programmable switch including input (IMUX) and output (OMUX) multiplexers;
an input data bus coupled to the IMUX;
an output data bus coupled to the OMUX;
a memory having an input port coupled to the input data bus and an output port coupled to the output data bus; and a multiplier having an input port coupled to the input data bus and an output port coupled to the output data bus, wherein the first and second function blocks share routing resources of the mufti-function block.
2. The FPGA of Claim 1, wherein the input data bus comprises a first bus to carry a first data signal and second bus to carry a second data signal, wherein:
the RAM includes a first input port coupled to the first bus and a second input port coupled to the second bus; and the multiplier includes a first operand port coupled to the first bus and a second operand port coupled to the second bus.
the RAM includes a first input port coupled to the first bus and a second input port coupled to the second bus; and the multiplier includes a first operand port coupled to the first bus and a second operand port coupled to the second bus.
3. The FPGA of Claim 2, wherein during a write operation to the RAM when the RAM is in a first configuration, the RAM writes a number of least-significant bits (LSBs) from the first data signal and from the second data signal to selected addresses in the RAM while the multiplier simultaneously multiples a number of most significant bits (MSBs) from the first data signal with a number of MSBs from the second data signal to generate a product.
4. The FPGA of Claim 3, wherein during a write operation to the RAM when the RAM is in a second configuration mode, the RAM writes the first and second data signals to selected addresses in the RAM.
5. The FPGA of Claim 1, wherein the output data bus comprises a first output bus and a second output bus coupled between the OMUX and first and second output ports, respectively, of the RAM.
6. A method of sharing routing resources between a multiplier and a memory within a multi-function block of a field programmable gate array (FPGA), comprising:
providing first and second data signals to the multi-function block;
providing a number of bits from the first data signal to the memory as a first data word;
providing a number of bits from the first data signal to the multiplier as a first operand;
providing a number of bits from the second data signal to the memory as a second data word;
providing a number of bits from the second data signal to the memory as a second operand;
writing the first and second data words to the memory; and simultaneously multiplying the first and second operands in the multiplier to generate a product.
providing first and second data signals to the multi-function block;
providing a number of bits from the first data signal to the memory as a first data word;
providing a number of bits from the first data signal to the multiplier as a first operand;
providing a number of bits from the second data signal to the memory as a second data word;
providing a number of bits from the second data signal to the memory as a second operand;
writing the first and second data words to the memory; and simultaneously multiplying the first and second operands in the multiplier to generate a product.
7. The method of Claim 6, further comprising:
reading first and second output words from first and second output ports, respectively, of the memory;
and selectively concatenating the MSBs of the product with the first output word and selectively concatenating the LSBs of the product with the second output word to facilitate simultaneous reading of data from the RAM and product information from the multiplier.
reading first and second output words from first and second output ports, respectively, of the memory;
and selectively concatenating the MSBs of the product with the first output word and selectively concatenating the LSBs of the product with the second output word to facilitate simultaneous reading of data from the RAM and product information from the multiplier.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/574,714 US6362650B1 (en) | 2000-05-18 | 2000-05-18 | Method and apparatus for incorporating a multiplier into an FPGA |
US09/574,714 | 2000-05-18 | ||
PCT/US2001/014259 WO2001089091A2 (en) | 2000-05-18 | 2001-05-02 | Method and apparatus for incorporating a multiplier into an fpga |
Publications (2)
Publication Number | Publication Date |
---|---|
CA2409161A1 true CA2409161A1 (en) | 2001-11-22 |
CA2409161C CA2409161C (en) | 2010-07-13 |
Family
ID=24297308
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CA2409161A Expired - Lifetime CA2409161C (en) | 2000-05-18 | 2001-05-02 | Method and apparatus for incorporating a multiplier into an fpga |
Country Status (6)
Country | Link |
---|---|
US (2) | US6362650B1 (en) |
EP (1) | EP1303912B1 (en) |
JP (1) | JP4593866B2 (en) |
CA (1) | CA2409161C (en) |
DE (1) | DE60140674D1 (en) |
WO (1) | WO2001089091A2 (en) |
Families Citing this family (154)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7266725B2 (en) | 2001-09-03 | 2007-09-04 | Pact Xpp Technologies Ag | Method for debugging reconfigurable architectures |
DE19651075A1 (en) | 1996-12-09 | 1998-06-10 | Pact Inf Tech Gmbh | Unit for processing numerical and logical operations, for use in processors (CPU's), multi-computer systems, data flow processors (DFP's), digital signal processors (DSP's) or the like |
DE19654595A1 (en) | 1996-12-20 | 1998-07-02 | Pact Inf Tech Gmbh | I0 and memory bus system for DFPs as well as building blocks with two- or multi-dimensional programmable cell structures |
EP1329816B1 (en) | 1996-12-27 | 2011-06-22 | Richter, Thomas | Method for automatic dynamic unloading of data flow processors (dfp) as well as modules with bidimensional or multidimensional programmable cell structures (fpgas, dpgas or the like) |
US6542998B1 (en) | 1997-02-08 | 2003-04-01 | Pact Gmbh | Method of self-synchronization of configurable elements of a programmable module |
US8686549B2 (en) | 2001-09-03 | 2014-04-01 | Martin Vorbach | Reconfigurable elements |
DE19861088A1 (en) | 1997-12-22 | 2000-02-10 | Pact Inf Tech Gmbh | Repairing integrated circuits by replacing subassemblies with substitutes |
JP2003505753A (en) | 1999-06-10 | 2003-02-12 | ペーアーツェーテー インフォルマツィオーンステヒノロギー ゲゼルシャフト ミット ベシュレンクテル ハフツング | Sequence division method in cell structure |
DE50115584D1 (en) | 2000-06-13 | 2010-09-16 | Krass Maren | PIPELINE CT PROTOCOLS AND COMMUNICATION |
US6844756B1 (en) * | 2000-06-23 | 2005-01-18 | Cypress Semiconductor Corp. | Configurable dedicated logic in PLDs |
US7346644B1 (en) * | 2000-09-18 | 2008-03-18 | Altera Corporation | Devices and methods with programmable logic and digital signal processing regions |
WO2002033504A2 (en) * | 2000-10-02 | 2002-04-25 | Altera Corporation | Programmable logic integrated circuit devices including dedicated processor components |
US8058899B2 (en) | 2000-10-06 | 2011-11-15 | Martin Vorbach | Logic cell array and bus system |
ATE437476T1 (en) * | 2000-10-06 | 2009-08-15 | Pact Xpp Technologies Ag | CELL ARRANGEMENT WITH SEGMENTED INTERCELL STRUCTURE |
US6754686B1 (en) * | 2000-10-13 | 2004-06-22 | Xilinx, Inc. | Literal sharing method for fast sum-of-products logic |
US7444531B2 (en) | 2001-03-05 | 2008-10-28 | Pact Xpp Technologies Ag | Methods and devices for treating and processing data |
US7581076B2 (en) * | 2001-03-05 | 2009-08-25 | Pact Xpp Technologies Ag | Methods and devices for treating and/or processing data |
US20070299993A1 (en) * | 2001-03-05 | 2007-12-27 | Pact Xpp Technologies Ag | Method and Device for Treating and Processing Data |
US9037807B2 (en) | 2001-03-05 | 2015-05-19 | Pact Xpp Technologies Ag | Processor arrangement on a chip including data processing, memory, and interface elements |
US7844796B2 (en) | 2001-03-05 | 2010-11-30 | Martin Vorbach | Data processing device and method |
US6605962B2 (en) | 2001-05-06 | 2003-08-12 | Altera Corporation | PLD architecture for flexible placement of IP function blocks |
AU2002347560A1 (en) * | 2001-06-20 | 2003-01-02 | Pact Xpp Technologies Ag | Data processing method |
US7996827B2 (en) * | 2001-08-16 | 2011-08-09 | Martin Vorbach | Method for the translation of programs for reconfigurable architectures |
US7434191B2 (en) * | 2001-09-03 | 2008-10-07 | Pact Xpp Technologies Ag | Router |
US8686475B2 (en) | 2001-09-19 | 2014-04-01 | Pact Xpp Technologies Ag | Reconfigurable elements |
US7577822B2 (en) * | 2001-12-14 | 2009-08-18 | Pact Xpp Technologies Ag | Parallel task operation in processor and reconfigurable coprocessor configured based on information in link list including termination information for synchronization |
US6920545B2 (en) * | 2002-01-17 | 2005-07-19 | Raytheon Company | Reconfigurable processor with alternately interconnected arithmetic and memory nodes of crossbar switched cluster |
WO2003060747A2 (en) | 2002-01-19 | 2003-07-24 | Pact Xpp Technologies Ag | Reconfigurable processor |
AU2003214003A1 (en) * | 2002-02-18 | 2003-09-09 | Pact Xpp Technologies Ag | Bus systems and method for reconfiguration |
WO2003081454A2 (en) * | 2002-03-21 | 2003-10-02 | Pact Xpp Technologies Ag | Method and device for data processing |
US8914590B2 (en) | 2002-08-07 | 2014-12-16 | Pact Xpp Technologies Ag | Data processing method and device |
US6781408B1 (en) | 2002-04-24 | 2004-08-24 | Altera Corporation | Programmable logic device with routing channels |
US7142011B1 (en) | 2002-04-24 | 2006-11-28 | Altera Corporation | Programmable logic device with routing channels |
KR20100114942A (en) | 2002-05-13 | 2010-10-26 | 페어차일드 세미컨덕터 코포레이션 | Cross point switch with serializer and deserializer functions |
US6844757B2 (en) | 2002-06-28 | 2005-01-18 | Lattice Semiconductor Corp. | Converting bits to vectors in a programmable logic device |
AU2003286131A1 (en) | 2002-08-07 | 2004-03-19 | Pact Xpp Technologies Ag | Method and device for processing data |
US7657861B2 (en) * | 2002-08-07 | 2010-02-02 | Pact Xpp Technologies Ag | Method and device for processing data |
US7043511B1 (en) | 2002-08-30 | 2006-05-09 | Lattice Semiconductor Corporation | Performing conditional operations in a programmable logic device |
EP1537486A1 (en) | 2002-09-06 | 2005-06-08 | PACT XPP Technologies AG | Reconfigurable sequencer structure |
US6803787B1 (en) | 2002-09-25 | 2004-10-12 | Lattice Semiconductor Corp. | State machine in a programmable logic device |
US6927601B1 (en) * | 2002-11-21 | 2005-08-09 | Altera Corporation | Flexible macrocell interconnect |
FR2850766B1 (en) * | 2003-01-31 | 2006-03-03 | St Microelectronics Sa | CONFIGURABLE ELECTRONIC CIRCUIT, PARTICULARLY DEDICATED TO ARITHMETIC CALCULATION |
DE60319945T2 (en) * | 2003-02-05 | 2008-07-17 | Alcatel Lucent | Electrical room switching matrix |
US6911840B1 (en) * | 2003-06-06 | 2005-06-28 | Xilinx, Inc. | Integrated circuit with overclocked dedicated logic circuitry |
US7098687B1 (en) * | 2003-08-18 | 2006-08-29 | Altera Corporation | Flexible routing resources in a programmable logic device |
EP1676208A2 (en) | 2003-08-28 | 2006-07-05 | PACT XPP Technologies AG | Data processing device and method |
CA2548327C (en) | 2003-12-29 | 2015-10-20 | Xilinx, Inc. | Integrated circuit with cascading dsp slices |
US7472155B2 (en) * | 2003-12-29 | 2008-12-30 | Xilinx, Inc. | Programmable logic device with cascading DSP slices |
US7467175B2 (en) * | 2003-12-29 | 2008-12-16 | Xilinx, Inc. | Programmable logic device with pipelined DSP slices |
US7865542B2 (en) * | 2003-12-29 | 2011-01-04 | Xilinx, Inc. | Digital signal processing block having a wide multiplexer |
US7849119B2 (en) * | 2003-12-29 | 2010-12-07 | Xilinx, Inc. | Digital signal processing circuit having a pattern detector circuit |
US7567997B2 (en) * | 2003-12-29 | 2009-07-28 | Xilinx, Inc. | Applications of cascading DSP slices |
US7870182B2 (en) * | 2003-12-29 | 2011-01-11 | Xilinx Inc. | Digital signal processing circuit having an adder circuit with carry-outs |
US7860915B2 (en) * | 2003-12-29 | 2010-12-28 | Xilinx, Inc. | Digital signal processing circuit having a pattern circuit for determining termination conditions |
US7853634B2 (en) * | 2003-12-29 | 2010-12-14 | Xilinx, Inc. | Digital signal processing circuit having a SIMD circuit |
US7882165B2 (en) * | 2003-12-29 | 2011-02-01 | Xilinx, Inc. | Digital signal processing element having an arithmetic logic unit |
US7844653B2 (en) * | 2003-12-29 | 2010-11-30 | Xilinx, Inc. | Digital signal processing circuit having a pre-adder circuit |
US7840627B2 (en) * | 2003-12-29 | 2010-11-23 | Xilinx, Inc. | Digital signal processing circuit having input register blocks |
US7480690B2 (en) * | 2003-12-29 | 2009-01-20 | Xilinx, Inc. | Arithmetic circuit with multiplexed addend inputs |
US7853632B2 (en) * | 2003-12-29 | 2010-12-14 | Xilinx, Inc. | Architectural floorplan for a digital signal processing circuit |
US8495122B2 (en) * | 2003-12-29 | 2013-07-23 | Xilinx, Inc. | Programmable device with dynamic DSP architecture |
US7840630B2 (en) * | 2003-12-29 | 2010-11-23 | Xilinx, Inc. | Arithmetic logic unit circuit |
US7467177B2 (en) | 2003-12-29 | 2008-12-16 | Xilinx, Inc. | Mathematical circuit with dynamic rounding |
US7853636B2 (en) * | 2003-12-29 | 2010-12-14 | Xilinx, Inc. | Digital signal processing circuit having a pattern detector circuit for convergent rounding |
US7284222B1 (en) * | 2004-06-30 | 2007-10-16 | Tabula, Inc. | Method and apparatus for identifying connections between configurable nodes in a configurable integrated circuit |
US7312630B2 (en) | 2004-06-30 | 2007-12-25 | Tabula, Inc. | Configurable integrated circuit with built-in turns |
US7282950B1 (en) * | 2004-11-08 | 2007-10-16 | Tabula, Inc. | Configurable IC's with logic resources with offset connections |
US8112466B2 (en) * | 2004-09-28 | 2012-02-07 | Sicronic Remote Kg, Llc | Field programmable gate array |
US7755387B2 (en) * | 2004-11-01 | 2010-07-13 | Sicronic Remote Kg, Llc | FPGA having a direct routing structure |
US7743085B2 (en) * | 2004-11-08 | 2010-06-22 | Tabula, Inc. | Configurable IC with large carry chains |
US7236009B1 (en) | 2004-12-01 | 2007-06-26 | Andre Rohe | Operational time extension |
US7350026B2 (en) * | 2004-12-03 | 2008-03-25 | Thales | Memory based cross compare for cross checked systems |
US7230451B1 (en) | 2005-08-22 | 2007-06-12 | Altera Corporation | Programmable logic device with routing channels |
US7590676B1 (en) | 2005-09-27 | 2009-09-15 | Altera Corporation | Programmable logic device with specialized multiplier blocks |
US8620980B1 (en) | 2005-09-27 | 2013-12-31 | Altera Corporation | Programmable device with specialized multiplier blocks |
US8463836B1 (en) | 2005-11-07 | 2013-06-11 | Tabula, Inc. | Performing mathematical and logical operations in multiple sub-cycles |
US7679401B1 (en) * | 2005-12-01 | 2010-03-16 | Tabula, Inc. | User registers implemented with routing circuits in a configurable IC |
US7716100B2 (en) * | 2005-12-02 | 2010-05-11 | Kuberre Systems, Inc. | Methods and systems for computing platform |
EP1974265A1 (en) | 2006-01-18 | 2008-10-01 | PACT XPP Technologies AG | Hardware definition method |
US8266198B2 (en) * | 2006-02-09 | 2012-09-11 | Altera Corporation | Specialized processing block for programmable logic device |
US8301681B1 (en) | 2006-02-09 | 2012-10-30 | Altera Corporation | Specialized processing block for programmable logic device |
US8041759B1 (en) | 2006-02-09 | 2011-10-18 | Altera Corporation | Specialized processing block for programmable logic device |
US8266199B2 (en) * | 2006-02-09 | 2012-09-11 | Altera Corporation | Specialized processing block for programmable logic device |
US7797497B1 (en) * | 2006-03-08 | 2010-09-14 | Tabula, Inc. | System and method for providing more logical memory ports than physical memory ports |
US7836117B1 (en) | 2006-04-07 | 2010-11-16 | Altera Corporation | Specialized processing block for programmable logic device |
US7822799B1 (en) | 2006-06-26 | 2010-10-26 | Altera Corporation | Adder-rounder circuitry for specialized processing block in programmable logic device |
US8386550B1 (en) | 2006-09-20 | 2013-02-26 | Altera Corporation | Method for configuring a finite impulse response filter in a programmable logic device |
US8386553B1 (en) | 2006-12-05 | 2013-02-26 | Altera Corporation | Large multiplier for programmable logic device |
US7930336B2 (en) * | 2006-12-05 | 2011-04-19 | Altera Corporation | Large multiplier for programmable logic device |
US7930666B1 (en) | 2006-12-12 | 2011-04-19 | Tabula, Inc. | System and method of providing a memory hierarchy |
US7814137B1 (en) | 2007-01-09 | 2010-10-12 | Altera Corporation | Combined interpolation and decimation filter for programmable logic device |
US8650231B1 (en) | 2007-01-22 | 2014-02-11 | Altera Corporation | Configuring floating point operations in a programmable device |
US7865541B1 (en) | 2007-01-22 | 2011-01-04 | Altera Corporation | Configuring floating point operations in a programmable logic device |
US8645450B1 (en) | 2007-03-02 | 2014-02-04 | Altera Corporation | Multiplier-accumulator circuitry and methods |
US7525344B2 (en) | 2007-03-20 | 2009-04-28 | Tabula, Inc. | Configurable IC having a routing fabric with storage elements |
US7949699B1 (en) | 2007-08-30 | 2011-05-24 | Altera Corporation | Implementation of decimation filter in integrated circuit device using ram-based data storage |
US8863067B1 (en) | 2008-02-06 | 2014-10-14 | Tabula, Inc. | Sequential delay analysis by placement engines |
US8959137B1 (en) | 2008-02-20 | 2015-02-17 | Altera Corporation | Implementing large multipliers in a programmable integrated circuit device |
US8244789B1 (en) | 2008-03-14 | 2012-08-14 | Altera Corporation | Normalization of floating point operations in a programmable integrated circuit device |
US7804325B1 (en) * | 2008-04-22 | 2010-09-28 | Altera Corporation | Dedicated function block interfacing with general purpose function blocks on integrated circuits |
US8166435B2 (en) * | 2008-06-26 | 2012-04-24 | Tabula, Inc. | Timing operations in an IC with configurable circuits |
US8626815B1 (en) | 2008-07-14 | 2014-01-07 | Altera Corporation | Configuring a programmable integrated circuit device to perform matrix multiplication |
WO2010032861A1 (en) * | 2008-09-16 | 2010-03-25 | 日本電気株式会社 | Semiconductor programmable device and control method therefor |
US8438522B1 (en) | 2008-09-24 | 2013-05-07 | Iowa State University Research Foundation, Inc. | Logic element architecture for generic logic chains in programmable devices |
US8661394B1 (en) | 2008-09-24 | 2014-02-25 | Iowa State University Research Foundation, Inc. | Depth-optimal mapping of logic chains in reconfigurable fabrics |
JP5311382B2 (en) * | 2008-09-29 | 2013-10-09 | 独立行政法人産業技術総合研究所 | Reconfigurable integrated circuit |
US8255448B1 (en) | 2008-10-02 | 2012-08-28 | Altera Corporation | Implementing division in a programmable integrated circuit device |
US8307023B1 (en) | 2008-10-10 | 2012-11-06 | Altera Corporation | DSP block for implementing large multiplier on a programmable integrated circuit device |
US8543635B2 (en) * | 2009-01-27 | 2013-09-24 | Xilinx, Inc. | Digital signal processing block with preadder stage |
US8479133B2 (en) * | 2009-01-27 | 2013-07-02 | Xilinx, Inc. | Method of and circuit for implementing a filter in an integrated circuit |
EP2224344A1 (en) * | 2009-02-27 | 2010-09-01 | Panasonic Corporation | A combined processing and non-volatile memory unit array |
US8549055B2 (en) | 2009-03-03 | 2013-10-01 | Altera Corporation | Modular digital signal processing circuitry with optionally usable, dedicated connections between modules of the circuitry |
US8706790B1 (en) | 2009-03-03 | 2014-04-22 | Altera Corporation | Implementing mixed-precision floating-point operations in a programmable integrated circuit device |
US8886696B1 (en) | 2009-03-03 | 2014-11-11 | Altera Corporation | Digital signal processing circuitry with redundancy and ability to support larger multipliers |
US8645449B1 (en) | 2009-03-03 | 2014-02-04 | Altera Corporation | Combined floating point adder and subtractor |
US8468192B1 (en) | 2009-03-03 | 2013-06-18 | Altera Corporation | Implementing multipliers in a programmable integrated circuit device |
US8805916B2 (en) * | 2009-03-03 | 2014-08-12 | Altera Corporation | Digital signal processing circuitry with redundancy and bidirectional data paths |
US8650236B1 (en) | 2009-08-04 | 2014-02-11 | Altera Corporation | High-rate interpolation or decimation filter in integrated circuit device |
US8396914B1 (en) | 2009-09-11 | 2013-03-12 | Altera Corporation | Matrix decomposition in an integrated circuit device |
US8412756B1 (en) | 2009-09-11 | 2013-04-02 | Altera Corporation | Multi-operand floating point operations in a programmable integrated circuit device |
US8539016B1 (en) | 2010-02-09 | 2013-09-17 | Altera Corporation | QR decomposition in an integrated circuit device |
US7948267B1 (en) | 2010-02-09 | 2011-05-24 | Altera Corporation | Efficient rounding circuits and methods in configurable integrated circuit devices |
US8601044B2 (en) * | 2010-03-02 | 2013-12-03 | Altera Corporation | Discrete Fourier Transform in an integrated circuit device |
US8458243B1 (en) | 2010-03-03 | 2013-06-04 | Altera Corporation | Digital signal processing circuit blocks with support for systolic finite-impulse-response digital filtering |
US8484265B1 (en) | 2010-03-04 | 2013-07-09 | Altera Corporation | Angular range reduction in an integrated circuit device |
US8510354B1 (en) | 2010-03-12 | 2013-08-13 | Altera Corporation | Calculation of trigonometric functions in an integrated circuit device |
US8539014B2 (en) * | 2010-03-25 | 2013-09-17 | Altera Corporation | Solving linear matrices in an integrated circuit device |
US8862650B2 (en) | 2010-06-25 | 2014-10-14 | Altera Corporation | Calculation of trigonometric functions in an integrated circuit device |
US8589463B2 (en) | 2010-06-25 | 2013-11-19 | Altera Corporation | Calculation of trigonometric functions in an integrated circuit device |
US8577951B1 (en) | 2010-08-19 | 2013-11-05 | Altera Corporation | Matrix operations in an integrated circuit device |
US8645451B2 (en) | 2011-03-10 | 2014-02-04 | Altera Corporation | Double-clocked specialized processing block in an integrated circuit device |
US9600278B1 (en) | 2011-05-09 | 2017-03-21 | Altera Corporation | Programmable device using fixed and configurable logic to implement recursive trees |
US8812576B1 (en) | 2011-09-12 | 2014-08-19 | Altera Corporation | QR decomposition in an integrated circuit device |
US9053045B1 (en) | 2011-09-16 | 2015-06-09 | Altera Corporation | Computing floating-point polynomials in an integrated circuit device |
US8949298B1 (en) | 2011-09-16 | 2015-02-03 | Altera Corporation | Computing floating-point polynomials in an integrated circuit device |
US8762443B1 (en) | 2011-11-15 | 2014-06-24 | Altera Corporation | Matrix operations in an integrated circuit device |
US8543634B1 (en) | 2012-03-30 | 2013-09-24 | Altera Corporation | Specialized processing block for programmable integrated circuit device |
US9098332B1 (en) | 2012-06-01 | 2015-08-04 | Altera Corporation | Specialized processing block with fixed- and floating-point structures |
US8996600B1 (en) | 2012-08-03 | 2015-03-31 | Altera Corporation | Specialized processing block for implementing floating-point multiplier with subnormal operation support |
US9553590B1 (en) | 2012-10-29 | 2017-01-24 | Altera Corporation | Configuring programmable integrated circuit device resources as processing elements |
US9207909B1 (en) | 2012-11-26 | 2015-12-08 | Altera Corporation | Polynomial calculations optimized for programmable integrated circuit device structures |
US9189200B1 (en) | 2013-03-14 | 2015-11-17 | Altera Corporation | Multiple-precision processing block in a programmable integrated circuit device |
US9348795B1 (en) | 2013-07-03 | 2016-05-24 | Altera Corporation | Programmable device using fixed and configurable logic to implement floating-point rounding |
US9379687B1 (en) | 2014-01-14 | 2016-06-28 | Altera Corporation | Pipelined systolic finite impulse response filter |
US9836221B1 (en) * | 2014-11-10 | 2017-12-05 | Ball Aerospace & Technologies Corp. | Configurable high speed FPGA scan mechanism controller |
US10452392B1 (en) | 2015-01-20 | 2019-10-22 | Altera Corporation | Configuring programmable integrated circuit device resources as processors |
US9684488B2 (en) | 2015-03-26 | 2017-06-20 | Altera Corporation | Combined adder and pre-adder for high-radix multiplier circuit |
US10606651B2 (en) * | 2015-04-17 | 2020-03-31 | Microsoft Technology Licensing, Llc | Free form expression accelerator with thread length-based thread assignment to clustered soft processor cores that share a functional circuit |
US10540588B2 (en) | 2015-06-29 | 2020-01-21 | Microsoft Technology Licensing, Llc | Deep neural network processing on hardware accelerators with stacked memory |
US10236888B2 (en) * | 2016-03-29 | 2019-03-19 | Arm Ltd. | Correlated electron switch device |
US10942706B2 (en) | 2017-05-05 | 2021-03-09 | Intel Corporation | Implementation of floating-point trigonometric functions in an integrated circuit device |
US10879904B1 (en) * | 2017-07-21 | 2020-12-29 | X Development Llc | Application specific integrated circuit accelerators |
US10790830B1 (en) * | 2019-05-20 | 2020-09-29 | Achronix Semiconductor Corporation | Fused memory and arithmetic circuit |
US11256476B2 (en) | 2019-08-08 | 2022-02-22 | Achronix Semiconductor Corporation | Multiple mode arithmetic circuit |
Family Cites Families (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4680628A (en) * | 1984-01-04 | 1987-07-14 | Itek Corporation | Realtime digital diagnostic image processing system |
US4642487A (en) * | 1984-09-26 | 1987-02-10 | Xilinx, Inc. | Special interconnect for configurable logic array |
US5367208A (en) * | 1986-09-19 | 1994-11-22 | Actel Corporation | Reconfigurable programmable interconnect architecture |
JP2879070B2 (en) * | 1989-02-15 | 1999-04-05 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | Programmable logic unit and signal processor |
US5633830A (en) * | 1995-11-08 | 1997-05-27 | Altera Corporation | Random access memory block circuitry for programmable logic array integrated circuit devices |
JPH06276086A (en) * | 1993-03-18 | 1994-09-30 | Fuji Xerox Co Ltd | Field programmable gate array |
US5455525A (en) * | 1993-12-06 | 1995-10-03 | Intelligent Logic Systems, Inc. | Hierarchically-structured programmable logic array and system for interconnecting logic elements in the logic array |
US5682107A (en) | 1994-04-01 | 1997-10-28 | Xilinx, Inc. | FPGA architecture with repeatable tiles including routing matrices and logic matrices |
US5754459A (en) | 1996-02-08 | 1998-05-19 | Xilinx, Inc. | Multiplier circuit design for a programmable logic device |
US5724276A (en) * | 1996-06-17 | 1998-03-03 | Xilinx, Inc. | Logic block structure optimized for sum generation |
US5933023A (en) | 1996-09-03 | 1999-08-03 | Xilinx, Inc. | FPGA architecture having RAM blocks with programmable word length and width and dedicated address and data lines |
US5914616A (en) | 1997-02-26 | 1999-06-22 | Xilinx, Inc. | FPGA repeatable interconnect structure with hierarchical interconnect lines |
US6014684A (en) * | 1997-03-24 | 2000-01-11 | Intel Corporation | Method and apparatus for performing N bit by 2*N-1 bit signed multiplication |
US6100715A (en) * | 1998-12-15 | 2000-08-08 | Vantis Corporation | Methods for configuring FPGA's having variable grain blocks and logic for providing time-shared access to interconnect resources |
US6097212A (en) * | 1997-10-09 | 2000-08-01 | Lattice Semiconductor Corporation | Variable grain architecture for FPGA integrated circuits |
US5915123A (en) * | 1997-10-31 | 1999-06-22 | Silicon Spice | Method and apparatus for controlling configuration memory contexts of processing elements in a network of multiple context processing elements |
US6069490A (en) * | 1997-12-02 | 2000-05-30 | Xilinx, Inc. | Routing architecture using a direct connect routing mesh |
JP3550986B2 (en) * | 1997-12-03 | 2004-08-04 | 日本電信電話株式会社 | Dynamic configuration method of logic circuit |
-
2000
- 2000-05-18 US US09/574,714 patent/US6362650B1/en not_active Expired - Lifetime
-
2001
- 2001-05-02 JP JP2001585404A patent/JP4593866B2/en not_active Expired - Lifetime
- 2001-05-02 EP EP01932925A patent/EP1303912B1/en not_active Expired - Lifetime
- 2001-05-02 CA CA2409161A patent/CA2409161C/en not_active Expired - Lifetime
- 2001-05-02 WO PCT/US2001/014259 patent/WO2001089091A2/en active Application Filing
- 2001-05-02 DE DE60140674T patent/DE60140674D1/en not_active Expired - Lifetime
-
2002
- 2002-01-08 US US10/043,958 patent/US6573749B2/en not_active Expired - Lifetime
Also Published As
Publication number | Publication date |
---|---|
EP1303912A2 (en) | 2003-04-23 |
CA2409161C (en) | 2010-07-13 |
JP2003533931A (en) | 2003-11-11 |
US20020057104A1 (en) | 2002-05-16 |
DE60140674D1 (en) | 2010-01-14 |
WO2001089091A3 (en) | 2002-09-26 |
WO2001089091A2 (en) | 2001-11-22 |
EP1303912B1 (en) | 2009-12-02 |
JP4593866B2 (en) | 2010-12-08 |
US6362650B1 (en) | 2002-03-26 |
US6573749B2 (en) | 2003-06-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CA2409161A1 (en) | Method and apparatus for incorporating a multiplier into an fpga | |
US6066961A (en) | Individually accessible macrocell | |
EP1512223B1 (en) | Programmable logic device having heterogeneous programmable logic blocks | |
US5315178A (en) | IC which can be used as a programmable logic cell array or as a register file | |
US6242946B1 (en) | Embedded memory block with FIFO mode for programmable logic device | |
USRE40423E1 (en) | Multiport RAM with programmable data port configuration | |
EP0426283B1 (en) | Programmable logic device with multi-function input pin | |
WO2002009287A3 (en) | Architecture and method for partially reconfiguring an fpga | |
US5909125A (en) | FPGA using RAM control signal lines as routing or logic resources after configuration | |
US7385417B1 (en) | Dual slice architectures for programmable logic devices | |
US7088134B1 (en) | Programmable logic device with flexible memory allocation and routing | |
US7463056B1 (en) | Writeable shift register lookup table in FPGA with SRAM memory cells in lookup table reprogrammed by writing after initial configuration | |
US4610004A (en) | Expandable four-port register file | |
US7679973B2 (en) | Register file | |
WO1988009035A3 (en) | Multi-port register file with flow-through of data | |
US6212591B1 (en) | Configurable I/O circuitry defining virtual ports | |
US7183796B2 (en) | Configuration memory implementation for LUT-based reconfigurable logic architectures | |
US7675321B1 (en) | Dual-slice architectures for programmable logic devices | |
CA2445001A1 (en) | Architectures for a single-stage grooming switch | |
US7460431B1 (en) | Implementation of double data rate embedded memory in programmable devices | |
US7248491B1 (en) | Circuit for and method of implementing a content addressable memory in a programmable logic device | |
US7183798B1 (en) | Synchronous memory | |
US5621696A (en) | Virtual multiple-read port memory array | |
Ngai et al. | A new generation of ORCA FPGA with enhanced features and performance | |
US6263482B1 (en) | Programmable logic device having macrocells with selectable product-term inversion |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
EEER | Examination request | ||
MKEX | Expiry |
Effective date: 20210503 |