Electronic digital logic circuitry – Multifunctional or programmable – Array
Reexamination Certificate
1999-06-15
2001-03-27
Tokar, Michael (Department: 2819)
Electronic digital logic circuitry
Multifunctional or programmable
Array
C326S041000, C326S038000
Reexamination Certificate
active
06208163
ABSTRACT:
FIELD OF THE INVENTION
This invention relates to programmable logic devices, and in particular to configurable logic blocks of field programmable gate arrays.
BACKGROUND OF THE INVENTION
FIG.
1
(A) is a simplified diagram showing a basic Field Programmable Gate Array (FPGA)
100
, which is a type of Programmable Logic Device (PLD). FPGA
100
includes an array of configurable logic blocks (CLBs) CLB-
1
,
1
through CLB-
4
,
4
surrounded by input/output blocks (IOBs) IOB-
1
through IOB-
16
, and programmable interconnect resources that include vertical interconnect segments
120
and horizontal interconnect segments
121
extending between the rows and columns of CLBs and IOBs. Each CLB includes configurable combinational circuitry and optional output registers programmed to implement a portion of a user's logic function. The interconnect segments of the programmable interconnect resources are configured using various switches to generate signal paths between the CLEs that link the logic function portions. Each IOB is similarly configured to selectively utilize an associated pin (not shown) of FPGA
100
either as a device input pin, a device output pin, or an input/output pin. Although greatly simplified, FPGA
100
is generally consistent with FPGAs that are produced by Xilinx, Inc. of San Jose, Calif.
FIGS.
1
(B) through
1
(D) are simplified diagrams showing examples of the various switches associated with the programmable interconnect resources of FPGA
100
. FIG.
1
(B) shows an example of a six-way segment-to-segment switch
122
that selectively connects vertical wiring segments
120
(
1
) and
120
(
2
) and horizontal wiring segments
121
(
1
) and
121
(
2
) in accordance with configuration data stored in memory cells Ml through M
6
. Alternatively, if horizontal and vertical wiring segments
120
and
121
do not break at an intersection, a single transistor makes the connection. FIG.
1
(C) shows an example of a segment-to-CLB/IOB input switch
123
that selectively connects an input wire
110
(
1
) of a CLB (or IOB) to one or more interconnect wiring segments in accordance with configuration data stored in memory cells M
7
and M
8
. FIG.
1
(D) shows an example of a CLB/IOB-to-segment output switch
124
that selectively connects an output wire
115
(
1
) of a CLB (or IOB) to one or more interconnect wiring segments in accordance with configuration data stored in memory cells M
9
through Mil.
Since the first FPGA was invented in the 1980's, variations on the basic FPGA circuitry have been devised that allow FPGAs to implement specialized functions more efficiently. For example, special interconnect lines have been added to allow adjacent CLBs to be connected at high speed and without taking up general interconnect lines. In addition, hardware has been placed between adjacent CLBs that allows fast carry signal transmissions when an FPGA is configured to implement an arithmetic function or certain wide logic functions. Finally, the circuitry associated with the CLBs has undergone several changes that allow each CLB to implement specialized functions more efficiently. Such CLB modifications are particularly relevant to the present invention.
FIG.
2
(A) is a simplified schematic diagram showing a prior art CLB
200
used in the XC
4000
™ series of FPGAs produced by Xilinx, Inc. CLB
200
includes a first four-input lookup table (LUT) F, a second four-input LUT G, a three-input LUT H, a set of LUT output multiplexers (MUXes)
210
, optional output registers FF-
1
and FF-
2
, and additional circuitry for routing signals within CLB
200
. LUT F receives data input signals F
1
through F
4
that are transmitted from the interconnect resources of the FPGA. Similarly, LUT G receives data input signals G
1
through G
4
. The operation of LUTs F and G is described in detail below. In addition to the eight data input signals F
1
through F
4
and G
1
through G
4
, CLB
200
receives a clock signal CLK, and data/control signals H
1
, DIN/H
2
, SR/H
0
, and EC. By selectively configuring the various programmable elements associated with CLB
200
, CLB
200
generates output signals in response to the data and control signals that are consistent with an assigned portion of a user's logic function.
FIG.
2
(B) is a diagram showing a circuit that can implement four-input LUTs F and G in CLB
200
. Each four-input LUT includes a memory circuit
230
having sixteen memory bits M
1
through M
15
and a MUX structure
240
. The programmed state of each of memory bits M
1
through M
15
is transmitted to MUX structure
240
on lines
235
. MUX structure
240
selectively passes the programmed state of one of the memory bits to output terminal
245
in response to the four input signals (either F
1
through F
4
or G
1
through G
4
). Functionally described, MUX structure
240
includes a series of two-input MUXes controlled by the four input signals. Each combination of four input signals produces a unique address that causes the LUT to output the contents of one of memory bits M
1
through M
15
of memory circuit
230
.
FIG.
2
(C) is a simplified circuit diagram showing memory bit M
0
of memory circuit
230
(see FIG.
2
(B)). Memory bit MO includes first and second inverters connected end-to-end to form a latch
231
that is connected to BIT and BIT_b (inverted bit) lines via pass transistors
232
and
233
, respectively, and a third inverter
234
that is connected between latch
231
and the output line
235
-
1
. Pass transistors
232
and
233
are controlled by a WRITE control line. During a configuration mode, the WRITE line is pulled high and data is transmitted to the latch via the BIT and BIT_b lines. During subsequent operation, the data bit stored by the latch is transmitted through the third inverter
234
and applied to output line
235
-
1
, which transmits the data bit to MUX structure
240
.
Four-input LUTs F and G of CLB
200
have proven extremely useful for implementing many logic functions. However, a problem arises when certain large logic functions are implemented that require signal transmission through four or more CLBs.
FIG. 3
is a simplified diagram showing a portion
300
of an FPGA that includes six CLBS. The interconnect resources associated with portion
300
are programmed to provide a signal path
310
for transmitting data signals between selected CLEs. Specifically, signal path
310
defines the transmission path of an input signal transmitted to LUT F of CLB-
1
,
1
, the output signal from LUT F of CLB-
1
,
1
that is transmitted to LUT F of CLB-
1
,
2
, the output signal from LUT F of CLB-
1
,
2
that is transmitted to LUT G of CLB-
2
,
2
, the output signal from LUT G of CLB-
2
,
2
that is transmitted to LUTs G and H of CLB-
2
,
3
, and the output signal from LUT H of CLB-
2
,
3
.
Signal path
310
represents one of many signal paths typically associated with a user's logic function. Other signal paths are used, for example, to transmit additional input signals to LUT F of CLB-
1
,
1
. (These additional signal paths are indicated in an abbreviated manner by the short lines extending from CLB-
1
,
1
.) The interconnect resources used by these additional signal paths are not shown, so that signal path
310
is clearly identified.
The various components of the CLBS, IOBS, and interconnect resources of a PLD introduce signal delays that delay signals through the PLD. For example, delays are introduced as the signal passes through the various switches associated with an FPGA (see FIGS.
1
(B) through
1
(D), discussed above). Even larger delays are typically produced by the propagation of signals through the CLBs of an FPGA. As mentioned above, an output signal from each four-input LUT F/G is passed through four MUXes from a selected memory cell that is addressed by the four input signals. The delay associated with the transmission through the four MUXes of each four-input LUT is approximately 1 nanosecond (ns). Additional delays are subsequently produced by the LUT output MUXes
210
.
PLD users often impose timing rest
Carberry Richard A.
Mohan Sundararajarao
Wittig Ralph D.
Bever Hoffman & Harms
Bever, Esq Patrick T.
Carter Lois D.
Tokar Michael
Tran Anh
LandOfFree
FPGA configurable logic block with multi-purpose... does not yet have a rating. At this time, there are no reviews or comments for this patent.
If you have personal experience with FPGA configurable logic block with multi-purpose..., we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and FPGA configurable logic block with multi-purpose... will most certainly appreciate the feedback.
Profile ID: LFUS-PAI-O-2485471