FIELD
Methods and systems consistent with this invention may relate to writing data to a memory, and in particular may relate to a controller circuit for writing data to a memory.
BACKGROUND
Generally, a memory controller circuit coordinates writing and reading data to and from a memory. The data may come from a central processing unit (CPU), for example. As the capacity of memory chips increases and CPUs become faster, there is a need for data to be stored and retrieved in memory chips at increasing speeds.
FIG. 1 is a block diagram of a controller circuit 102 and a memory 104 connected together. In this example, four signals span between controller 102 and memory 104: a clock signal MCLK, a data signal PD, a command signal CMD, and a data strobe signal DQS. FIG. 2 is a timing diagram illustrating some of the challenges of writing data to a memory. In this example, command signal CMD, data signal PD, data strobe signal DQS, and clock signal MCLK are all supplied from controller circuit 102 to memory circuit 104.
In the example of FIG. 2, command signal CMD triggers a write command at the rising edge of the signal MCLK. Data strobe signal DQS oscillates on and off at some time after the write command. Memory 104 uses strobe signal DQS to “clock” or “latch” in data signal PD into memory 104 at the rising and/or falling edge of strobe signal DQS. In this example, the rising edge of strobe signal DQS is timed so that it is in the “middle” of a data bit D0 of data signal PD. For example, as shown in FIG. 2, the rising edge of strobe signal DQS occurs at a data setup time Tds after the start of bit D0, but before the end of bit D0 by the data hold time Tdh. Further, the falling edge of strobe signal DQS is timed so that it is in the “middle” of a data bit D1 of data signal PD. For example, as shown in FIG. 2, the falling edge of strobe signal DQS occurs at a data setup time Tds after the start of bit D1, but before the end of bit D1 by the data hold time Tdh.
One of the challenges of controller circuit 102 is to supply data strobe signal DQS, data signal PD, and clock signal MCLK to memory 104 with precise timing so that the data is properly latched into memory 104 without error. For example, the values of Tds and Tdh may be 0.5 nanoseconds, a very short period of time.
SUMMARY
Methods and systems consistent with this invention write data to a memory. Such methods and systems may generate a clock signal, generate an intermediate clock signal from the clock signal using a clock tree buffer, delay the intermediate clock signal to form a data strobe signal, and write the data to the memory using the data strobe signal and a memory clock signal. Such methods and systems may also delay the intermediate clock signal to form the memory clock signal.
It is understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate one several embodiments of the invention and together with the description, serve to explain the principles of the invention.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of a controller circuit and a memory connected together;
FIG. 2 is a timing diagram for writing data to a memory;
FIG. 3 is a circuit diagram of one embodiment of a control circuit consistent with this invention;
FIG. 4 is a flow chart of a method consistent with this invention for programming the circuit of FIG. 3;
FIG. 5 is a signal timing diagram consistent with this invention;
FIG. 6 is a flow chart of a method consistent with this invention for writing data to a memory; and
FIG. 7 is a flow chart of a method consistent with this invention for writing data to a memory with a two-phase-shifted base clock signal.
DESCRIPTION OF THE EMBODIMENTS
Reference will now be made in detail to the present exemplary embodiments of the invention, examples of which are illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
FIG. 3 is a circuit diagram of one embodiment of a control circuit consistent with this invention. A phase locked loop 310 supplies a clock signal CLK and a clock signal CLKQ, where clock signal CLKQ is 90 degrees ahead of or leading clock signal CLK. The clock signals CLK and CLKQ may be generated from the same base clock signal. The clock signals CLK and CLKQ may also be generated from the same clock generator. Clock signal CLK is fed through a clock tree buffer (CTS) 312 forming signal CTS—CLK (not shown) at node A. Signal CTS—CLK is fed through an inverter 322, forming signal CTS—CLK˜ (not shown), which is 180 degrees out of phase from clock signal CTS—CLK. Clock signal CLKQ is fed through a clock tree buffer (CTS) 314 forming signal CTS—CLKQ (not shown) at node B. Signal CTS—CLKQ is fed through an inverter 324, forming signal CTS—CLKQ˜ (not shown), which is 180 degrees out of phase from CTS—CLKQ. In the embodiment of FIG. 3, all four signals CTS—CLK, CTS—CLKQ, CTS—CLK˜, and CTS—CLKQ˜ are fed into a multiplexer 304.
Using a two-bit programmable input (not shown), multiplexer 304 selects one of the four signals CTS—CLK, CTS—CLKQ, CTS—CLK˜, and CTS—CLKQ˜, which it outputs to a delay circuit 308. Multiplexer 304 provides a “quarter-clock” selection, i.e. ninety degree phase selection, of signal CTS—CLK. In effect, multiplexer 304 provides delaying signal CTS—CLK by a multiple (zero, one, two, three, for example) of a quarter period. Delay circuit 308 may delay the signal further and may output memory clock signal MCLK to a memory. In other words, delay circuit 308 provides fine-tuning of the quarter clock selection. Delay circuit 308, for example, may provide four-bit resolution with a ninety degree range such that between the quarter clock selection of multiplexer 304 and programmable delay 308, the phase of clock signal MCLK may be programmed between zero and 360 degrees.
Signal CTS—CLK at node A is also inverted by an inverter 318 forming a second CTS—CLK˜, which is input to a multiplexer 302. Signal CTS—CLKQ is also inverted by an inverter 320 forming a second CTS—CLKQ˜, which is input into multiplexer 302. Using a two-bit programmable input (not shown), multiplexer 302 selects one of four signals CTS—CLK, CTS—CLKQ, CTS—CLK˜, and CTS—CLKQ˜, which it outputs to an AND gate 328. The purpose of AND gate 328 is described below.
Multiplexer 302 provides a “quarter-clock” selection, i.e. ninety degree phase selection, of signal CTS—CLK. In effect, multiplexer 302 provides delaying signal CTS—CLK by a multiple (zero, one, two, three, for example) of a quarter period. The output of AND gate 328 feeds through delay circuit 306. Delay circuit 306 may delay the signal and may output data strobe signal DQS. Delay circuit 306 provides fine-tuning of the quarter clock selection of multiplexer 302. Delay circuit 306, for example, may provide four-bit resolution with a ninety degree range such that between the quarter clock selection of multiplexer 302 and programmable delay 306, the phase of strobe signal DQS may be programmed between zero and 360 degrees.
As shown in the timing diagram of in FIG. 2, at times strobe signal DQS may not oscillate on and off, such as when no data is being written to memory 104. Referring to FIG. 3, AND gate 328 multiplies the output of multiplexer 302 by the logic value that appears at a node C. If the logic value at node C is “zero,” then the output of AND gate 328 is also “zero” and signal DQS does not oscillate on and off. If the logic value at node C is “one” then the output of AND gate 328 will follow the output of multiplexer 302 and strobe signal DQS oscillates on and off. The value at node C is selected by a multiplexer 326 as being one of pre—dqs—mclk, pre—dqs—mclk#, pre—dqs—mclkq, or pre—dqs—mclkq#. The signals pre—dqs—mclk, pre—dqs—mclk#, pre—dqs—mclkq, and pre—dqs—mclkq# determine when data strobe signal DQS starts to oscillate after a command, such as the write command, is executed. Signal pre—dqs—mclkq is ahead of signal pre—dqs—mclk by ninety degrees (as measured by CTS—CLK); signal pre—dqs—mclkq# is behind signal pre—dqs—mclkq by 180 degrees (as measured by CTS—CLK); signal pre—dqs—mclk# is behind signal pre—dqs mclk by 180 degrees (as measured by CTS—CLK).
In the embodiment of FIG. 3, signal CTS—CLK is also used by a flip-flop 316 to latch data out of a controller circuit as data signal PD. Note that in this embodiment, data signal PD is effectively the reference signal to which strobe signal DQS and clock signal MCLK are adjusted.
In one embodiment of the invention, there are multiple data signals, such as data signal PD, that span multiple data channels between controller 102 and memory 104. For example, there may be 2, 4, 8 16, 32, or 64 data channels and data signals. In this instance, memory 104 may simultaneously latch many data signals into memory. It may be desirable to delay some of the data signals, such as data signal PD, to prevent simultaneous latching that may result if every data channel had the same phase. Delaying some of the data channels, creating different phases, may reduce instantaneous power consumption because not all the switching current is being drawn from the power supply at once. Thus, in this embodiment, flip-flop 316 may use a delayed signal CTS—CLK. Using a two-bit input multiplexer 330, the CTS—CLK may be delayed by zero phase, by a delay circuit 332, by delay circuit 332 and a delay circuit 334, or by delay circuits 332, 334, and a delay circuit 336. A value for the delay time of delay circuits 332, 334, and 336 may be 200 picoseconds, for example.
A user may program the circuit shown in FIG. 3 to allow the rising and falling edge of strobe signal DQS and clock signal MCLK to be lined appropriately with data signal PD. Programming comprises selecting the appropriate signal in multiplexers 302, 304, 330 and 326 and selecting the delay in delay circuits 306 and 308. In one embodiment, multiplexers 302, 304, and 326 all are programmed to the same quarter-clock selection. For example, multiplexers 302 and 304 may be programmed to select CTS—CLK and multiplexer 326 may be programmed to select pre—dqs—mclk. As another example, multiplexers 302 and 304 may be programmed to select CTS—CLK˜ and multiplexer 326 may be programmed to select pre—dqs—mclk#. As another example, multiplexers 302 and 304 may be programmed to select CTS—CLKQ and multiplexer 326 may be programmed to select pre—dqs—mclkq. Finally, multiplexers 302 and 304 may be programmed to select CTS—CLKQ˜ and multiplexer 326 may be programmed to select pre—dqs—mclkq#. A phase detector 340 detects the phase between data signal PD, strobe signal DQS, and clock signal MCLK.
FIG. 4 is a flow chart of a method consistent with this invention for programming the circuit of FIG. 3. In this embodiment, data signal PD is used as a reference clock. If the rising edge of the clock signal MCLK and strobe signal DQS are ahead of data signal PD by 0.75 to 1 times a period of the clock (Tck) (step 402), a delay time (Tdelay) is set to 0.75 Tck (step 420). If the rising edge of clock signal MCLK and strobe signal DQS are ahead of data signal PD by 0.5 to 0.75 times the period of the clock Tck (step 404), then the delay time Tdelay is set to 0.5 Tck (step 418). If the rising edge of the clock signal MCLK and strobe signal DQS are ahead of data signal PD by 0.25 to 0.5 times the period of the clock Tck (step 406), then the time delay Tdelay is set to 0.25 Tck (step 422). If the rising edge of clock signal MCLK and strobe signal DQS are ahead of data signal PD by 0 to 0.25 times the period of the clock Tck (step 408), then the time delay Tdelay is set to 0 Tck (step 410). In this embodiment, the value of delay time Tdelay determines whether to select CTS—CLK, CTS—CLKQ, CTS—CLK˜, or CTS—CLKQ˜ in multiplexers 302 and 304 and whether to select pre—dqs—mclk, pre—dqs—mclk#, pre—dqs—mclkq, and pre—dqs—mclkq# in multiplexer 326 (step 412). After the signals are chosen in multiplexers 302, 304, and 306, then the delay time is adjusted using delay circuits 306 and 308 (step 416).
Table I shows a delay table consistent with this invention for programmable delay circuits such as delay circuits 306 and 308 of FIG. 3. The first column in Table I lists the different four-bit selections. The second column lists the longest delay time for the rising edge of a signal through the delay circuit for the particular delay selection. The third column lists the shortest delay time for the rising edge of a signal through the delay circuit for the particular delay selection. The fourth column lists the longest delay time for the falling edge of a signal through the delay circuit for the particular delay selection. The fifth column lists the shortest delay time for the falling edge of a signal through the delay circuit for the particular delay selection. In another embodiment, the delay circuits are fixed delays and not programmable.
TABLE I
|
|
Programmable Delay
|
Longest Rising
Shortest
Longest
Shortest
|
Delay Bit
Edge Delay
Rising Edge
Falling Edge
Falling Edge
|
Selection
(ns)
Delay (ns)
Delay (ns)
Delay (ns)
|
|
0000
0.3788
0.3997
0.1800
0.2058
|
0001
1.2800
1.3400
0.5169
0.5621
|
0010
1.5280
1.5190
0.6483
0.6426
|
0011
1.8460
1.9100
0.7890
0.8147
|
0100
1.9780
2.0020
0.8383
0.8786
|
0101
2.3110
2.4050
0.9574
1.0490
|
0110
2.5680
2.5560
1.0730
1.1220
|
0111
2.9240
2.9590
1.2370
1.3010
|
1000
2.9260
2.8640
1.2810
1.2840
|
1001
3.2520
3.2630
1.3690
1.4520
|
1010
3.5520
3.4360
1.5530
1.5320
|
1011
3.8640
3.8350
1.6870
1.7120
|
1100
3.9470
3.9600
1.6700
1.7770
|
1101
4.3110
4.3360
1.8960
1.9450
|
1110
4.5480
4.5230
2.0200
2.0110
|
1111
4.9180
4.9200
2.1580
2.1820
|
|
FIG. 5 is a signal timing diagram consistent with this invention. As described above, clock signal MCLK, command signal CMD, data strobe signal DQS, and data signal PD are supplied by controller 102 to memory 104. Similar to the example in FIG. 2, in FIG. 5, command signal CMD issues a write command at the rising edge of signal MCLK. It one embodiment, the rising or falling edge of data strobe signal DQS is timed so that it may properly latch data signal PD into memory 104.
Signal CTS—CLK, shown in FIG. 5, is the signal that appears at node A in FIG. 3. Signal CTS—CLKQ, shown in FIG. 5, is the signal that appears at node B in FIG. 3. Signal CTS—CLKQ˜ appears after inverters 320 and 324 in FIG. 3.
FIG. 5 also shows a signal PRE—DQS—MCLK, which appears at a node E when multiplexer 326 selects signal pre—dqs—mclk. Signal PRE—DQS—MCLK is the product of the output of multiplexer 302 and node C. Signal PRE—DQS—MCLKQ appears at node E when multiplexer 326 selects signal pre—dqs—mclkq. Signal PRE—DQS—MCLKQ is the product of the output of multiplexer 302 and node C. Signal PRE—DQS—MCLK# (not shown in FIG. 5) appears at node E when multiplexer 326 selects signal pre—dqs—mclk# (not shown in FIG. 5). Signal PRE—DQS—MCLK# is the product of the output of multiplexer 302 and node C. Finally, signal PRE—DQS—MCLKQ# appears at node E when multiplexer 326 selects signal pre—dqs—mclkq#. Signal PRE—DQS—MCLKQ# is the product of the output of multiplexer 302 and node C.
FIG. 6 is a flow chart of a method consistent with this invention for writing data to a memory. Methods and systems consistent with this invention generate at least one clock signal (step 602), such as CLK or CLKQ shown in FIG. 3. Such methods and systems then may generate at least one intermediate clock signal from the clock signal using a clock tree buffer (step 604), such as CTS—CLK or CTS—CLKQ. Such methods and systems may then delay the at least one intermediate clock signal to form a data strobe signal (step 606), such as data strobe signal DQS. Methods and systems consistent with this invention may then also delay the at least one intermediate clock signal to form the memory clock signal (step 608), such as signal MCLK. Finally, such methods and systems may write the data to the memory using the data strobe signal and a memory clock signal (step 610).
A method and apparatus for reading data from a memory is found in U.S. patent application Ser. No. 10/404,425 filed Apr. 2, 2003, entitled “Method and Apparatus for Reading Data From a Memory,” and is hereby incorporated by reference.
FIG. 7 is a flow chart of a method consistent with this invention for writing data to a memory with a two-phase-shifted base clock signals (from PLL 310). Methods and systems consistent with this invention generate at least two clock signals (step 702), such as CLK and CLKQ shown in FIG. 3, and these two clock signals can have a specific phase shift of a fraction of one clock, for example, a quarter of one clock. Such methods and systems then may generate a plurality of intermediate clock signals from the at least two clock signals using a clock tree buffer (step 704), such as the signals CTS—CLK, CTS—CLK˜, CTS—CLKQ, and CTS—CLKQ˜. Such methods and systems may then delay the plurality of intermediate clock signals to form a data strobe signal (step 706), such as data strobe signal DQS. Methods and systems consistent with this invention may then also delay the plurality of intermediate clock signal to form the memory clock signal (step 708), such as signal MCLK. Methods and systems consistent with this invention may then also delay at least one of the plurality of intermediate clock signal to form the data clock signal to latch data signal of the data channel (step 710), such as data signal PD. Finally, such methods and systems may write the data to the memory using the data strobe signal and a memory clock signal (step 712).
Other embodiments of the invention will be apparent to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. In the claims an in the specification “a memory,” such as memory 104, may comprise a single memory chip or more than one memory chip. Further, controller 102 and memory 104 may be separate chips or may be on the same chip. Also, the quarter clock selection could be a selection of a fractional period of the clock signal other than a quarter, for example. Further, methods and systems consistent with this invention may generate a plurality of each of (1) clock signals; (2) intermediate clock signals; (2) memory clock signals; (3) data strobe signals; (4).
It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.