The present invention relates to memory systems, and more particularly, to systems and methods for coupling command, address and data signals between a memory controller and one or more memory devices.
Computer systems use memory devices, such as dynamic random access memory (“DRAM”) devices, to store data that are accessed by a processor. These DRAM devices are normally used as system memory in a computer system. In a typical computer system, the processor communicates with the system memory through a processor bus and a memory controller. The system memory is typically arranged in memory modules each having multiple memory devices, and the memory modules are coupled through a memory bus to the memory controller. The processor issues a memory request, which includes a memory command, such as a read command, and an address designating the location from which data or instructions are to be read or to which data or instructions are to be written. The memory controller uses the command and address to generate appropriate command signals as well as row and column addresses, which are applied to the system memory through the memory bus. In response to the commands and addresses, data are transferred between the system memory and the processor. The memory controller is often part of a system controller, which also includes bus bridge circuitry for coupling the processor bus to an expansion bus, such as a PCI bus.
A high data bandwidth is a desirable capability of memory systems. Generally, bandwidth limitations are not related to the memory controllers since the memory controllers sequence data to and from the system memory as fast as the memory devices allow. One approach to increasing bandwidth is to increase the speed of the memory data bus coupling the memory controller to the memory devices. However, memory devices have not been able to keep up with increases in the data bandwidth of memory controllers and memory data buses. In particular, the memory controller must schedule all memory commands to the memory devices in a manner that allows the memory devices to respond to the commands. Although these hardware limitations can be reduced to some degree through the design of the memory device, a compromise must be made because reducing the hardware limitations typically adds cost, power, and/or size to the memory devices, all of which are undesirable alternatives. While memory devices can rapidly handle “well-behaved” accesses at ever increasing rates, for example, sequel traffic to the same page of a memory device, it is much more difficult for the memory devices to resolve “badly-behaved traffic,” such as accesses to different pages or banks of the memory device. As a result, the increase in memory data bus bandwidth does not result in a corresponding increase in the bandwidth of the memory system.
In addition to the limited bandwidth of memory devices, the performance of computer systems is also limited by latency problems that increase the time required to read data from memory devices. More specifically, when a memory device read command is coupled to a system memory device, such as a synchronous DRAM (“SDRAM”) device, the read data cannot be output from the SDRAM device until a delay of several clock periods has occurred. Although SDRAM devices can synchronously output burst data at a high data rate, the delay in initially providing the data can significantly slow the operating speed of a computer system using such SDRAM devices. These latency issues generally cannot by alleviated to any significant extent by simply increasing the memory data bus bandwidth.
The memory latency problem is greatly exacerbated by read accesses alternating with write accesses, a situation known as “read/write turnarounds.” When a memory controller issues a read command to a memory device, the memory device must couple read data from a memory array to external data bus terminals of the memory device. The read data must then be coupled through a data bus portion of the memory bus from the memory device to the memory controller. It is only then that the memory controller can couple write data to the memory device through the data bus to initiate a write memory access.
Latency problems also exist for sequentially read command directed to different pages of memory cells in memory devices. If a second read is directed to a different page, the page to which the read is directed will not be an “open” page, i.e., a row of memory cells from which data was read during the previous memory access. If the row to which the read access is directed is not already open, data cannot be coupled from a memory array to the data bus terminals of the memory device until the page has been opened. Opening the page requires the coupling of memory command and a row address and a column address from the memory controller to the memory device. In response to the read address, the memory device must equilibrate the corresponding row, turn on access transistors for that row, and allow a sense amplifier for each column to sense the voltage that a respective memory cells couples to the sense amplifier. All of this can take a considerable period of time. For this reason, a read operations from a closed page and read/write turnarounds can prevent memory devices from even coming close to achieving the data bandwidths that are possible with high speed memory controllers and memory buses.
There is therefore a need for a memory device and memory system that allows a higher data bandwidth to be achieved particularly in the presence of alternating read and write accesses.
A memory system is able to achieve a high bandwidth and low latency through the use of two separate data buses coupling a memory controller to one or more memory device. A downstream bus couples write data from the memory controller to each memory device, and an upstream bus couples read data from each memory device to the memory controller. As a result, read data can be coupled from each memory device to the memory controller at the same time that write data can be coupled from the memory controller to each memory device. A single downstream memory bus may be used to couple memory commands and memory addresses to each memory device along with write data. Each memory device can include a write buffer that allows memory commands and addresses and write data for several write access to be accumulated while read requests are processed. After a number of write accesses have been accumulated, they can be processed in a burst manner without any intervening read accesses.
A memory system 10 according to one embodiment of the invention is illustrated in
In operation, the memory controller 14 couples write data “downstream” to the DRAM devices 20-26 through the write data bus 30, and the DRAM devices 20-26 couple read data “upstream” to the memory controller 14 through the read data bus 32. The bandwidth of the write data bus 30 may be the same as the bandwidth of the read data bus 32. Alternatively, the write data bus 30 and the read data bus 32 may have different bandwidths to accommodate different data rates though the buses 30, 32. In the event the DRAM devices 20-26 are synchronous DRAM (“SDRAM”) devices, the memory controller 14 also couples a clock signal to each of the DRAM devices 20-26. By using separate write and read data buses 30, 32, respectively, the memory controller 14 can couple write data to the DRAM devices 20-26 at the same time that the memory devices 20-26 are coupling read to the memory controller 14.
The DRAM devices 20-26 are shown in greater detail in
The read latch 50 outputs read data on an 8-bit read data bus 60 in synchronism with a clock signal that is also coupled from the read latch 50 on line 62. The memory devices 20-26 include a large number of other conventional memory device components, but these have been omitted from
In operation, memory commands, such as write commands and read commands, as well as memory addresses are coupled through the write data bus 52. The memory commands and addresses are stored in the command/address register 58. The write data also coupled through the write data bus 52 and stored in the write buffer 46. In response to a read command coupled to the command/address register 58, the memory devices 20-26 output read data, which are coupled to the read latch 50. The read latch 50 stores the read data until the read data bus 60 and memory controller 14 (
In one embodiment of the invention, the memory controller 14 (
A computer system 100 using the memory system 10 of
Although the present invention has been described with reference to the disclosed embodiments, persons skilled in the art will recognize that changes may be made in form and detail without departing from the spirit and scope of the invention. Such modifications are well within the skill of those ordinarily skilled in the art. Accordingly, the invention is not limited except as by the appended claims.
This application is a continuation of U.S. patent application Ser. No. 10/928,411, filed Aug. 27, 2004 now U.S. Pat. No. 7,200,693.
Number | Name | Date | Kind |
---|---|---|---|
4208715 | Kumahara et al. | Jun 1980 | A |
4503497 | Krygowski et al. | Mar 1985 | A |
4831522 | Henderson et al. | May 1989 | A |
4954992 | Kumanoya et al. | Sep 1990 | A |
5003485 | Francisco | Mar 1991 | A |
5086388 | Matoba et al. | Feb 1992 | A |
5202856 | Glider et al. | Apr 1993 | A |
5278957 | Chan | Jan 1994 | A |
5289431 | Konishi | Feb 1994 | A |
5369619 | Ohba | Nov 1994 | A |
5375089 | Lo | Dec 1994 | A |
5384745 | Konishi et al. | Jan 1995 | A |
5446691 | North et al. | Aug 1995 | A |
5517462 | Iwamoto et al. | May 1996 | A |
5539691 | Kozaru et al. | Jul 1996 | A |
5597084 | Parasin | Jan 1997 | A |
5619471 | Nunziata | Apr 1997 | A |
5745732 | Cherukuri et al. | Apr 1998 | A |
5847998 | Van Buskirk | Dec 1998 | A |
5856947 | Fang | Jan 1999 | A |
5925118 | Revilla et al. | Jul 1999 | A |
5991223 | Kozaru et al. | Nov 1999 | A |
6038630 | Foster et al. | Mar 2000 | A |
RE36655 | Kozaru et al. | Apr 2000 | E |
6061763 | Rubin et al. | May 2000 | A |
6081458 | Lattimore et al. | Jun 2000 | A |
6084823 | Suzuki et al. | Jul 2000 | A |
6091662 | Mochida | Jul 2000 | A |
6144604 | Haller et al. | Nov 2000 | A |
6167475 | Carr | Dec 2000 | A |
6195280 | Lattimore et al. | Feb 2001 | B1 |
6215497 | Leung | Apr 2001 | B1 |
6219763 | Lentz et al. | Apr 2001 | B1 |
6269413 | Sherlock | Jul 2001 | B1 |
6275432 | Hardee | Aug 2001 | B1 |
6278644 | Takasugi | Aug 2001 | B1 |
6282588 | Yamamoto | Aug 2001 | B1 |
6338108 | Motomura | Jan 2002 | B1 |
6351423 | Ooishi | Feb 2002 | B2 |
6396749 | Al-Shamma et al. | May 2002 | B2 |
6442646 | Tsuruta | Aug 2002 | B1 |
6452864 | Condemi et al. | Sep 2002 | B1 |
6510161 | Trevitt et al. | Jan 2003 | B2 |
6515927 | Kitamoto et al. | Feb 2003 | B2 |
6518787 | Allegrucci et al. | Feb 2003 | B1 |
6522167 | Ansari et al. | Feb 2003 | B1 |
6587905 | Correale, Jr. et al. | Jul 2003 | B1 |
6587927 | Hotta et al. | Jul 2003 | B2 |
6618775 | Davis | Sep 2003 | B1 |
6636444 | Uchida et al. | Oct 2003 | B2 |
6647485 | Nguyen et al. | Nov 2003 | B2 |
6662285 | Douglass et al. | Dec 2003 | B1 |
6704238 | Izutsu et al. | Mar 2004 | B2 |
6717624 | Kasai | Apr 2004 | B1 |
6718439 | Jayavant | Apr 2004 | B1 |
6728157 | Yagishita et al. | Apr 2004 | B2 |
20020023191 | Fudeyasu | Feb 2002 | A1 |
20040034753 | Jeddeloh | Feb 2004 | A1 |
20040044870 | Pawlowski | Mar 2004 | A1 |
20060190671 | Jeddeloh | Aug 2006 | A1 |
20060250879 | Jeddeloh | Nov 2006 | A1 |
20070028027 | Janzen et al. | Feb 2007 | A1 |
Entry |
---|
Intel Dual Channel DDR Memory Architecture White Paper, Kingston Technology, Sep. 2003. |
Croucher, Phil, “Meaning Behind Ram RAS and CAS”, http://www.kingston.com/tools/umg/umg03.asp, printed Feb. 24, 2006. |
Definition of “The Memory Controller”, PC Guide, http://www.pcguide.com/ref/ram/timingController-c.html, printed Aug. 2, 2006. |
De Gelas, Johan, “Ace's Guide to Memory Technology”, Ace's Hardware, Jul. 13, 2000, pp. 1-6, http://www.aceshardware.com/read.isp?id=5000172, printed Feb. 24, 2006. |
“Dynamic Random Access Memory”, Wikipedia, the free encyclopedia, pp. 1-7, http://en.wikipedia.org/wiki/Dynamic—Random—Access—Memory, printed Feb. 24, 2006. |
“How Memory Works”, Kingston Technology, pp. 1-8, http://www.Kingston.com/tools/umg/umg03.asp, printed Feb. 24, 2006. |
Kent, Dean, “Ram Guide”, Tom's Hardware, Oct. 24, 1998, pp. 1, http://www.tomshardware.com/1998/10/24/ram—guide/page2.html, printed Feb. 24, 2006. |
Number | Date | Country | |
---|---|---|---|
20070055814 A1 | Mar 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10928411 | Aug 2004 | US |
Child | 11594355 | US |