The present invention relates generally to a memory system for a processor-based computing system, and more particularly, to a hub-based memory system providing expansion capabilities for computer components.
Computer systems use memory devices, such as dynamic random access memory (“DRAM”) devices, to store data that are accessed by a processor. These memory 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 memory devices of the system memory, typically arranged in memory modules having multiple memory devices, 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. 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.
In memory systems, high data bandwidth is desirable. 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 that has been taken to increase bandwidth is to increase the speed of the memory data bus coupling the memory controller to the memory devices. Thus, the same amount of information can be moved over the memory data bus in less time. However, despite increasing memory data bus speeds, a corresponding increase in bandwidth does not result. One reason for the non-linear relationship between data bus speed and bandwidth is the hardware limitations within the memory devices themselves. That is, the memory controller has to schedule all memory commands to the memory devices such that the hardware limitations are honored. 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. Thus, given these constraints, although it is easy for memory devices to move “well-behaved” traffic 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 bouncing between different pages or banks of the memory device. As a result, the increase in memory data bus bandwidth does not yield a corresponding increase in information bandwidth.
In addition to the limited bandwidth between processors and memory devices, the performance of computer systems is also limited by latency problems that increase the time required to read data from system 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 are output from the SDRAM device only after a delay of several clock periods. Therefore, 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. Increasing the memory data bus speed can be used to help alleviate the latency issue. However, as with bandwidth, the increase in memory data bus speeds do not yield a linear reduction of latency, for essentially the same reasons previously discussed.
Although increasing memory data bus speed has, to some degree, been successful in increasing bandwidth and reducing latency, other issues are raised by this approach. For example, as the speed of the memory data bus increases, loading on the memory bus needs to be decreased in order to maintain signal integrity since traditionally, there has only been wire between the memory controller and the memory slots into which the memory modules are plugged. Several approaches have been taken to address the memory bus loading issue. For example, reducing the number of memory slots to limit the number of memory modules that contribute to the loading of the memory bus, adding buffer circuits on a memory module in order to provide sufficient fanout of control signals to the memory devices on the memory module, and providing multiple memory device interfaces on the memory module since there are too few memory module connectors on a single memory device interface. The effectiveness of these conventional approaches are, however, limited. A reason why these techniques were used in the past is that it was cost-effective to do so. However, when only one memory module can be plugged in per interface, it becomes too costly to add a separate memory interface for each memory slot. In other words, it pushes the system controllers package out of the commodity range and into the boutique range, thereby, greatly adding cost.
One recent approach that allows for increased memory data bus speed in a cost effective manner is the use of multiple memory devices coupled to the processor through a memory hub. A computer system 100 shown in
The system controller 110 includes a memory hub controller 128 that is coupled to the processor 104. The system controller 110 is further coupled over a high speed bi-directional or unidirectional system controller/hub interface 134 to several memory modules 130a-n. As shown in
The memory devices 148 on the memory modules 130a-n are typically capable of operating at high clock frequencies in order to facilitate the relatively high speed operation of the overall memory system. Consequently, computer systems employing this architecture can also use the high-speed system controller/hub interface 134 to complement the high clock speeds of the memory devices 148. Additionally, with a memory hub based system, signal integrity can be maintained on the system controller/hub interface 134 since the signals are typically transmitted through multiple memory hubs 140 to and from the memory hub controller 128. Moreover, this architecture also provides for easy expansion of the system memory without concern for degradation in signal quality as more memory modules are added, such as occurs in conventional memory bus architectures.
Although the memory hub architecture shown in
As well known, arbitration schemes are implemented by the system controller 110 in order to prioritize memory requests it receives from the various components 112, 118, 120, 124, as well as memory requests received from the processor 104. The arbitration schemes that are implemented attempt to provide efficient memory access to the various components 112, 118, 120, 124, and processor 104 in order to maximize processing capabilities. Some memory requests are given priority over others regardless of the order in which the requests are received by the system controller 110, for example, the processor 104 is often given highest priority to access the memory modules 130a-n to avoid the situation where processing is halted while the processor 104 is waiting for a memory request to be serviced. As sophisticated as arbitration techniques have become, it is still unlikely that bottlenecks at the system controller 110 can be completely avoided. Even where a component is given direct memory access to the memory modules 130a-n, such as the graphics controller 112, it is nevertheless subject to the arbitration routine that is implemented by the system controller 110, and consequently, the component does not have unlimited access privileges to the memory modules 130a-n. It is by the nature of the architecture used in the computer system 100, namely, providing access to the memory modules 130a-n through the single point of the system controller 110, that makes bottlenecks at the system controller 110 inevitable. Therefore, there is a need for an alternative system and method for providing components of a processing system, such as a computer system, access to memory resources.
A system memory in one aspect of the invention includes a memory hub controller, a memory module accessible by the memory hub controller, and an expansion module coupled to the memory module having a processor circuit also having access to the memory module. The memory hub controller provides memory requests to access memory devices, and the memory module includes a plurality of memory devices coupled to a memory hub. The memory hub receives the memory requests, accesses the memory devices according to the memory requests, and provides memory responses in response to the memory requests. The processor circuit of the expansion module provides memory requests to the memory hub of the memory module to access the memory devices, and processes data returned in the memory responses from the memory hub. The memory hub controller is coupled to the memory hub through a first portion of a memory bus on which the memory requests and the memory responses are coupled. A second portion of the memory bus couples the memory hub to the processor circuit and is used to couple memory requests from the processor circuit and memory responses provided by the memory hub to the processor circuit.
As shown in
In contrast to the computer system 100 of
Although the component expansion module 230 is shown in
The arrangement of the system 200 allows for access to the memory modules 130a-c by the component expansion module 230 without intervention by the system controller 110. As previously discussed, the memory hubs 240 can receive memory requests and provide memory responses in both the downstream and upstream directions. By adopting a consistent communication protocol with the memory hubs 240 of the memory modules 130a-c, communication with the memory hubs 240 of the memory modules 130a-c can be performed directly by the component expansion module 230, thereby eliminating the need for intervention by the system controller 110. As a result, access to the memory modules 130a-c is not limited to going through the system controller 110, but the component expansion module 230 can access the memory modules 130a-c directly. In contrast, the graphics controller 112 in the computer system 100 (
Many suitable communication protocols are known in the art, including the use of command packets that include appropriate information for making memory requests to particular memory modules 130a-c in the system 200 and providing memory responses in return. For example, command packets can include information such as identification data for uniquely identifying the particular memory request, address information for identifying a particular memory module 130a-c to which the memory request is directed, and memory device command information, including memory addresses, command type, and where a write operation is requested, data can be included as well. Other protocols can be used as well, and it will be appreciated by those ordinarily skilled in the art that the present invention is not limited by the particular protocol implemented.
Additionally, the arrangement of the system 200 reduces the memory request and response load on the system controller 110 since it is relieved from handling the memory requests from a requesting entity, namely the graphics controller 112 (
The cross bar switch 310 can also couple any of the link interfaces 302, 304, 306, 308 to either or both of the memory controllers 324a, 324b, each of which is coupled to a plurality of memory devices 148 (not shown in
It will be appreciated by those ordinarily skilled in the art that
The memory hub controller 428 is coupled over a high speed bi-directional or unidirectional system controller/hub interface 134 to several memory modules 130a-c. The controller/hub interface 134 includes a downstream bus 154 and an upstream bus 156 which are used to couple data, address, and/or control signals away from or toward, respectively, the memory hub controller 428. Each memory module 130a-c in the system 400 includes a memory hub 240 that is coupled to the system controller/hub interface 134, and which is further coupled a number of memory devices 148 through command, address and data buses, collectively shown as bus 150. The memory hub 240 efficiently routes memory requests and responses between the memory hub controller 128 and the memory devices 148. As with the memory hub 240 shown in
Coupled in series with the memory modules 130a-c over the downstream and upstream buses 154, 156 are component expansion modules 230 and 430. The component expansion module 230, as previously described with reference to
Unlike the systems 100 and 200, where the input and output devices 118, 120 are coupled to the system controller 110, input and output devices (not shown in
It will be appreciated by those ordinarily skilled in the art that the embodiments shown in
From the foregoing it will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.
This application is a continuation of U.S. application Ser. No. 12/580,085, filed on Oct. 15, 2009, which application is a continuation of U.S. application Ser. No. 12/075,424, filed on Mar. 10, 2008 and issued as U.S. Pat. No. 7,610,430 on Oct. 27, 2009, which application is a continuation of U.S. application Ser. No. 11/715,517, filed on Mar. 7, 2007 and issued as U.S. Pat. No. 7,370,134 on May 6, 2008, which application is a continuation of U.S. application Ser. No. 11/399,873, filed on Apr. 7, 2006 and issued as U.S. Pat. No. 7,206,887 on Apr. 17, 2007, which application is division of U.S. application Ser. No. 10/810,229, filed on Mar. 25, 2004 and issued as U.S. Pat. No. 7,120,723 on Oct. 10, 2006, the disclosures of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6256253 | Oberlaender et al. | Jul 2001 | B1 |
6343171 | Yoshimura et al. | Jan 2002 | B1 |
6344664 | Trezza et al. | Feb 2002 | B1 |
6366375 | Sakai et al. | Apr 2002 | B1 |
6405273 | Fleck et al. | Jun 2002 | B1 |
6430696 | Keeth | Aug 2002 | B1 |
6493784 | Kamimura et al. | Dec 2002 | B1 |
6507899 | Oberlaender et al. | Jan 2003 | B1 |
6552304 | Hirose et al. | Apr 2003 | B1 |
6567963 | Trezza | May 2003 | B1 |
6599031 | Li | Jul 2003 | B2 |
6623177 | Chilton | Sep 2003 | B1 |
6661940 | Kim | Dec 2003 | B2 |
6661943 | Li | Dec 2003 | B2 |
6707726 | Nishio et al. | Mar 2004 | B2 |
6752539 | Colgan et al. | Jun 2004 | B2 |
6793411 | Seifert | Sep 2004 | B2 |
6829398 | Ouchi | Dec 2004 | B2 |
6910812 | Pommer et al. | Jun 2005 | B2 |
6949406 | Bosnyak et al. | Sep 2005 | B2 |
6980748 | Leas | Dec 2005 | B2 |
7106973 | Kube et al. | Sep 2006 | B2 |
7136953 | Bisson et al. | Nov 2006 | B1 |
7171508 | Choi | Jan 2007 | B2 |
20020083287 | Zumkehr et al. | Jun 2002 | A1 |
20030110368 | Kartoz | Jun 2003 | A1 |
20040015650 | Zumkehr et al. | Jan 2004 | A1 |
20040024959 | Taylor | Feb 2004 | A1 |
20040028412 | Murphy | Feb 2004 | A1 |
20040047169 | Lee et al. | Mar 2004 | A1 |
20040251929 | Pax et al. | Dec 2004 | A1 |
20040257890 | Lee et al. | Dec 2004 | A1 |
20040268009 | Shin et al. | Dec 2004 | A1 |
20050030797 | Pax et al. | Feb 2005 | A1 |
20050091464 | James | Apr 2005 | A1 |
20050105350 | Zimmerman | May 2005 | A1 |
20050146946 | Taylor | Jul 2005 | A1 |
20050177690 | LaBerge | Aug 2005 | A1 |
20050210185 | Renick | Sep 2005 | A1 |
20050216648 | Jeddeloh | Sep 2005 | A1 |
20050257021 | James | Nov 2005 | A1 |
20060023528 | Pax et al. | Feb 2006 | A1 |
20060179203 | Jeddeloh | Aug 2006 | A1 |
20060179208 | Jeddeloh | Aug 2006 | A1 |
20060195647 | Jeddeloh | Aug 2006 | A1 |
20060218331 | James | Sep 2006 | A1 |
Number | Date | Country | |
---|---|---|---|
20110145463 A1 | Jun 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10810229 | Mar 2004 | US |
Child | 11399873 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12580085 | Oct 2009 | US |
Child | 13032251 | US | |
Parent | 12075424 | Mar 2008 | US |
Child | 12580085 | US | |
Parent | 11715517 | Mar 2007 | US |
Child | 12075424 | US | |
Parent | 11399873 | Apr 2006 | US |
Child | 11715517 | US |