Multiplex communications – Communication techniques for information carried in plural... – Combining or distributing information via time channels
Reexamination Certificate
1998-06-22
2002-06-04
Nguyen, Chau (Department: 2663)
Multiplex communications
Communication techniques for information carried in plural...
Combining or distributing information via time channels
C370S532000, C327S407000, C708S301000
Reexamination Certificate
active
06400735
ABSTRACT:
FIELD OF THE INVENTION
The present invention relates to delay lines for digital systems. More specifically, the present invention relates to a tuneable and glitchless delay line.
BACKGROUND OF THE INVENTION
Delay lines are used in digital circuits such as board level systems and integrated circuit (IC) devices, including field programmable gate arrays (FPGAs) and microprocessors, to control the timing of various signals in the digital circuits. A simple delay line receives an input signal on an input terminal and provides an output signal on an output terminal, the output signal being a copy of the input signal delayed by a certain time period that is referred to as the delay D of the delay line. More complicated delay lines are tuneable so that delay D of the delay line can be adjusted.
An IC device such as an FPGA can use a tuneable delay line to synchronize clock signals in various parts of the FPGA. As shown in
FIG. 1
, a circuit board
100
comprises an FPGA
105
and another IC device
150
. FPGA
105
comprises a delay line
110
and configurable logic circuits
130
. Clock signal CLK
1
is coupled to an input terminal of delay line
110
and to the clocked circuits (not shown) of IC device
150
. Delay line
110
drives a clock signal CLK
2
to configurable logic circuits
130
. Before clock signal CLK
2
reaches configurable logic circuits
130
, clock signal CLK
2
may be skewed by various factors such as capacitance, heavy loading on the clock line, and propagation delay. The various skewing factors are represented by clock skew
140
which causes a skew delay on clock signal CLK
2
. To distinguish clock signal CLK
2
from the skewed version of clock signal CLK
2
, the skewed version is referred to as skewed clock signal S_SLK
2
. Skewed clock signal S_SLK
2
drives the clock input terminals (not shown) of the clocked circuits within configurable logic circuits
130
. For proper operation of FPGA
105
with IC device
150
, clock signal CLK
1
should be synchronized with skewed clock signal S_SLK
2
. Clock signal CLK
1
can be synchronized with skewed clock signal S_CLK
2
by adjusting delay line
110
so that delay D plus skew delay S_D is equal to a multiple of the period of clock signal CLK
1
. Various circuits and methods of using delay lines to synchronize clock signals are well known in the art.
FIG. 2
shows a block diagram of a conventional tuneable delay line
200
. Tuneable delay line
200
comprises a multi-tap delay circuit
210
and a multiplexer
220
. Multi-tap delay circuit
210
is configured to receive an input signal IN and provide a plurality of delayed output signals D_O[
0
] to D_O[N] (also called taps). Each output signal is a copy of input signal IN delayed by some multiple of a basic delay of tuneable delay line
210
. Specifically, delayed output signal D_O[
0
] is a copy of input signal IN delayed by zero times the basic delay, (i.e. not delayed). Delayed output signal D_O[
1
] is a copy of input signal IN delayed by the basic delay. Delay output signal D_O[
2
] is a copy of input signal IN delayed by two times the basic delay. In general, delayed output signal D_O[X] is a copy of input signal IN delayed by X times the basic delay. Some multi-tap delay circuits
210
may not provide delayed output signal D_O[
0
].
Multiplexer
220
is configured to receive some or all of the delayed output signals. Thus, the input terminals of multiplexer
220
are coupled to the output terminals of multi-tap delay circuit
210
. To avoid confusion, terminals are referred to with the same identifier as the signals driven by the terminal. For example, delayed output signal D_O[
2
] is driven by output terminal D_O[
2
]. Multiplexer
220
is controlled by tap select signals TS[
0
-M]. As used herein, signals that logically form groups are referred to using a group name followed by brackets enclosing a number for each signal. If more than one signal is referred to simultaneously, brackets containing a range of numbers are used. For example tap select signals TS[
0
−M] comprise M+1 signals TS[
0
], TS[
1
], TS[
2
]. . . TS[M−1], and TS[M]. Tap select lines TS[
0
-M] select which delayed output signal multiplexer
220
drives output terminal OUT.
FIG. 3A
is a block diagram that illustrates multi-tap delay circuit
210
in more detail. The delay circuit of
FIG. 3A
comprises a plurality of delay elements
310
_
0
to
310
_N−1. Delay elements
310
_
1
to
310
_N−1 are coupled in series so that the input terminal of a delay element
310
_X is coupled to the output terminal of a delay element
310
_X−1, where X is an integer from 1 to N−1. The input terminal of delay element
310
_
0
is coupled to input terminal IN of multi-tap delay circuit
210
. Each delay element
310
_X drives a delayed output signal D_O[X+1]. Delayed output signal D_O[
0
] is provided at the input terminal of delay element
310
_
0
. Typically, each delay element is identical and provides a delay equal to the base delay. Thus, each delayed output signal D_O[X] is delayed by the base delay from the previous delayed output signal D_O[X−1].
FIG. 3B
shows a typical delay element
350
. Delay element
350
comprises an inverter
351
coupled in series with an inverter
352
. Logically, inverter
351
and inverter
352
cancel out. However, both inverter
351
and inverter
352
provide a small propagation delay. Thus, for delay element
350
the base delay is equal to the propagation delay of inverter
351
plus the propagation delay of inverter
352
. Other types of delay elements are also well known in the art and can be used in multi-tap delay circuits.
As explained above, multiplexer
220
(
FIG. 2
) selects a delayed output signal from multi-tap delay circuit
210
to drive output terminal OUT. However, conventional multiplexers sometimes produce glitches due to race conditions on select lines TS[
0
-M]. For example,
FIG. 4
is a circuit diagram illustrating a version of multiplexer
220
, where N=16. To switch from delayed output signal D_O[
7
] to delayed output signal D_O[
8
], tap select signals TS[
0
-
3
] must transition from 0111 (binary) to 1000 (binary). During the transition from 0111 to 1000, tap select signals TS[
0
-
3
] may transition temporarily to 1111, which would temporarily select delayed output signal D_O[
15
]. For example, if delayed output signal D_O[
15
] is at a logic high level while the desired delayed output signal D_O[
8
] is at a logic low level, a glitch appears on output signal OUT. If delay line
200
is being used for synchronizing clock signals as shown in
FIG. 1
, the temporary transition to the logic high level caused by the glitch may erroneously trigger clocked elements of configurable logic circuits
130
, thereby causing FPGA
100
to perform erroneously. Hence, there is a need for a tuneable delay line that provides glitchless operation.
SUMMARY OF THE INVENTION
The invention provides a tuneable delay line that uses a unique Gray code multiplexer to select the appropriate delayed output signal without glitches by eliminating race conditions on the multiplexer select signals. The invention takes advantage of the fact that the delay line settings change in an ordered fashion, i.e., the settings are sequentially ordered. Specifically, in one embodiment of the present invention a delay line comprises a multi-tap delay circuit that generates a plurality of sequentially ordered delayed output signals on a plurality of sequentially ordered delayed output terminals. The input terminals of a Gray code multiplexer are coupled to the sequentially ordered output terminals of the multi-tap delay circuit. The Gray code multiplexer routes one of the delayed output signals to an output terminal in response to a Gra
Mao Edward S.
Nguyen Chau
Trinh D.
Xilinx , Inc.
LandOfFree
Glitchless delay line using gray code multiplexer does not yet have a rating. At this time, there are no reviews or comments for this patent.
If you have personal experience with Glitchless delay line using gray code multiplexer, we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Glitchless delay line using gray code multiplexer will most certainly appreciate the feedback.
Profile ID: LFUS-PAI-O-2937629