The present embodiments relate to integrated circuits and, more particularly, to dynamic clock-data phase alignment in a source-synchronous interface circuit.
Signal transmission and reception is the basis for communication between circuits within electronic devices as well as between circuits within different electronic devices. However, when building high-performance products, system developers face significant challenges in maintaining the precise timing and signal integrity required to reliably sustain high data rates. Differential signaling standards like low voltage differential signaling (LVDS) aid in this effort by providing common mode rejection, which greatly reduces the effects of electrical noise.
Clock-data recovery (CDR) transceiver implementations combine the clock and data into a single signal, thus ensuring simultaneous arrival at their destination. However, a number of interface standards such as DDR memory, HyperTransport buses, and the System Packet Interface (SPI) 4.2 standard are source-synchronous. Those source-synchronous interface standards require the transmission and reception of a clock signal that is transmitted separately from the data signal.
On the receiver side, the clock signal must be phase shifted relative to the data signal to enable the capture of the data. For example, edge-aligned clock and data signals must be phase shifted relative to each other by 90 degrees such that the edge of the clock signal is aligned with the center of the data signal, thereby enabling the storage of the data signal in a storage circuit that is triggered by an edge of the clock signal.
Dynamic phase alignment (DPA) technology has been developed to address the phase alignment in interfaces that require data ranges above 700 megabits per second (Mbps). The goal of dynamic phase alignment (DPA) is to allow devices to actively respond to changes in skew between the transmitted clock and data signals. Integrated circuits that are equipped with DPA continuously check the incoming data signal and adjust the phase of the clock signal to align with it. Several industry standards responsible for defining source synchronous interfaces, including System Packet Interface (SPI) 4.2, have recognized the value of DPA, and have included or recommended it in their specifications.
Clock-data phase alignment circuitry may include clock phase adjustment circuitry, first and second clock distribution networks, and a storage circuit. The clock phase adjustment circuitry may receive a differential clock with first and second clock signals that are complementary to each other. The first clock distribution network may receive the first clock signal and propagate the first clock signal through at least one first clock buffer to provide a delayed first clock signal. The storage circuit may receive the delayed first clock signal and a data signal and store the data signal based on the delayed first clock signal, and a second clock distribution network coupled between the first clock distribution network and the clock phase adjustment circuitry may receive the delayed first clock signal and propagate the delayed first clock signal through at least one second clock buffer to provide a further delayed first clock signal to the clock phase adjustment circuitry.
It is appreciated that the embodiments described herein can be implemented in numerous ways, such as a process, an apparatus, a system, a device, or a method executed on a processing machine. Several inventive embodiments are described below.
In certain embodiments, the above mentioned clock-data phase alignment circuitry may replicate at least a branch of the first clock distribution network in the second clock distribution network, and each of the at least first and second clock buffers may have a delay of less than half a unit interval (UI).
If desired, the clock phase adjustment circuitry may further include a first adjustable delay circuit that delays the first clock signal by a first adjusted delay and a second adjustable delay circuit that delays the further delayed first clock signal by a second adjusted delay to provide a feedback clock signal.
In some embodiments, the above mentioned clock phase adjustment circuitry may further include a phase detector, a delay control circuit, and/or a register. The phase detector may provide a control signal based on a phase difference between the second clock signal and the feedback clock signal, the delay control circuit may adjust the first and second adjusted delays of the first and second adjustable delay circuits, respectively, based on the control signal, and the register may provide the control signal by storing the second clock signal based on the feedback signal.
Further features of the invention, its nature and various advantages, will be apparent from the accompanying drawings and the following detailed description of the preferred embodiments.
The present embodiments provided herein relate to integrated circuits and, more particularly, to dynamic clock-data phase alignment in a source-synchronous interface circuit.
Source-synchronous interface standards require the transmission and reception of a clock signal that is transmitted separately from the data signal. On the receiver side, the clock signal must be phase shifted relative to the data signal to enable the capture of the data. For example, edge-aligned clock and data signals are preferably phase shifted relative to each other by 90 degrees such that the edge of the clock signal is aligned with the center of the data signal, thereby sampling the data signal in a storage circuit at an edge of the clock signal.
Some implementations use the clock signal of the source-synchronous interface to clock input capture registers directly. In other implementations, the clock signal drives a delay-locked loop (DLL) circuit or a phase-locked loop (PLL) circuit that clocks the input capture registers. There are usually larger timing margins for interfaces that use a DLL or a PLL to clock the input capture registers than there are for interfaces that use the clock signal directly to clock the capture registers, especially with an increasing size of data bits that are transmitted in parallel and have to be captured in parallel. Such larger buses often require a DLL and a quadrature clock generator, both of which are costly in power and area.
Consequently, it is desirable to provide clock-data phase alignment circuitry that is capable of aligning the clock and data signals using less power and area than the above mentioned alternative of using a DLL and a quadrature clock generator while still supporting a large data bus.
It will be recognized by one skilled in the art, that the present exemplary embodiments may be practiced without some or all of these specific details. In other instances, well-known operations have not been described in detail in order not to unnecessarily obscure the present embodiments.
An illustrative embodiment 100 of interconnected circuits is shown in
Examples of such circuits also include complex electronic systems such as network routers and cell phone base stations or parts thereof that communicate with each other over wired or wireless networks. Interconnection resources 160 such as conductive lines and busses, optical interconnect infrastructure, or wired and wireless networks with optional intermediate switches may be used to send signals from one circuit to another circuit or to broadcast information from one circuit to multiple other circuits.
Interconnection resources 160 may transport signals serially or in parallel or using a combination of serial-parallel data transmission, if desired. For example, interconnection resources 160 may implement a 100 gigabit per second (Gbps) connection between circuit A (110) and circuit B (130) using four serial connections of 25 Gbps each.
The signals that are transported over interconnection resources 160 may have the clock and data signals combined in a single signal. For example, a transmitting circuit (e.g., circuit A (110)) may serialize a data signal based on a clock signal and send the serialized data signal over interconnection resources 160 to a receiving circuit (e.g., circuit B (130)), and the receiving circuit may analyze the serialized data to recover a clock signal.
If desired, a transmitting circuit (e.g., circuit A (110)) may send the clock and data signals as separate signals over interconnection resources 160, and the receiving circuit (e.g., circuit B (130)) may ensure a predetermined phase shift between the clock and data signals, thereby implementing a source-synchronous interface standard.
Integrated circuits 290 may include processing and storage components 210 such as random-access memory (RAM), first-in first-out (FIFO) circuitry, stack or last-in first-out (LIFO) circuitry, read-only memory (ROM), content addressable memory (CAM), or other memory elements, embedded microprocessors, digital signal processors (DSP), microcontrollers, or other processing circuitry, clock-data phase alignment circuitry 250, and interconnection resources 260 such as conductive lines and busses.
Interconnection resources 260 may be used to send signals from one component to another component or to broadcast signals from one component to one or more other components. For example, interconnection resources 260 may be used to distribute a clock signal from the clock-data phase alignment circuitry 250 to some or all of the components in the integrated circuit.
Integrated circuit may include input/output circuitry 270 which may include parallel input/output circuitry, differential input/output circuitry, serial data transceiver circuitry, or any other desired input/output circuitry. Input/output circuitry 270 may be used for transmitting and receiving signals over interconnection resources 280 when communicating with other circuits.
For example, integrated circuit 290 may transmit serialized data signals at a given transmission rate to another integrated circuit over interconnection resources 280 using input/output circuitry 270. If desired, parallel data signals may be transmitted using input/output circuitry 270. As an example, a plurality of data signals may be transmitted in parallel and in parallel with a differential clock signal that includes positive and negative clock signals that are complementary relative to each other. In this example, clock-data phase alignment circuitry 250 of the signal receiving integrated circuit may ensure a predetermined phase shift between the clock and data signals to allow for the sampling of the data signal in the signal receiving integrated circuit.
Integrated circuit 290 may be programmable such as integrated circuit 300 shown in
Input-output circuitry 320 may include general-purpose input-output (GPIO) circuitry, which may be configured to be an input or an output. If desired, input-output circuitry 320 may include interface circuitry that accommodates communications using different protocols and/or standards. Protocols and standards that may be implemented using input-output circuitry 320 may include network standards and protocols such as low-voltage differential signaling (LVDS), Interlaken, Peripheral Component Interconnect Express (PCIe), Ethernet, gigabit Ethernet (GigE) such as the 10 Gigabit Attachment Unit Interface (XAUI), HyperTransport, System Packet Interface (SPI) 4.2, or other communications network standards or protocols. Memory standards such as double-data-rate (DDR) memory standards may be implemented using input-output circuitry 320. These examples are merely illustrative. If desired, any suitable interface and any number of desired interfaces for communicating with external circuitry may be implemented using input-output circuitry 320. Input-output circuitry 320 may be coupled to corresponding input-output pins 340.
Interconnection resources 360 such as global and local vertical, horizontal, and diagonal conductive lines and buses may be used to route signals on integrated circuit 300. Interconnection resources 360 may include fixed interconnects such as conductive lines. If desired, interconnection resources 360 may include programmable interconnects (i.e., programmable connections between respective fixed interconnects). Interconnection resources 360 may sometimes be referred to herein as interconnect resources or interconnects (e.g., interconnects formed from combinations of fixed interconnects and programmable interconnects).
Interconnects 360 may be used to couple circuitry in the integrated circuit. For example, interconnects 360 may interconnect regions of programmable logic such as programmable logic regions 380. Programmable logic regions 380 may sometimes be referred to as logic array blocks (LABs) or programmable circuit regions. Programmable logic regions 380, may, if desired, contain groups of smaller logic regions. These smaller logic regions, which may sometimes be referred to as logic elements (LEs), adaptive logic modules (ALMs), or configurable logic blocks (CLBs) may be interconnected using local interconnection resources.
Programmable logic regions 380 may include combinational and sequential logic circuitry. For example, programmable logic regions 380 may include look-up tables, logic gates (e.g., logic AND gates, logic OR gates, logic exclusive OR gates, inverter gates, etc.), synchronous circuitry (e.g., registers or flip-flops, latches, random-access memory (RAM), read-only memory (ROM), shift register logic (SRL), first-in first-out (FIFO) circuits, stacks or last-in first-out (LIFO) circuits, etc.), arithmetic operators (e.g., adders, multipliers, etc.), and multiplexers. Programmable logic regions 380 may be configured to perform a custom logic function.
Programmable logic regions 380 may contain programmable elements 350. Programmable elements 350 are sometimes also referred to as configuration RAM (CRAM) cells, configuration memory, memory cells, configuration cells, or configuration elements. Programmable elements 350 may be based on any suitable programmable technology, which may be volatile or non-volatile, such as fuses, antifuses, electrically-programmable read-only-memory technology, random-access memory cells, mask-programmed elements, optically programmable electron spin memory, etc. As an example, programmable elements 350 may be formed from memory cells.
During programming, configuration data may be loaded into programmable elements 350 using input-output pins 340 and input-output circuitry 320. As an example, consider the scenario in which programmable elements 350 are random-access memory (RAM) cells. In this scenario, the RAM cells may store the configuration data during write access operations (e.g., as part of a boot procedure that integrated circuit 300 may perform during power-up, as part of partial reconfiguration of integrated circuit 300, etc.).
Programmable elements 350 may provide static control output signals for controlling the state of logic components in programmable logic 380. In certain embodiments, the output signals generated by programmable elements 350 may be applied to gates of metal-oxide-semiconductor (MOS) transistors. For example, the static control output signals may control pass gate transistors. These pass gate transistors may form a multiplexer in the programmable interconnect of interconnect resources 360. Thus, controlling the gates of the pass gate transistors may contribute to implementing a routing path in interconnect resources 360 between two circuits that are located in programmable logic regions 380.
In some scenarios, programmable elements 350 may provide static data output signals for programmable circuitry. For example, look-up tables may include programmable elements 350 that produce static data output signals. In this scenario, control signals may configure the look-up tables to provide the static data output signals at look-up table outputs based on the look-up table inputs.
The circuitry of integrated circuit 300 may be organized using any suitable architecture. As an example, programmable logic 380 of integrated circuit 300 may be organized in a series of rows and columns of programmable logic regions, each of which may contain multiple smaller programmable logic regions.
The logic resources of integrated circuit 300 may be interconnected by interconnection resources 360 such as associated vertical, horizontal, diagonal, and through-silicon-via (TSV) conductors. These conductors may include global conductive lines that span substantially all of integrated circuit 300, fractional global lines such as half-lines or quarter lines that span part of integrated circuit 300, staggered lines of a particular length (e.g., sufficient to interconnect a predetermined number of resources in programmable logic regions 380 or a sufficient to interconnect a predetermined number of programmable logic regions 380, etc.), smaller local lines, or any other suitable interconnection resource arrangement.
If desired, the programmable logic regions 380 of integrated circuit 300 may be arranged in more levels or layers in which multiple logic regions are interconnected to form still larger portions of logic regions. Other device arrangements may include programmable logic regions that are not arranged in rows and columns.
Integrated circuit 300 may be part of a data processing system that includes one or more of the following components: a processor, memory, I/O circuitry, and peripheral devices. The data processing system can be used in a wide variety of applications, such as computer networking, data networking, instrumentation, video processing, digital signal processing, or any suitable other application where the advantage of using an integrated circuit with programmable or re-programmable logic is desirable.
Integrated circuit 300 may be used to perform a variety of different logic functions. For example, integrated circuit 300 may be configured as a processor or controller that works in cooperation with a system processor. Integrated circuit 300 may also be used as an arbiter for arbitrating access to a shared resource in the data processing system. In yet another example, the integrated circuit 300 may be configured as an interface between a processor and one of the other components in the system. In one embodiment, the integrated circuit 300 may be one of the families of devices owned by the assignee.
In addition to the relatively large blocks of programmable logic that are shown in
For example, integrated circuit 300 may receive serialized data signals at a given transmission rate from another circuit over pins 340 and input/output circuitry 320, and/or integrated circuit 300 may receive parallel data signals at a given rate from another circuit using parallel input/output circuitry 320. In some scenarios, integrated circuit 300 may receive a differential clock signal in addition to the parallel data signals for the purpose of implementing a source synchronous interface in integrated circuit 300.
In such a scenario, integrated circuit 300 may implement clock-data phase alignment circuitry. For example, integrated circuit 300 may receive the clock and data signals with its input/output circuitry 320 from where the clock and data signals may be sent over interconnection resources 360 to clock-data phase alignment circuitry which may be implemented by programmable components in a programmable logic region 380. In some embodiments, integrated circuit 300 may include specialized circuitry for implementing at least a portion of the clock-data phase alignment circuitry
The clock-data phase alignment circuitry may generate and maintain a predetermined phase shift between the clock and data signals at the arrival of the respective signals at storage circuitry to ensure successful sampling of the data signals.
The above example was described with the transmitting circuitry being located in another circuit. This other circuit may be any type of circuit such as one of circuits 110 and/or 130 of
A clock distribution network such as clock distribution network 430 may include wired connections and buffers that allow to distribute a clock signal with predictable delay and minimal skew to clocked elements (e.g., registers or flip-flops, RAMs, etc.) in a circuit. Thus, the clock signal that is propagated through clock distribution network 430 arrives with a minimal difference in time at all registers 440 . . . 449.
A clock distribution network is sometimes also referred to as a clock tree. A clock distribution network may have an input, which is sometimes also referred to as a root, and a plurality of outputs, which are sometimes also referred to as leaves. The paths from the root to the leaves is sometimes also referred to as branches.
The clock-data phase alignment circuitry may receive a differential clock signal that includes clock signals CLK_P and CLK_N that are complementary to each other and (N+1) data signals D_0 . . . D_N. If desired, data signals D_0 . . . D_N may be differential signals, i.e., each of data signals D_0 . . . D_N may have a first and a second component that are complementary to each other. As an example, a first component of signal D_0 may have a rising edge when the second component of signal D_0 has a falling edge and vice versa. Together, the first and second components form an eye-diagram, and the capture of either of the first and second components samples the corresponding data signal. As shown in
The time interval between condition changes of data signals D_0 . . . D_N (e.g., the time interval between a positive edge and a negative edge of the first component of data signal D_0) is sometimes also referred to as unit interval (UI), pulse time, bit period, or symbol duration time. In other words, a unit interval (UI), pulse time, or symbol duration time is the time taken in a data stream by each subsequent symbol or the time required to transmit one bit, which is equal to the time between a positive and a negative edge of clock signal CLK_P or CLK_N (i.e., half a clock period of clock signal CLK_P or CLK_N for clock signals with a 50/50 duty cycle).
The clock-data phase alignment circuitry may receive clock signals CLK_P and CLK_N with clock phase adjustment circuitry 410. Clock phase adjustment circuitry 410 may propagate one of the clock signals CLK_P and CLK_N (e.g., CLK_P) to clock distribution network 430. Clock distribution network 430 may propagate the clock signal through at least one clock buffer and provide a delayed first clock signal CLK_MID_J to register 440. Clock distribution network 430 may provide the same delayed first clock signal CLK_MID_J or another instance of the delayed first clock signal CLK_MID_I to register 449. Similarly, clock distribution network 430 may provide the same delayed first clock signal CLK_MID_J (or CLK_MID_I) or another instance of the delayed first clock signal CLK_MID_K to replica clock distribution network 420.
The delayed first clock signals CLK_MID_I, CLK_MID_J, and CLK_MID_K may be phase shifted by half a unit interval compared to data signals D_0 . . . D_N, thereby enabling the sampling of data signals D_0 . . . D_N in registers 440 . . . 449, respectively, based on clock edges (e.g., upon a rising edge, a falling edge, or a rising and a falling edge).
The replica clock distribution network 420 may be coupled between clock distribution network 430 and clock phase adjustment circuitry 410. Replica clock distribution network 420 may include a copy of a subset of branches of clock distribution network 430 (e.g., replica clock distribution network 420 may replicate one branch of clock distribution network 430). If desired, replica clock distribution network 420 may include a complete copy of clock distribution network 430.
Replica clock distribution network 420 may receive the delayed first clock signal (e.g., delayed first clock signal CLK_MID_K) and propagate the delayed first clock signal through at least one second clock buffer to provide a further delayed first clock signal to clock phase adjustment circuitry 410.
Adjustable delay circuit 515 may receive one of the clock signals CLK_P and CLK_N (e.g., CLK_P) and delay the clock signal as directed by delay control circuit 555 before providing the clock signal through a clock distribution network (e.g., clock distribution network 430 of
If desired, delay control circuit 555 may adjust the delay of adjustable delay circuit 515 such that the total delay of the clock signal through the clock phase adjustment circuitry and the clock distribution network results in a phase shift of 90 degrees between the data signal and the clock signal. This delay may correspond to half a unit interval (UI) delay between the clock input and the clock port of the storage circuit, thereby resulting in a clocking event (i.e., a rising or falling edge of the clock signal) at the center of the eye of the data signal, and thus enabling the capture of the data signal with the storage circuit.
Consider the scenario in which the replica clock distribution network has the same delay as the clock distribution network and that delay control circuit 555 has adjusted adjustable delay circuit 545 to have the same delay as adjustable delay circuit 515. In this scenario, a clock signal (e.g., CLK_P) that is propagated through adjustable delay circuit 515, the clock distribution network, the replica clock distribution network, and adjustable delay circuit 545 arrives at phase detector 565 with a phase shift of 180 degrees relative to the same clock signal (e.g., CLK_P) at the clock input, which may correspond to one unit interval (UI) delay between the clock input and phase detector 565. In other words, the delayed clock signal which is sometimes also referred to as the feedback clock signal or the feedback signal (e.g., CLK_P) arrives in phase with the complementary clock signal (e.g., CLK_N), which phase detector 565 may use as a reference signal.
Phase detector 565 may detect a phase difference between the reference signal (e.g., CLK_N) and the feedback clock signal (e.g., CLK_P), generate a corresponding control signal, and provide the control signal to delay control circuit 555. Delay control circuit 555 may adjust the delays of adjustable delay circuits 515 and 545 accordingly.
For example, if the reference signal arrives before the feedback signal, phase detector 565 may direct delay control circuit 555 to reduce the delays of adjustable delay circuits 515 and 545. In contrast, if the reference signal arrives after the feedback signal, phase detector 565 may direct delay control circuit 555 to increase the delays of adjustable delay circuits 515 and 545.
An embodiment of a phase detector circuit 565 within illustrative clock phase adjustment circuitry coupled to first and second clock distribution networks (e.g., clock distribution network 430 and replica clock distribution network 420 of
As shown in
As shown, adjustable delay circuit 510 may receive clock signal CLK_P and delay the clock signal as directed by FSM 550. Clock distribution network 520 may propagate the clock signal from adjustable delay circuit 510 through at least one clock buffer and provide a delayed first clock signal CLK_MID_J to register 570. Clock distribution network 520 may provide the same delayed first clock signal CLK_MID_J or another instance of the delayed first clock signal CLK_MID_I to register 580.
Similarly, clock distribution network 520 may provide the same delayed first clock signal CLK_MID_J (or CLK_MID_I) or another instance of the delayed first clock signal CLK_MID_K to replica clock distribution network 530.
If desired, FSM 550 may adjust the delay of adjustable delay circuit 510 such that the delayed first clock signals CLK_MID_I, CLK_MID_J, and CLK_MID_K are phase shifted by 90 degrees relative to data signals D_0 . . . D_N and clock signal CLK_P. This delay may correspond to half a unit interval (UI) delay between CLK_P and the clock port of the storage circuit, thereby resulting in a clocking event (i.e., a rising or falling edge of the clock signals CLK_MID_I, CLK_MID_J, and CLK_MID_K) at the center of the eye of the respective data signal D_0 . . . D_N, and thus enabling the capture of the data signal with the registers 570 . . . 580.
Replica clock distribution network 530 may include a copy of a subset of branches of clock distribution network 520 (e.g., replica clock distribution network 530 may replicate one branch of clock distribution network 520). If desired, replica clock distribution network 530 may include a complete copy of clock distribution network 520.
Replica clock distribution network 530 may receive the delayed first clock signal (e.g., delayed first clock signal CLK_MID_K) and propagate the delayed first clock signal through at least one second clock buffer to provide a further delayed first clock signal to adjustable delay circuit 540.
Consider the scenario in which replica clock distribution network 530 has the same delay as clock distribution network 520 and that FSM 550 has adjusted adjustable delay circuit 540 to have the same delay as adjustable delay circuit 510. In this scenario, clock signal CLK_P that is propagated through adjustable delay circuit 510, clock distribution network 520, replica clock distribution network 530, and adjustable delay circuit 540 arrives at register 560 as signal CLK_P_DLY with a phase shift of 180 degrees relative to clock signal CLK_P, which may correspond to one unit interval (UI) delay. In other words, ideally the delayed clock signal CLK_P_DLY which is sometimes also referred to as the feedback clock signal or the feedback signal arrives in phase with the complementary clock signal CLK_N, which is sometimes also referred to as the reference clock signal or the reference signal.
Register 560 may act as a phase detector. Consider the scenario in which register 560 stores data at a rising edge event of clock signal CLK_P_DLY. In this scenario, if the feedback clock signal CLK_P_DLY arrives before the reference clock signal CLK_N, register 560 may store a logic ‘0’, whereas if the feedback clock signal CLK_P_DLY arrives after the reference clock signal CLK_N, register 560 may store a logic ‘1’.
The signal stored in register 560 may thus serve as a control signal to FSM 550, which may adjust the delays of adjustable delay circuits 510 and 540 accordingly: If register 560 stores a logic ‘1’, FSM 550 may reduce the adjusted delays of adjustable delay circuits 510 and 540. In contrast, if register 560 stores a logic ‘0’, FSM 550 may increase the adjusted delays of adjustable delay circuits 510 and 540.
FSM 560 may include circuitry that prevents glitches when adjusting the delays of adjustable delay circuits 510 and 540. If desired, FSM 560 may receive a lock request signal and provide a status signal upon successful locking a predetermined phase shift between the reference clock signal CLK_N and the feedback clock signal CLK_P_DLY.
Clock signals CLK_P and CLK_N are also complementary to each other and have a duty cycle of 50/50 (i.e., the time during which the clock signal is logic ‘1’ is equal to the time during which the clock signal is logic ‘0’). As shown, the edges of the clock signals ClK_P and CLK_N are aligned with each other, and thus a unit interval may be the time between a rising edge of clock signal CLK_P at time 610 and a falling clock edge of clock signal CLK_P at time 620.
As shown in
At time 640, the rising edge of clock signal CLK_MID_J is in the center of the eye of data signal D_0 and thus enables the capture of data signal D_0 with register 570 of
As shown in
Thus, register 560 may act as a phase detector. If clock signal CLK_P_DLY arrives at register 560 early (i.e., in less than one unit delay, before time 650), register 560 may store a logic ‘0’, whereas if clock signal CLK_P_DLY arrives at register 560 late (i.e., in more than one unit delay, after time 650), register 560 may store a logic ‘1’.
The signal stored in register 560 may thus serve as a control signal to FSM 550, which may adjust the delays of adjustable delay circuits 510 and 540 accordingly: If register 560 stores a logic ‘1’, FSM 550 may reduce the adjusted delays of adjustable delay circuits 510 and 540 so that clock signal CLK_P_DLY arrives earlier. In contrast, if register 560 stores a logic ‘0’, FSM 550 may increase the adjusted delays of adjustable delay circuits 510 and 540 so that clock signal CLK_P_DLY arrives later.
During step 710, clock phase adjustment circuitry may receive a differential clock with first and second clock signals that are complementary to each other. For example, clock phase adjustment circuitry 410 of
During step 720, the clock-data phase alignment circuitry may propagate the first clock signal through at least one first clock buffer in a first clock distribution network to provide a delayed first clock signal. For example, the clock-data phase alignment circuitry of
During step 730, the clock-data phase alignment circuitry may store a data signal based on the delayed first clock signal in a storage circuit. For example, register 440 in
During step 740, the clock-data phase alignment circuitry may propagate the delayed first clock signal through at least one second clock buffer in a second clock distribution network that is coupled between the first clock distribution network and the clock phase adjustment circuitry to provide a further delayed first clock signal to the clock phase adjustment circuitry. For example, the clock-data phase alignment circuitry of
The method and apparatus described herein may be incorporated into any suitable circuit or system of circuits. For example, the method and apparatus may be incorporated into numerous types of devices such as microprocessors or other integrated circuits. Exemplary integrated circuits include programmable array logic (PAL), programmable logic arrays (PLAs), field programmable logic arrays (FPGAs), electrically programmable logic devices (EPLDs), electrically erasable programmable logic devices (EEPLDs), logic cell arrays (LCAs), field programmable gate arrays (FPGAs), coarse-grained reconfigurable architectures (CGRAs), digital signal processing (DSP) circuits, application specific standard products (ASSPs), application specific integrated circuits (ASICs), just to name a few.
The integrated circuit described herein may be part of a data processing system that includes one or more of the following components: a processor; memory; I/O circuitry; and peripheral devices. The data processing system can be used in a wide variety of applications, such as computer networking, data networking, instrumentation, video processing, digital signal processing, or any suitable other application where the advantage of using a source synchronous interface circuit is desirable.
The integrated circuit may be configured to perform a variety of different logic functions. For example, the integrated circuit may be configured as a processor or controller that works in cooperation with a system processor. The integrated circuit may also be used as an arbiter for arbitrating access to a shared resource in the data processing system. In yet another example, the integrated circuit may be configured as an interface between a processor and one of the other components in the system. In one embodiment, the integrated circuit may be one of the families of devices owned by the assignee.
Although the method operations were described in a specific order, it should be understood that other operations may be performed in between described operations, described operations may be adjusted so that they occur at slightly different times or described operations may be distributed in a system which allows the occurrence of the processing operations at various intervals associated with the processing.
The foregoing is merely illustrative of the principles of the embodiments and various modifications can be made by those skilled in the art without departing from the scope and spirit of the embodiments disclosed herein. The foregoing embodiments may be implemented individually or in any combination. The above described embodiments are presented for purposes of illustration and not of limitation, and the present invention is limited only by the claims that follow.
This application is a continuation of U.S. patent application Ser. No. 15/226,037 filed Aug. 2, 2016, entitled, “DYNAMIC CLOCK-DATA PHASE ALIGNMENT IN A SOURCE SYNCHRONOUS INTERFACE CIRCUIT”, which is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5509037 | Buckner | Apr 1996 | A |
5617452 | Haulin | Apr 1997 | A |
5852640 | Kliza | Dec 1998 | A |
5889436 | Yeung | Mar 1999 | A |
6075832 | Geannopoulos | Jun 2000 | A |
6127865 | Jefferson | Oct 2000 | A |
6219384 | Kliza | Apr 2001 | B1 |
6232806 | Woeste | May 2001 | B1 |
6396887 | Ware | May 2002 | B1 |
6622255 | Kurd | Sep 2003 | B1 |
6630855 | Fayneh | Oct 2003 | B2 |
6867616 | Venkata | Mar 2005 | B1 |
7034597 | Mo | Apr 2006 | B1 |
7046174 | Lui | May 2006 | B1 |
7075365 | Starr | Jul 2006 | B1 |
7107477 | Singh | Sep 2006 | B1 |
7272677 | Venkata | Sep 2007 | B1 |
7295641 | Wortman | Nov 2007 | B1 |
7340021 | Churchill | Mar 2008 | B1 |
7346873 | Mandry | Mar 2008 | B2 |
7486702 | Yang | Feb 2009 | B1 |
7493461 | Thorne | Feb 2009 | B1 |
7499513 | Tetzlaff | Mar 2009 | B1 |
7515664 | Yeoh | Apr 2009 | B1 |
7545196 | Hutton | Jun 2009 | B1 |
7555667 | Burney | Jun 2009 | B1 |
7587686 | Schleicher, II | Sep 2009 | B1 |
7590211 | Burney | Sep 2009 | B1 |
7642812 | Xue | Jan 2010 | B1 |
7644296 | Burney | Jan 2010 | B1 |
7664978 | Burney | Feb 2010 | B2 |
7676768 | Bourgeault | Mar 2010 | B1 |
7715467 | Burney | May 2010 | B1 |
7737751 | Lai | Jun 2010 | B1 |
7839966 | Masepohl | Nov 2010 | B1 |
8115512 | O'Dwyer | Feb 2012 | B1 |
8115530 | Lewis | Feb 2012 | B2 |
8149038 | Sung | Apr 2012 | B1 |
8191028 | Bourgeault | May 2012 | B1 |
8350595 | Kanno | Jan 2013 | B2 |
8464088 | Nguyen | Jun 2013 | B1 |
8519763 | Ravi | Aug 2013 | B2 |
8610474 | Aryanfar | Dec 2013 | B2 |
8612795 | Ding | Dec 2013 | B1 |
8643414 | Navid | Feb 2014 | B1 |
8812893 | Venkata | Aug 2014 | B1 |
8836394 | Zerbe | Sep 2014 | B2 |
8847626 | Chong | Sep 2014 | B1 |
8860475 | Yeoh | Oct 2014 | B1 |
9065453 | Aryanfar | Jun 2015 | B2 |
9160350 | Zerbe | Oct 2015 | B2 |
9432025 | Khor | Aug 2016 | B1 |
9503057 | Venkata | Nov 2016 | B1 |
9577649 | Liong | Feb 2017 | B1 |
9588176 | Hutton | Mar 2017 | B1 |
9602106 | Bourgeault | Mar 2017 | B1 |
10218360 | Patil | Feb 2019 | B2 |
20010038674 | Trans | Nov 2001 | A1 |
20040213051 | Lin | Oct 2004 | A1 |
20050259775 | Chang | Nov 2005 | A1 |
20050262373 | Kim | Nov 2005 | A1 |
20060188050 | Jenkins | Aug 2006 | A1 |
20060262891 | Faulkner | Nov 2006 | A1 |
20070230513 | Talbot | Oct 2007 | A1 |
20080054959 | Fujisawa | Mar 2008 | A1 |
20080062780 | Cheng | Mar 2008 | A1 |
20080263381 | Khor | Oct 2008 | A1 |
20100117697 | Kanno | May 2010 | A1 |
20100289544 | Lee | Nov 2010 | A1 |
20110291719 | Ok | Dec 2011 | A1 |
20120187988 | Aryanfar | Jul 2012 | A1 |
20120187993 | Kanno | Jul 2012 | A1 |
20120223754 | Lewis | Sep 2012 | A1 |
20120250811 | Misek | Oct 2012 | A1 |
20120314721 | Bulzacchelli | Dec 2012 | A1 |
20130033946 | Ware | Feb 2013 | A1 |
20130148447 | Shaeffer | Jun 2013 | A1 |
20130249612 | Zerbe | Sep 2013 | A1 |
20140195728 | Hsu | Jul 2014 | A1 |
20140211571 | Lee | Jul 2014 | A1 |
20140247683 | Riho | Sep 2014 | A1 |
20140333356 | Aryanfar | Nov 2014 | A1 |
20150003574 | Mozak | Jan 2015 | A1 |
20160246325 | Chalasani | Aug 2016 | A1 |
20180004878 | Hutton | Jan 2018 | A1 |
20180006653 | Duong | Jan 2018 | A1 |
20180041328 | Patil | Feb 2018 | A1 |
Entry |
---|
Advisory Action for U.S. Appl. No. 15/226,037, dated Apr. 9, 2018, 3 Pages.—Cited in IDS Submitted Jan. 4, 2019. |
Final Office Action for U.S. Appl. No. 15/226,037, dated Nov. 27, 2017,10 pages—Cited in IDS Submitted Jan. 4, 2019. |
First Office Action for U.S. Appl. No. 15/226,037, dated May 23, 2017, 9 pages.—Cited in IDS Submitted Jan. 4, 2019. |
Advisory Action for U.S. Appl. No. 15/226,037, dated Apr. 9, 2018, 3 pages. |
Final Office Action for U.S. Appl. No. 15/226,037, dated Nov. 27, 2017, 10 pages. |
First Office Action for U.S. Appl. No. 15/226,037, dated May 23, 2017, 9 pages. |
International Search Report and Written Opinion for PCT Patent Application No. PCT/US17/40999, dated Oct. 13, 2017, 17 pages. |
Number | Date | Country | |
---|---|---|---|
20190149154 A1 | May 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15226037 | Aug 2016 | US |
Child | 16246629 | US |