MODULAR MEMORY CONTROLLER CLOCKING ARCHITECTURE
According to one embodiment, a memory controller is disclosed. The memory controller includes a phase locked loop (PLL) to generate a differential reference clock and a first clocking component coupled to the PLL. The first clocking component includes a first delay locked loop (DLL) to receive the reference clock and to generate transmit and receive delay de-skew clock signals, a first set of phase interpolators to provide data transmit de-skewing and a first set of slave delay lines to provide data receive de-skewing.
The present invention relates to computer systems; more particularly, the present invention relates to interfacing with memory devices.
BACKGROUNDA memory controller is an integrated circuit located on the motherboard, or processor die, within a computer system that manages the flow of data to and from a main memory device. Particularly, memory controllers include logic necessary to read and write data to dynamic RAM (DRAM). A component of the logic includes a clocking architecture to carry out transactions with the DRAM.
The clocking architecture typically includes special delay locked loops (DLL) that are used to transmit de-skew and receive de-skew. However, the conventional clocking architecture implements a relatively large number of logic components to control all de-skewing for a single memory controller channel.
The invention is illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements, and in which:
A modular memory controller clocking architecture is described. In the following detailed description of the present invention numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be apparent to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form, rather than in detail, in order to avoid obscuring the present invention.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
In a further embodiment, a chipset 107 is also coupled to interconnect 105. Chipset 107 may include a memory control hub (MCH) 110. MCH 110 may include a memory controller 112 that is coupled to a main system memory 115. Main system memory 115 stores data and sequences of instructions that are executed by CPU 102 or any other device included in system 100.
In one embodiment, main system memory 115 includes one or more DIMMs incorporating dynamic random access memory (DRAM) devices; however, main system memory 115 may be implemented using other memory types. Additional devices may also be coupled to interconnect 105, such as multiple CPUs and/or multiple system memories.
MCH 110 may be coupled to an input/output control hub (ICH) 140 via a hub interface. ICH 140 provides an interface to input/output (I/O) devices within computer system 100. ICH 140 may support standard I/O operations on I/O interconnects such as peripheral component interconnect (PCI), accelerated graphics port (AGP), universal serial interconnect (USB), low pin count (LPC) interconnect, or any other kind of I/O interconnect (not shown). In one embodiment, ICH 140 is coupled to a wireless transceiver 160.
Notwithstanding the embodiment, memory controller performs memory transactions with main memory 115 by transferring data between computer system 100 and memory 115. To perform the memory transactions, memory controller 112 includes a clocking mechanism having delay locked loops (DLL) that are used to transmit de-skew and receive de-skew.
On the transmit side shown in
The DLL sets the requisite delay in each of a number of delay elements within the DLL. This delay tracks Process, Voltage & Temperature (PVT) variations, is converted to an analog voltage (bias) and coupled to the slave delay lines. The PI coupled to each slave delay line creates a finer step of the delay and distributes the resultant clocks to each of the high speed 10 transmitters, such as the Stub Series Termination Logic (SSTL) driver.
In a memory controller implementing a conventional clocking mechanism, there are typically eleven groups of transmitters that are skewed independently. Hence, there are eleven slave delay lines and corresponding clock buffers in the transmit direction. These clocking circuitries are located at a centralized location, as shown in
The problem with the conventional memory controller clocking mechanism is that the memory controller uses a total of nine DLLs & nineteen slave delay lines to control all of the de-skewing in a one channel memory controller. Further, the transmit deskew delays are generated at one location and then transmitted to the individual I/O transmitters, which are far away from the generation location. This results in area and power inefficiencies, as well as lost deskew setting accuracy when the data rate is scaled up.
According to one embodiment, memory controller 112 includes a clocking architecture for both transmit and receive clock circuitries that reduces the number of delay locked loops and the number of slave delay lines, resulting in a reduction in silicon area and power, while providing comparable to better resolution to the conventional mechanism.
On the transmit side of module 420, MDLL 510 generates de-skew clocks together with a set of PIs as well as maintaining the required delay. The PIs are now used for transmit bit de-skew. Therefore in one embodiment, eleven PIs are implemented, as opposed to the eleven slave delay lines employed in conventional transmit clocking components. Because the size of each PI is smaller than each slave delay line, there is a reduction in the silicon area needed to fabricate module 420.
In one embodiment, the delay generated by MDLL 510 is converted to an analog bias voltage, as shown in
The bias voltage is then transmitted from the transmit component to the slave delay line 520 of the receive component. The slave delay lines also include delay elements coupled to a PI via a multiplexer. The slave delay lines receive a channel receive/clock strobe.
As shown above, the modular clocking mechanism enables a reduction of the number DLLs from nine to four, and the number of slave delay lines from nineteen to eight. The de-skew resolution is provided back by the additional PIs. Therefore, the modular clocking mechanism has a superior power to data rate scaling than conventional architectures due to the optimal and efficient use of circuit components.
Whereas many alterations and modifications of the present invention will no doubt become apparent to a person of ordinary skill in the art after having read the foregoing description, it is to be understood that any particular embodiment shown and described by way of illustration is in no way intended to be considered limiting. Therefore, references to details of various embodiments are not intended to limit the scope of the claims, which in themselves recite only those features regarded as essential to the invention.
Claims
1. A memory controller comprising:
- a phase locked loop (PLL) to generate a differential reference clock; and
- a first clocking component, coupled to the PLL, including: a first delay locked loop (DLL) to receive the reference clock and to generate transmit and receive delay de-skew clock signals; a first set of phase interpolators to provide data transmit de-skewing; and a first set of slave delay lines to provide data receive de-skewing.
2. The memory controller of claim 1 further comprising a second clocking component, coupled to the PLL, including:
- a second delay locked loop (DLL) to receive the reference clock and to generate transmit and receive delay de-skew clock signals;
- a second set of phase interpolators to provide data transmit de-skewing; and
- a second set of slave delay lines to provide data receive de-skewing.
3. The memory controller of claim 1 further comprising high speed input/output circuitry coupled to the first and second clocking components.
4. The memory controller of claim 1 wherein the first DLL comprises:
- a set of delay elements to receive the reference clock and to delay the reference clock; and
- a phase deductor to receive the delayed reference clock and to generate a bias voltage.
5. The memory controller of claim 4 wherein the bias voltage is provided to the first set of slave delay lines.
6. The memory controller of claim 4 further comprising a multiplexer coupled between the set of delay elements and a PI.
7. The memory controller of claim 5 wherein the first set of slave delay lines comprise a second set of delay elements to receive a strobe clock and to delay the strobe clock.
8. The memory controller of claim 1 wherein the PLL provides a low jitter reference clock.
9. A method comprising:
- a delay locked loop (DLL) receiving a differential reference clock from a phase locked loop (PLL); and
- the DLL generating transmit and receive delay de-skew clock signals;
- a set of phase interpolators transmitting data providing transmit de-skewing; and
- a set of slave delay lines providing data receive de-skewing.
10. The method of claim 9 wherein the DLL generating delay de-skew clock signals comprises:
- receiving the reference clock at a set of delay elements within the DLL; an
- delaying the reference clock.
11. The method of claim 10 further comprising receiving the delayed reference clock at a phase deductor.
12. The method of claim 11 further comprising the phase deductor generating a bias voltage.
13. The method of claim 12 further comprising receiving the bias voltage at the set of slave delay lines.
14. A computer system comprising:
- a dynamic random access memory (DRAM); and
- memory controller coupled to the DRAM, including: a phase locked loop (PLL) to generate a differential reference clock; and a first clocking component, coupled to the PLL, having: a first delay locked loop (DLL) to receive the reference clock and to generate transmit and receive delay de-skew clock signals; a first set of phase interpolators to provide data transmit de-skewing; and a first set of slave delay lines to provide data receive de-skewing.
15. The computer system of claim 14 wherein the memory controller further comprises a second clocking component, coupled to the PLL, including:
- a second delay locked loop (DLL) to receive the reference clock and to generate transmit and receive delay de-skew clock signals;
- a second set of phase interpolators to provide data transmit de-skewing; and
- a second set of slave delay lines to provide data receive de-skewing.
16. The computer system of claim 14 wherein the memory controller further comprises high speed input/output circuitry coupled to the first and second clocking components.
17. The computer system of claim 14 wherein the first DLL comprises:
- a set of delay elements to receive the reference clock and to delay the reference clock; and
- a phase deductor to receive the delayed reference clock and to generate a bias voltage.
18. The computer system of claim 17 wherein the bias voltage is provided to the first set of slave delay lines.
19. The computer system of claim 17 wherein the memory controller further comprises a multiplexer coupled between the set of delay elements and a PI.
20. The computer system of claim 18 wherein the first set of slave delay lines comprise a second set of delay elements to receive a strobe clock and to delay the strobe clock.
Type: Application
Filed: Dec 28, 2006
Publication Date: Jul 3, 2008
Inventors: Hing To (Cupertino, CA), Mamun Ur Rashid (Folsom, CA)
Application Number: 11/647,656
International Classification: G06F 1/04 (20060101);