A memory module comprises a data interface including a plurality of data lines and a plurality of configurable switches coupled between the data interface and a data path to one or more memories. The effective width of the memory module can be configured by enabling or disabling different subsets of the configurable switches. The configurable switches may be controlled by manual switches, by a buffer on the memory module, by an external memory controller, or by the memories on the memory module.
| 
 | 1.  A memory system, comprising:
 a motherboard comprising a plurality of motherboard data lines; a first memory module coupled to at least a first subset of the plurality of motherboard data lines via the first memory module slot, the first memory module comprising a first memory core associated with a first rank and a second memory core associated with a second rank, the first memory module including a first data path to couple the first subset of the plurality of motherboard data lines to the first memory core and to the second memory core; a second memory module coupled to at least a second subset of the plurality of motherboard data lines via the second memory module slot, the second memory module comprising a third memory core associated with the first rank and a fourth memory core associated with the second rank, the second memory module including a second data path to couple the second subset of the plurality of motherboard data lines to the third memory core and to the fourth memory core; wherein the first memory core and the third memory core associated with the first rank are each accessible by a memory controller when a first select line associated with the first rank is enabled, and the first memory core and the third memory core associated with the first rank are each inaccessible to the memory controller when the first select line is disabled; wherein the second memory core and the fourth memory core associated with the second rank are each accessible by a memory controller when a second select line associated with the second rank is enabled, and the second memory core and the fourth memory core associated with the second rank are each inaccessible to the memory controller when the second select line is disabled. 2.  The memory system of  a data interface including a plurality of data pins coupled to each of the plurality of data lines; a plurality of configurable switches coupled between the data interface and the first data path, each of the configurable switches coupled between one of the plurality of data pins and a corresponding one of a plurality of memory module data lines and when enabled coupling said one of the plurality of data pins to said corresponding one of the plurality of memory module data lines, and when disabled decoupling said one of the plurality of data pins from said corresponding one of the plurality of memory module data lines. 3.  The memory system of  a buffer to route the data between a first subset of the first side memory module data lines and a first subset of the second side memory module data lines during a first time when the first select line is enabled and the second select line is disabled, and to route the data between the first subset of the first side memory module data lines and a second subset of the second side memory module data lines during a second time when the first select line is disabled and the second select line is enabled. 4.  The memory system of  a mode register to store a mode register value, the mode register value being output to the plurality of configurable switches to enable a subset of the plurality of configurable switches. 5.  The memory system of  a control pin to receive a control value from the memory controller, the control pin to output the control value to the plurality of configurable switches to enable a subset of the configurable switches. 6.  The memory system of  a manual switch to control a control value output to the plurality of configurable switches to enable a subset of the plurality of configurable switches. 7.  The memory system of  a mode register to store a mode register value, the mode register value being output to one or more of the plurality of configurable switches to enable said one or more of the plurality of configurable switches. 8.  The memory system of  a first control line to collectively enable or disable each of a first subset of the plurality of configurable switches; and a second control line to collectively enable or disable each of a second subset of the plurality of configurable switches. 9.  The memory system of  10.  The memory system of  a buffer to route the data between the first subset of the plurality of motherboard data lines and the first memory core during a first time and to route the data between the first subset of the plurality of motherboard data lines and the second memory core during a second time. 11.  The memory system of  a plurality of data pins; memory logic to configure a width of the first memory module, the memory logic including a mode register to generate switch control signals to enable or disable a plurality of switches based on the configured width, the plurality of switches coupled between the plurality of data pins and the first memory core, the first memory core to store data read on the plurality of data pins in response to a write command and to output data to the plurality of data pins in response to a read command. 12.  The memory of  13.  The memory system of  a plurality of data pins to communicate data to and from the first memory module; a command address pin to output a command address signal to control a read operation to read data on the plurality of data pins, and the command address signal to control a write operation to write data to the plurality of data pins; and enable pins to output an enable signal to enable or disable one or more of a plurality of configurable switches on the first memory module; and memory controller logic to generate the enable signal based on a configuration of the first memory module. 14.  The memory controller of  15.  The memory system of  a mode register to enable or disable one or more of a plurality of configurable switches; memory controller side data lines coupled to the plurality of configurable switches, the memory controller side data lines including a first subset of the memory controller side data lines coupled to enabled switches of the plurality of configurable switches, and the memory controller side data lines including a second subset of the memory controller side data lines coupled to disabled switches of the plurality of configurable switches, the first subset of the memory controller side data lines configured to communicate data to and from the memory controller; memory core side data lines to communicate the data to and from the first and second memory cores; a data router coupled between the memory controller side data lines and the memory core side data lines, the data router to route the data between the first subset of the memory controller side data lines and a first subset of the memory core side data lines during a first time when the first select line is enabled and the second select line is disabled, and to route the data between the first subset of the memory controller side data lines and a second subset of the memory core side data lines during a second time when the first select line is disabled and the second select line is enabled. 16.  The memory system of  17.  The memory system of  | |||||||||||||||||||||||||
This application claims the benefit of U.S. Provisional Application No. 61/767,097 entitled “Folded Memory Modules” to Amir Amirkhany, et al., filed on Feb. 20, 2013, the contents of which are incorporated by reference herein.
As memory bus speeds increase, maintaining good signal integrity becomes increasingly difficult. In multi-drop data topologies, multiple memory devices share data signals in order to expand memory capacity without increasing the number of data pins on the memory controller or data lines on the motherboard. However, multi-drop data topologies can degrade signal integrity due to increased loading characteristics, thereby reducing speed at which memory can run.
The teachings of the embodiments herein can be readily understood by considering the following detailed description in conjunction with the accompanying drawings.
A multi-module memory system has a folded topology that enables expandable memory with reduced signal degradation compared to conventional multi-drop topologies. In the folded memory topology, each memory module uses only a fraction (e.g., half) of the available data lines, thus reducing loading effects. In a first embodiment, the multi-module memory system can be implemented via a motherboard having a plurality of dedicated memory slots (e.g., even and odd memory slots) for use with a plurality of interchangeable fixed width memory modules (e.g., each using half of the available data lines on the motherboard). In a second embodiment, the multi-module memory system can be implemented using a standard multi-drop motherboard with a plurality of memory modules each configured as a particular memory module type (e.g., an even memory module or an odd memory module). In one embodiment, the memory modules may be hardwired for their particular configuration (e.g., even or odd). Alternatively, the memory modules may be configurable using configurable switches between the data pins and the memories. The configurable switches may be controlled by a manual switch, by a buffer on the memory module, by control pins coupled to an external memory controller, or by a control signal from the memories. These embodiments are described in further detail below with reference to the figures.
The microbuffers 120 buffer and route data between data lines 125 and memories 112, 114, 116, 118. For example, in one embodiment, microbuffer 120 provides, for each set of four data lines (e.g., DQ[3:0], DQ[7:4], DQ[11:8], DQ[15:12]), a one-to-one routing with one of the memories 112, 114, 116, 118.
The architecture of 
In contrast to the multi-drop topology of 
Within each memory module 202, individual memories are assigned to different “ranks.” Memories that are assigned to the same rank share a common chip select (not shown) and are thus concurrently enabled or disabled. In one embodiment, for example, memories 212-A, 214-A on first memory module 202-A are assigned to a first rank and memories 216-A, 218-A on first memory module 202-A are assigned to a second rank. On second memory module 202-B, memories 212-B, 214-B are assigned to the first rank and memories 216-B, 218-B are assigned to the second rank. In third module 202-C and fourth module 202-D, memories 212-C, 214-C, 212-D, 214-D are assigned to a third rank and memories 216-C, 218-C, 216-D, 218-D are assigned to a fourth rank. This topology, in which ranks are split between two or more different memory modules 202, is referred to herein as a “folded” topology.
Microbuffers 220 buffer and route the data between data lines 225 and memories 212, 214, 216, 218. Microbuffers 220 may route the data to and from different ones of memories 212, 214, 216, 218 depending on which rank is currently selected. For example, referring to memory module 202-A, in a first configuration of the microbuffer 220-A (e.g., when the first rank is selected), microbuffer 220-A routes data between data lines DQ[3:0], DQ[7:4] and memories 212-A, 214-A respectively. In a second configuration (e.g., when the second rank is selected), microbuffer 220-A instead routes data between data lines DQ[3:0], DQ[7:4] and memories 216-A, 218-A respectively. Microbuffers 220 on the remaining memory modules 202 function similarly. In alternative embodiments, microbuffers 220 may route data in a different manner. For example, in one embodiment, microbuffers 220 may provide full crossbar switching, thus enabling routing between any of the data lines 225 and any of the memories in various configurations.
The folded topology of 
In one embodiment, damping resistors 322 on the memory modules 302 are used to make the connections between data lines 325 and the microbuffer 320, where present. Conveniently, the printed circuit boards for the memory modules 302 can be similarly manufactured for both even and odd modules, and then configured as either an odd memory module or an even memory module simply by adding damping resistors 322 to complete the appropriate connections.
The folded topology of 
Memories 402 may comprise for example dynamic random access memories (DRAMs) or other types of volatile or non-volatile memories. Memories 402 store data received via memory side data lines DQ in response to receiving a write command via the command address signal CA. Memories 402 output data to memory side data lines DQ in response to receiving a read command via the command address signal CA.
Odd data path 416 comprises a plurality of odd data lines, each of which correspond to one of the odd data pins 410 and communicate data to and from the buffer 450. Programmable switches 422 (e.g., metal oxide semiconductor field effect transistors (MOSFETs)) are coupled in series between each of the odd data pins 410 and odd data path 416. The programmable switches 422 couple the odd data pins 410 to the corresponding data lines of the data path 416 when enabled and decouple the odd data pins 410 from the corresponding data lines of the data path 416 when disabled.
Similarly, an even data path 418 comprises a plurality of even data lines, each of which correspond to one of the even data pins 420 and communicate data to and from the buffer 450. Programmable switches 424 are coupled in series between each of the even data pins 420 and even data path 418. The programmable switches 424 couple the even data pins 420 to the corresponding data lines of the data path 418 when enabled and decouple the even data pins 420 from the corresponding data lines of the data path 418 when disabled.
Buffer 450 buffers the data signals received from the data paths 416, 418 and provides the buffered data signals to appropriate memories 402 via memory side data lines DQ. For example, buffer 450 may route data between a given memory 402 and a subset of odd data lines 416, a subset of even data lines 418, or both. Buffer 450 also receives a command address (CA) input that provides control and addressing information for various memory operations. Buffer 450 buffers the command address signal CA and provides the buffered signal to the appropriate memories 402 via command address lines CA. Buffer 450 furthermore generates odd enable signal 412 and even enable signal 414 to control the odd switches 422 and the even switches 424. Buffer 450 may furthermore provide routing for additional signals (such as, for example chip select signals) that are omitted from the figure for clarity purposes.
By controlling odd switches 422 and even switches 424, buffer 450 can dynamically configure memory module 400 as either an odd memory module (e.g., by enabling odd switches 422 and disabling even switches 424), an even memory module (e.g., by enabling even switches 424 and disabling odd switches 422), or a full-width memory module (e.g., by enabling both odd switches 422 and even switches 424). When configured as an odd memory module, buffer 450 provides data routing to allow communication of data to and from each of the memories 402 using only odd data lines 410. Similarly, when configured as an even memory module, buffer 450 provides data routing to allow communication of data to and from each of the memories 402 using only even data lines 420. In one embodiment, switches 422, 424 may be optimized to provide an appropriate damping resistance, low internal capacitance, and good linearity.
In alternative embodiments, memory module 400 may be configurable using a different scheme for sharing data lines between multiple memories that is not necessarily an even/odd configuration described above. For example, in an alternative embodiment, the memory module 400 can be configured as either a lower memory module (communicating with lower data lines) or an upper memory module (communicating with upper data lines). Furthermore, in other embodiments, the memory module 400 can be configured such that each memory uses a different fraction of the data lines that is not necessarily half (e.g., each memory uses a quarter of the available data lines).
A data router 520 routes data between controller side data lines 502, 504 and memory side data lines 512, 514 according to the command address signal 506. For example, when configured as an odd memory module, data router 520 routes data between odd data lines 504 and a first subset 512 of the memory side data lines during a first time (e.g., when a first rank is selected), and routes data between odd data lines 504 and a second subset 514 of the memory side data lines during a second time (e.g., when the second rank is selected). Similarly, when configured as an even memory module, data router 520 routes data between even data lines 502 and first subset 512 of the memory side data lines during a first time (e.g., when the first rank is selected), and routes data between even data lines 502 and second subset 514 of the memory side data lines during a second time (e.g., when the second rank is selected). When configured as a full memory module (i.e., both even and odd are enabled), even data lines 502 are passed directly to first subset 512 of the memory side data lines and odd data lines 504 are passed directly to second subset 514 of the memory side data lines.
A mode register 540 stores a mode register value representing the configuration of buffer 450. For example, in one embodiment, mode register 540 comprises an odd enable register 542 and an even enable register 544 that collectively represent the mode register value. The mode register value is output to the configurable switches 422, 424 to enable or disable different subsets of the switches 422, 424. For example, when odd enable register 542 is set, odd enable signal 412 is asserted, thereby enabling odd switches 422. Similarly, when even enable register 544 is asserted, even enable signal 414 is asserted, thereby enabling even switched 424. Data router 520 also reads the odd enable register 542 and the even enable register 544 to determine how to route data between controller side data lines 502, 504 and memory side data lines 512, 514. In one embodiment, mode register 540 can be configured in response to a command sent via the command address signal 506.
Rank multiplication logic 530 receives the command address signal 506 and reads the odd enable register 542 and even enable register 544 to generate command address signal 516 provided to the memories 402. Rank multiplication logic 530 generates appropriate addresses to correctly address memories in different ranks depending on the particular memory configuration.
In alternative embodiments, buffer 450 may implement a different routing scheme to enable different memory configurations that are not necessarily an odd/even configuration as described in the example. For example, in an alternative embodiment, buffer 450 can configure memory module 400 as either a lower memory module (communicating with lower data lines) or an upper memory module (communicating with upper data lines). Furthermore, buffer 450 can configure memory module 400 according to different grouping of data lines that may involve three or more subsets (e.g., each memory uses a quarter of the available data lines).
For example, in one embodiment a memory controller 860 provides commands (via command address signal CA) and data (via data pins 886, 888) to perform memory operations such as read or write operations. Memory controller 860 also includes output pins 882, 884 for providing enable signals 412, 414 to control the configuration of one or more connected memory modules 800. Thus, memory controller 860 can dynamically configure connected memory modules 800 as either odd memory modules, even modules, or full-width memory modules. Alternative embodiments may include a memory controller that can configure memory modules according to different possible configurations discussed above (e.g., lower/upper memory modules, quarter-width configurations, etc.).
Upon reading this disclosure, those of ordinary skill in the art will appreciate still alternative structural and functional designs and processes for a folded memory module. Thus, while particular embodiments and applications of the present disclosure have been illustrated and described, it is to be understood that the disclosure is not limited to the precise construction and components disclosed herein. Various modifications, changes and variations which will be apparent to those skilled in the art may be made in the arrangement, operation and details of the method and apparatus of the present disclosure herein without departing from the scope of the disclosure as defined in the appended claims.
Shaeffer, Ian, Rajan, Suresh, Amirkhany, Amir, Secker, David A., Kollipara, Ravindranath
| Patent | Priority | Assignee | Title | 
| 10235242, | Sep 28 2015 | Rambus Inc. | Fault tolerant memory systems and components with interconnected and redundant data interfaces | 
| 10455698, | Oct 15 2013 | Rambus, Inc. | Load reduced memory module | 
| 10813216, | Oct 15 2013 | Rambus Inc. | Load reduced memory module | 
| 11061773, | Sep 28 2015 | Rambus Inc. | Fault tolerant memory systems and components with interconnected and redundant data interfaces | 
| 11317510, | Oct 15 2013 | Rambus Inc. | Load reduced memory module | 
| 11468925, | Dec 03 2018 | Rambus Inc. | DRAM interface mode with improved channel integrity and efficiency at high signaling rates | 
| 11709736, | Sep 28 2015 | Rambus Inc. | Fault tolerant memory systems and components with interconnected and redundant data interfaces | 
| 11955200, | Dec 03 2018 | Rambus Inc. | Dram interface mode with improved channel integrity and efficiency at high signaling rates | 
| 11963299, | Oct 15 2013 | Rambus Inc. | Load reduced memory module | 
| Patent | Priority | Assignee | Title | 
| 6820163, | Sep 18 2000 | Intel Corporation | Buffering data transfer between a chipset and memory modules | 
| 7606042, | Sep 03 2004 | TAMIRAS PER PTE LTD , LLC | High capacity thin module system and method | 
| 8380943, | Jan 07 2008 | Rambus Inc | Variable-width memory module and buffer | 
| 8756364, | Mar 05 2004 | Netlist, Inc. | Multirank DDR memory modual with load reduction | 
| 9037774, | Mar 05 2004 | Netlist, Inc. | Memory module with load reducing circuit and method of operation | 
| 20010052057, | |||
| 20040186956, | |||
| 20040188704, | |||
| 20050166026, | |||
| 20140040568, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Mar 08 2013 | SECKER, DAVID A | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0004 | |
| Mar 08 2013 | RAJAN, SURESH | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0004 | |
| Mar 09 2013 | AMIRKHANY, AMIR | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0004 | |
| Mar 21 2013 | KOLLIPARA, RAVINDRANATH | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0004 | |
| Mar 22 2013 | SHAEFFER, IAN | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0004 | |
| Feb 18 2014 | Rambus Inc. | (assignment on the face of the patent) | / | |||
| Mar 05 2014 | RAJAN, SURESH | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0067 | |
| Mar 05 2014 | KOLLIPARA, RAVINDRANATH | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0067 | |
| Mar 10 2014 | AMIRKHANY, AMIR | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0067 | |
| Mar 19 2014 | SECKER, DAVID A | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0067 | |
| Mar 25 2014 | SHAEFFER, IAN | Rambus Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032597/ | 0067 | 
| Date | Maintenance Fee Events | 
| May 08 2020 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. | 
| May 08 2024 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. | 
| Date | Maintenance Schedule | 
| Nov 08 2019 | 4 years fee payment window open | 
| May 08 2020 | 6 months grace period start (w surcharge) | 
| Nov 08 2020 | patent expiry (for year 4) | 
| Nov 08 2022 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Nov 08 2023 | 8 years fee payment window open | 
| May 08 2024 | 6 months grace period start (w surcharge) | 
| Nov 08 2024 | patent expiry (for year 8) | 
| Nov 08 2026 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Nov 08 2027 | 12 years fee payment window open | 
| May 08 2028 | 6 months grace period start (w surcharge) | 
| Nov 08 2028 | patent expiry (for year 12) | 
| Nov 08 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |