The present disclosure relates to interfaces, and more particularly to a data interface with a delay locked loop for digital to analog converters and analog to digital converters.
The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
A digital to analog converter (DAC) converts digital data into an analog signal. When operating at high speeds, the digital data received by the DAC typically needs to meet various timing requirements. For example only, the system needs to account for timing variations in the DAC that occur due to variations in process, supply voltage and temperature (PVT). The system also needs to account for timing variations that occur in a circuit such as a field programmable gate array (FPGA) or application specific integrated circuit (ASIC) that generates the digital data. Meeting the timing requirements ensures that a data latch clock of the DAC can reliably latch the digital data and achieve a desired dynamic performance.
A data interface between the FPGA or ASIC and the DAC becomes more difficult to implement as the speed of the DAC increases. For example only, one DAC implementation operates at 4 Giga samples per second (Gsps). A 4-to-1 multiplexer may be used at an input of the DAC, which reduces a digital data rate to 1 Gbps. In this application, there is only a 1 nanosecond (ns) time slot for the data interface for each bit of the digital data in a 16 bit digital data bus.
Several conventional implementations of the data interface will be described below in conjunction with
The DATACLK signal after the buffer 52 is virtually identical to the CLK_data signal inside the DAC 28. The DATACLK signal is used as a synchronization clock in the circuit 24. The DATACLK signal ensures that the DAC 28 and the circuit 24 are frequency synchronized. Synchronizing a phase between the digital data and the CLK_data signal of the DAC 28 becomes an issue when the DAC conversion speed increases, which leaves less time for the CLK_data signal to latch the incoming digital data.
DATACLK jitter, digital data jitter, data to clock setup time and hold time, data line to data line skew, temperature changes, semiconductor manufacturing process variations, and/or power supply variations also tend to reduce timing margin and tend to collapse a valid data window shown in
Referring now to
The DAC 64 further includes a clock divider circuit 80 that receives a DAC clock (CLK_dac) signal. An output of the clock divider circuit 80 supplies the CLK_data signal to the multiplexer 74 and the FIFO circuit 72. A buffer 82 communicates with the clock divider circuit 80 and outputs a data clock (DATACLK) signal to a buffer 84 of the circuit 62. The buffer 84 transmits the DATACLK signal to the serializer circuit 68 and to a buffer 88, which generates and outputs the CLK_fifo signal to the FIFO memory circuit 72.
In this approach, the DATACLK signal generated by the DAC 64 is sent to the circuit 62 for data clocking and synchronization. A version of the DATACLK signal from the buffer 88 (the CLK_fifo signal) is transmitted back to the DAC 64 along with the digital data. The CLK_fifo signal latches the incoming digital data into the FIFO memory circuit 72. The digital data in the FIFO memory circuit 72 is clocked out by the CLK_data signal.
With enough FIFO depth, synchronization occurs between the two clock domains (CLK_fifo and CLK_data). While this approach can be implemented fully digitally and design synthesis tools may be used, the system 60 tends to consume relatively high power and generates digital noise and spurs in frequency spectrum that reduce DAC dynamic performance. In addition, this implementation requires large chip area, which increases cost.
Referring now to
The buffer 118 outputs a data clock (DATACLK) signal (via a conductor having a length L) to a buffer 120 of the circuit 102. The buffer 120 transmits the DATACLK signal to a first input of a digital clock management (DCM) circuit 122. An output of the DCM circuit 122 is output to first and second clock inputs of a second serializer circuit 124. An output of the second serializer circuit 124 is input to a delay circuit 126, which outputs a DCLK signal to a buffer 130. A second buffer 132 receives an output of the buffer 130. The second buffer 132 outputs the DCLK signal to a clock feedback input of the DCM circuit 122.
In use, the DATACLK signal generated by the DAC 104 is transmitted to the circuit 102 as a synchronization clock to clock out the digital data. The DATACLK signal is also used as a reference clock signal for DCM circuit 122 associated with the circuit 102. A conductor 150 that routes DCLK between the buffers 130 and 132 has a length (M+L). This length matches a sum of a length M of a conductor carrying the digital data from the buffer 108 to the multiplexer 112 and the length L of the conductor carrying the DATACLK signal from the buffer 118 to the buffer 120. For example, the conductor 150 can be a trace on a printed circuit board (PCB).
There is a fixed phase relationship between the CLK_data signal and the DATACLK signal as can be seen in
A phase relationship between the CLK_data signal and the digital data is fixed and optimized for a given PVT case. However, the optimal timing point may change with PVT changes due to the output buffer 118 inside the DAC 104, which may reduce the timing margin in the data interface.
In general, the DCM circuit 122 inside the circuit 102 has relatively large jitter. The output lines of the circuit 102 also tend to have relatively large skew. As a result, this approach tends to suffer reduced timing margin because of the jitter and skew. In addition, this approach may require manual tuning of the length M+L of the conductor 150 to obtain the proper timing.
A system comprises a first circuit includes a data transmitter circuit that transmits digital data based on a first clock signal. A sync generator outputs a sync signal based on the first clock signal. A digital to analog converter circuit includes a data receiver circuit that latches the digital data based on a second clock signal. A digital to analog converter core receives an output of the data receiver circuit. A delay locked loop circuit determines a delay based on the second clock signal and the sync signal and outputs the first clock signal to the first circuit based on the second clock signal and the delay.
In other features, a clock divider receives a third clock signal and that outputs the second clock signal. The delay locked loop circuit comprises an in-phase/quadrature (I/Q) clock generator that receives the second clock signal and that generates I and Q signals. A phase detector receives the sync signal and the second clock signal and generates up and down signals. A loop filter receives the up and down signals. The sync signal comprises a pseudo random bit. A phase interpolator generates a fourth clock signal based on the I and Q signals and an output of the loop filter. A clock divider receives the fourth clock signal and outputs the first clock signal.
In other features, a linear phase detector receives the sync signal and the second clock. A charge pump communicates with an output of the linear phase detector. A filter receives an output of the charge pump. The sync signal comprises a periodic signal. A voltage controlled delay line generates a fourth clock signal based on the second clock and an output of the filter. A clock divider receives the fourth clock signal and outputs the first clock signal.
In other features, the first circuit is implemented as a first integrated circuit and the receiver circuit is implemented as a second integrated circuit. The first integrated circuit and the second integrated circuit are mounted on a printed circuit board in a spaced relationship and connected by traces.
In other features, the first circuit comprises one of an Application Specific Integrated Circuit (ASIC) and a Field Programmable Gate Array (FPGA). The data transmitter circuit comprises a serializer and the data receiver circuit comprises a multiplexer.
A system includes a transmitter circuit. The transmitter circuit includes a data transmitter circuit that outputs digital data based on a first clock signal. A sync generator outputs a sync signal based on the first clock signal. A receiver circuit includes a data receiver circuit that latches the digital data based on a second clock signal. The receiver includes a delay locked loop circuit that determines a delay based on a phase difference between the second clock signal and the sync signal and that outputs the first clock signal to the first circuit based on the second clock signal and the delay.
A method includes outputting digital data from a first circuit based on a first clock signal; outputting a sync signal from the first circuit based on the first clock signal; latching the digital data at a second circuit based on a second clock signal; using a delay locked loop to determine a delay at the second circuit based on a phase difference between the second clock signal and the sync signal; and outputting the first clock signal from the second circuit to the first circuit based on the second clock signal and the delay.
Further areas of applicability of the present disclosure will become apparent from the detailed description provided hereinafter. It should be understood that the detailed description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the disclosure.
The present disclosure will become more fully understood from the detailed description and the accompanying drawings, wherein:
The following description is merely exemplary in nature and is in no way intended to limit the disclosure, its application, or uses. For purposes of clarity, the same reference numbers will be used in the drawings to identify similar elements. As used herein, the phrase at least one of A, B, and C should be construed to mean a logical (A or B or C), using a non-exclusive logical or. It should be understood that steps within a method may be executed in different order without altering the principles of the present disclosure.
The present disclosure relates to a data interface between a transmitter circuit that transmits digital data to a receiver circuit. While the present disclosure will be described in the context of digital to analog converters (DACs) and analog to digital converters (ADCs), skilled artisans will appreciate that the present disclosure applies to data interfaces for other types of data transmitters and receiver circuits. At a very high level, the receiver circuit generates a clock signal that is used by the transmitter circuit to send data. The transmitter circuit generates a SYNC signal that is used by a delay lock loop circuit associated with the receiver circuit to adjust the clock signal.
In some implementations, the data interface according to the present disclosure uses the delay locked loop (DLL) circuit to synchronize a CLK_data signal and a digital data signal. The data interface reduces the impact of the DATACLK signal and digital data jitter, temperature changes, semiconductor manufacturing process variations and power supply variations. The data interface maximizes a valid data window, relaxes speed grade requirements on the FPGA, ASIC or other circuit and the internal DCM (Digital Clock Management), and eliminates the need for manual tuning. The DLL circuit forces the incoming data to track the reference clock, which is the CLK_data signal.
Operation of the data interface with the DLL circuit is accomplished in part by using an internal DAC data latch clock as a reference clock, by outputting a timing adjustable data clock to the transmitter circuit as the incoming data clock, by accepting a pseudo random bit sequence (a SYNC signal) with timing that is the same as DAC digital data, and by locking the SYNC signal to the DLL reference clock, which is the same clock as the DAC data latch clock.
The data interface according to the present disclosure also tends to relax requirements on the transmitter circuit for several reasons. Timing margin consumed by a large skew of the transmitter circuit is partially compensated by the DAC DLL circuit due to the low jitter performance. The data interface according to the present disclosure can adjust the timing of the digital data from circuit against the DAC data latch clock such that the digital data can be latched at the desired timing point regardless of variations due to PVT. As a result, the data interface according to the present disclosure can be used in high speed DACs.
Referring now to
Referring back to
The DLL circuit 226 outputs a DATACLK signal to the transmitter circuit 204 and receives a SYNC signal from the transmitter circuit 204. The DATACLK signal is transmitted to a buffer 230. The buffer 230 outputs the DATACLK signal to a sync generator 238 and the data transmitter circuit 212. In
In use, the internal DAC data clock, the CLK_data signal is used in a different manner. According to the present disclosure, the CLK_data signal is transmitted to the transmitter circuit 204 as the DATACLK signal. The relationship between the internal DAC clock, the CLK_data signal, and the DATACLK signal is managed by DLL circuit 226 of the receiver circuit 206. The DLL circuit 226 monitors the SYNC signal such that the DATACLK signal is compensated for delay. The delay compensation on the DATACLK signal aligns the incoming data (in the SYNC signal) to the CLK_data signal. Exemplary CLK_data, DATACLK and SYNC signals and a valid data window are shown in
The DLL circuit 226 of the receiver circuit 206 uses the CLK_data signal as a reference clock signal and the SYNC signal as a feedback signal. The DLL circuit 226 outputs the DATACLK signal with timing delay needed for proper alignment of the CLK_data signal and the SYNC signal alignment.
The delays that the DLL circuit 226 needs to compensate include the delay introduced by PCB routing on the DATACLK signal lines, the delay introduced inside the transmitter circuit 204, and the delay introduced in the SYNC signal line. All these external circuits (DATACLK signal lines, SYNC signal line and delay inside the transmitter circuit 204) are part of the delay locked loop. Since the delays from the transmitter circuit 204 are part of the delay locked loop, the DLL circuit 226 will compensate for PVT delay variations. The delays outside of the receiver circuit 206 are typically not well defined and depend on particular details of the transmitter circuit 204 and PCB or packaging design. In some implementations, the DLL circuit 226 may have a relatively large tracking range.
Referring now to
As can be appreciated, other types of DLL circuits may be used. In other words, the DLL circuit ensures that the synchronization clock (the DATACLK signal) sent to the transmitter circuit 204 is delay adjusted to align the incoming digital data from the transmitter circuit 204 with the reference clock signal, the CLK_data signal, of the DLL circuit 226.
Referring now to
Referring back to
The divider circuit 312 may provide the option of selecting a lower speed for the transmitter circuit 204, which may lower cost. The SYNC signal may be generated inside the transmitter circuit 204 the same way as all the other digital data bits. Thus, the timing relationship between the SYNC signal and the CLK_data signal will be the same as the timing relationship between the digital data and the CLK_data signal. If the DLL can align the SYNC signal with required timing to the CLK_data signal, the digital data will be aligned to the CLK_data signal the same way as the SYNC signal.
The DLL uses the CLK_data signal as the reference clock into one input of the phase detector 324. The phase detector 324 determines the phase difference between the CLK_data signal and the SYNC signal. A phase error is then filtered by the loop filter 328. Based on the phase error, the phase interpolator 310 provides a delay required to make the DATACLK phase change such that the SYNC signal (input to the phase detector 324) is aligned to the CLK_data signal.
The DLL includes the phase detector 324, the loop filter 328 and the phase interpolator 310 arranged in the receiver circuit 206. The DLL also includes the external PCB routing and the transmitter circuit 204 as part of the DLL. With the external PCB routing and the circuit as part of the DLL, the delay variation of the transmitter circuit 204 is compensated by the DLL over PVT of the transmitter circuit 204.
The SYNC signal can be a pseudo random bit to spread digital noise over a broad spectrum to avoid introducing any fixed pattern spurious signals. The SYNC signal can also use a digital data bit as the feedback to the phase detector. Alternately, the SYNC signal can be a periodic signal.
The data interface according to the present disclosure can also be applied to a data interface between a high-speed ADC and an FPGA, ASIC or other circuit. Referring now to
The data output buffer 414 also generates digital random data that is input to the phase detector 430. The phase detector 430 outputs a control signal to a phase interpolator 438 of the ADC 404 via a loop filter 434 of the circuit 410. The transmitter circuit 404 further includes a clock generator 440 that generates the CLK_data signal for the ADC core 412, the data output buffer 414 and the phase interpolator 438 along with I/Q clock signals. The phase interpolator 438 generates and outputs the DATACLK signal to the phase detector 430 and the input registers 420.
In general, a DLL circuit can be implemented inside the receiver circuit 410, where the DATACLK signal is sent from the transmitter circuit 404 to the receiver circuit 410. The DLL circuit can adjust a phase of the DATACLK to provide a latching clock inside the receiver circuit 410 for latching the data into the receiver circuit 410. A SYNC signal such as random data bit periodic signal can be sent from by the transmitter circuit 404 as a reference.
In general, low jitter DLLs are usually implemented as an analog circuits. The phase interpolator 438 is implemented by the transmitter circuit 404 and the phase detector 430 and the loop filter 434 are implemented by the receiver circuit 410. The DLL circuit uses the digital random data bit (or a data bit) as a reference and the DATACLK signal as a feedback clock to the phase detector 430 and the input registers 420. The DLL automatically adjusts the CLK_data signal through the loop-controlled phase interpolator 438 such that the DATACLK signal to the DLL loop and FPGA input registers is aligned to the ADC digital random data.
The broad teachings of the disclosure can be implemented in a variety of forms. Therefore, while this disclosure includes particular examples, the true scope of the disclosure should not be so limited since other modifications will become apparent to the skilled practitioner upon a study of the drawings, the specification, and the following claims.
Number | Name | Date | Kind |
---|---|---|---|
6321282 | Horowitz et al. | Nov 2001 | B1 |
6765424 | Zampetti et al. | Jul 2004 | B2 |
6795076 | Deering et al. | Sep 2004 | B2 |
6943609 | Zampetti et al. | Sep 2005 | B2 |
7315269 | Schreier et al. | Jan 2008 | B2 |
7425858 | Daga | Sep 2008 | B1 |
7590207 | Shumarayev et al. | Sep 2009 | B1 |
7622969 | Johnson | Nov 2009 | B2 |
7639090 | Lin | Dec 2009 | B2 |
7715471 | Werner et al. | May 2010 | B2 |
7860203 | Shumarayev et al. | Dec 2010 | B1 |
20020061087 | Williams | May 2002 | A1 |
20020154718 | Fong et al. | Oct 2002 | A1 |
20020184581 | Komatsu | Dec 2002 | A1 |
20030094982 | Zampetti et al. | May 2003 | A1 |
20040095838 | Li | May 2004 | A1 |
20040164782 | Zampetti et al. | Aug 2004 | A1 |
20040252804 | Aoyama | Dec 2004 | A1 |
20050017810 | Lin | Jan 2005 | A1 |
20050099967 | Baba | May 2005 | A1 |
20050140537 | Waltari | Jun 2005 | A1 |
20050169417 | Amirichimeh et al. | Aug 2005 | A1 |
20050259764 | Hung Lai et al. | Nov 2005 | A1 |
20070109030 | Park | May 2007 | A1 |
20070146038 | Werner et al. | Jun 2007 | A1 |
20070152766 | Herrin et al. | Jul 2007 | A1 |
20070279112 | Maeda et al. | Dec 2007 | A1 |
20080303568 | Werner et al. | Dec 2008 | A1 |
20090079485 | Lin | Mar 2009 | A1 |
20090146705 | Huang | Jun 2009 | A1 |
20090309652 | Kranabenter | Dec 2009 | A1 |
20100102868 | Kim et al. | Apr 2010 | A1 |
20100228514 | Ong et al. | Sep 2010 | A1 |
20110142112 | Lin et al. | Jun 2011 | A1 |
20110267898 | Yun et al. | Nov 2011 | A1 |
20110289245 | Horowitz et al. | Nov 2011 | A1 |
20120155586 | Felder et al. | Jun 2012 | A1 |
Entry |
---|
Application Note 989—Multiply Your Sampling Rate with Time-Interleaved Data Converters; Maxim Integrated Products, Inc.; Mar. 1, 2001; 6 pages. |
Number | Date | Country | |
---|---|---|---|
20110298508 A1 | Dec 2011 | US |