WO2008039886A2 - Main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies - Google Patents
Main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies Download PDFInfo
- Publication number
- WO2008039886A2 WO2008039886A2 PCT/US2007/079622 US2007079622W WO2008039886A2 WO 2008039886 A2 WO2008039886 A2 WO 2008039886A2 US 2007079622 W US2007079622 W US 2007079622W WO 2008039886 A2 WO2008039886 A2 WO 2008039886A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- memory
- volatile memory
- printed circuit
- circuit board
- volatile
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
- G06F13/1605—Handling requests for interconnection or transfer for access to memory bus based on arbitration
- G06F13/1652—Handling requests for interconnection or transfer for access to memory bus based on arbitration in a multiprocessor architecture
- G06F13/1657—Access to multiple memories
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/06—Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
- G06F12/0638—Combination of memories, e.g. ROM and RAM such as to permit replacement or supplementing of words in one module by words in another module
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/10—Program control for peripheral devices
- G06F13/12—Program control for peripheral devices using hardware independent of the central processor, e.g. channel or peripheral processor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
- G06F13/1668—Details of memory controller
- G06F13/1694—Configuration of memory controller to different memory types
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1006—Data managing, e.g. manipulating data before writing or reading out, data bus switches or control circuits therefor
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1072—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers for memories with random access ports synchronised on clock signal pulse trains, e.g. synchronous memories, self timed memories
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/25—Using a specific main memory architecture
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7203—Temporary buffering, e.g. using volatile buffer or dedicated buffer blocks
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
- Structures For Mounting Electric Components On Printed Circuit Boards (AREA)
Abstract
An apparatus includes a printed circuit board with a plurality of printed circuit board traces, a memory controller mounted on the printed circuit board coupled to one or more of the plurality of printed circuit board traces, a plurality of non-volatile type of memory integrated circuits coupled to the printed circuit board, and a plurality of support integrated circuits coupled between the memory controller and the plurality of non-volatile type of memory integrated circuits.
Description
MAIN MEMORY IN A SYSTEM WITH A MEMORY CONTROLLER
CONFIGURED TO CONTROL ACCESS TO NON-VOLATILE MEMORY, AND RELATED TECHNOLOGIES
CROSS REFERENCE TO RELATED APPLICATIONS
[0001] This PCT Patent Application claims the benefit of U.S. Provisional Patent
Application No. 60/827,421 entitled SUBSTITUTION OF A PROCESSOR WITH A BUILT IN DRAM MEMORY CONTROLLER BY A NON-DRAM MEMORY CONTROLLER TO CONTROL ACCESS TO NON-DRAM TYPE MEMORY MODULES filed on September 28, 2006 by inventors Kumar Ganapathy et al and U.S. Provisional Patent Application No. 60/862,597 entitled EXPANSION OF MAIN MEMORY IN A MULTPROCESSOR SYSTEM WITH A NON-DRAM MEMORY CONTROLLER TO CONTROL ACCESS TO NON-DRAM TYPE MEMORY filed on October 23, 2006 by inventors Kumar Ganapathy et al. This Application further claims the benefit of U.S. Non-Provisional Application 11/847,986 entitled MAIN MEMORY IN A SYSTEM WITH A MEMORY CONTROLLER CONFIGURED TO CONTROL ACCESS TO NON-VOLATILE MEMORY, AND RELATED TECHNOLOGIES, filed on August 30, 2007 by inventors Vijay Karamcheti et al.
FIELD
[0002] This document generally relates to memory controllers and memory modules.
BACKGROUND
[0003] A computing system may include dynamic random access memory (DRAM) integrated circuits (ICs) as part of its main memory. DRAM ICs retain data information by storing a certain amount of charge on a capacitor in each memory cell to store a logical one or alternatively, a logical zero. Over time, and because of read operations, the stored charge on the capacitor dissipates, in a process often referred to as leaking off. To preserve the stored charge on a DRAM capacitor, and thus maintain the ability of the DRAM to maintain its memory contents, the stored charge in the memory cell may be increased through refresh cycles, which sometimes are performed periodically.
BRIEF DESCRIPTIONS OF THE DRAWINGS
[0004] Figure 1 is a functional block diagram of a computer system with only DRAM
DIMMS wherein the memory controllers are physically separate from the processors.
[0005] Figure IA is a functional block diagram of an alternate configuration of a memory controller through the use of subsidiary memory controller chips.
[0006] Figure 2A is a functional block diagram of a computer system with integrated memory controllers collocated within the processors.
[0007] Figure 2B is a functional block diagram of another computer system with integrated memory controllers collocated within the processors.
[0008] Figure 3 A is a functional block diagram of a card with a memory controller to control non-DRAM type of memory DIMMS capable of plugging into an expansion slot.
[0009] Figure 3B is a functional block diagram of a card with a memory controller and non-DRAM type of memory mounted thereto.
[0010] Figure 4 is a functional block diagram of a non-DRAM type of memory module.
[0011] Figure 5 is a functional block diagram of an internet server coupled to the internet.
[0012] Figures 6A-6B are functional block diagrams of a support integrated circuit.
[0013] Figure 7A illustrates a flow chart of a method for upgrading a computing system.
[0014] Figure 7B illustrates a flow chart of a method for assembling a printed circuit board assembly with a memory controller and non-DRAM type of memory integrated circuits mounted thereto.
DETAILED DESCRIPTION
[0015] In the following detailed description, numerous examples of specific implementations are set forth. However, implementations may include configurations that include less than all of or alternatives for the detailed features and combinations set forth in these examples.
[0016] For similar memory capacity, dynamic random access memory (DRAM)
integrated circuits (ICs) typically consume more power than non-volatile memory integrated circuits, particularly when data is read. Non-volatile memory integrated circuits typically do not require refresh cycles and thus conserve power. To reduce power consumption in system applications with a main memory, a non-volatile memory integrated circuit may be used in place of or as a supplement to a DRAM integrated circuit.
[0017] Typically, a write access to non-volatile memory integrated circuits takes more time than a write access to DRAM integrated circuits. Some types of non-volatile memory integrated circuits, such as NOR FLASH EEPROM integrated circuits, may be configured with improved read access times (e.g., twice that of DRAM integrated circuits). In order to address differences between read and write performance, a data communication protocol may be used that accesses the non-volatile memory modules in a different manner than DRAM memory modules.
[0018] In one configuration, a non-DRAM memory controller and non-volatile memory modules may be introduced into a computer system. The technologies used by nonvolatile memory integrated circuits differ from dynamic random access memory (DRAM) integrated circuits (ICs) in the structure of their memory cell and in how they store information within the cell. These differences may help the resultant computer system achieve relatively low power consumption characteristics. For example, non-volatile memory integrated circuits typically do not require refresh cycles and thus conserve power. Alternately or in addition, they may help expand the capacity of main memory in the system.
[0019] Referring now to Figure 1, a functional block diagram of a computer system is illustrated with dual in-line memory modules (DIMMS). The computer system includes a multiprocessor mother-board 10OA. Mounted to the mother-board IOOA is a plurality of processor sockets 101 A-101N. Processors 122A-122N may be inserted into these processor sockets 101 A-101N. The processor sockets are connected to the interconnect fabric 103 via traces 102A-102N. The interconnect fabric 103 may consist of printed circuit board traces alone or it may include other integrated circuits. The interconnect fabric 103 may be configured to connect the various processors, memory, and I/O together within the motherboard. Portions of the interconnect fabric logic may be embedded within the processors and memory controllers.
[0020] Additionally mounted to the mother-board IOOA are one or more memory controllers 107A-107N, 117 connected to the interconnect fabric 103 via traces 106A-106N.
The memory controllers 107A-107N, 117 respectively control each of the memory channels 123A-123N, 133A-133N. Additional printed circuit board traces 1 lOA-1 ION in each of the memory channels 123A-123N, 133A-133N are coupled between the memory module sockets 108A-108N and the memory controllers 107A-107N, 117.
[0021] One or more DRAM memory DIMMS 109A-109N may be accommodated by the sockets 108A-108N in the memory channels 123A-123N. One or more non-DRAM DIMMS 1 19A-119N, such as non-volatile random access memory (NVRAM) DIMMS, may be accommodated by the sockets 108A-108N in the memory channels 133A-133N.
[0022] Additionally mounted to the mother-board IOOA are one or more I/O subsystems 1O5A-1O5N that are connected to the interconnect fabric 103 via traces 104A- 104N.
[0023] Additionally mounted to the mother-board 10OA may be one or more expansion (EXP) connectors 121 A-12 IN that may be connected to the interconnect fabric by traces 120A-120N. In one configuration, one or more of the expansion connectors 121 A- 121N are used to upgrade the main memory of the mother-board IOOA.
[0024] In Figure 1, the memory controllers 107A-107N, 117 are directly coupled to the sockets 108A-108N in each respective memory channel 123A-123N, 133A-133N using the PCB traces 110A- 1 ION. However, memory controllers may also indirectly couple to the sockets 108A-108N in each memory channel through secondary memory controllers.
[0025] Referring now to Figure 1 A, an alternate memory controller system is used instead of the direct memory control provided by the memory controllers 107A-107N, 117. The alternate memory controller system includes one or more primary memory controllers (PMC) 113A for each of several or all memory control channels, and one or more secondary memory controllers (SMC) 112A- 112N, (SNVMC) 132 for each of the one or more primary memory controllers 1 13A.
[0026] The one or more primary memory controllers (PMC) 1 13 A connect to the interconnect fabric 103 via traces 106A-106N. In this configuration, the one or more primary memory controllers 1 13A are indirectly coupled to the memory channels 123A-123N, 133A- 133N. Each of the one or more primary memory controllers 113A connects to the one or more secondary memory controllers (SMC) 112A- 112N, (SNVMC) 132 via interconnect traces 111 A- H lN.
[0027J Each of the one or more secondary memory controllers 112A-112N, 132 are coupled to the DIMM sockets 108A-108N via the printed circuit board traces 110A- 1 ION. The one or more secondary memory controllers 112A-112N may couple to one or more of the DRAM DIMMS 109A-109N inserted into the DIMM sockets 108A-108N within the memory channels 123A-123N to control the read and write access to DRAM memory modules. One or more secondary non-DRAM memory controllers (SNVMC) 132, such as a secondary non-volatile memory controller, may couple to one or more of the non-DRAM DIMMS 119A-119N (such as non-volatile memory (NVRAM) DlMMS) inserted into the DIMM sockets 108A-108N within the memory channels 133A-133N to control the read and write access to non-DRAM memory modules. In some implementations, the secondary non- DRAM memory controller 132 is a secondary non-volatile memory controller to control read and write access to non-volatile memory modules.
|0028] Referring now to Figure 2A, an alternate multiprocessor system and motherboard IOOB is illustrated. In Figure 2A, the external memory controllers 107A-107N, 117 of Figure 1 are moved into the processor packages 200A-200N, 200P' as part of a processor with one or more integrated memory controllers.
[0029] In the multiprocessor system IOOB, processor sockets 204A-204P are connected to the interconnect fabric 103 via the traces 102A-102N. The processor sockets 204A-204N are also connected to the memory channels 123A-123N, 133A-133N via traces 1 lOA-1 ION. In this construction, the processor package 200A-200N,200P' includes both one or more processor elements (MP) 201 A-201P and an integrated memory controller (IMC) 202A-202N, (INVMC) 212.
[0030] The integrated memory controllers (IMC) 202A-202N control read and write accesses to DRAM memory modules 109A-109N plugged into the DIMM sockets 108A- 108N within the memory channels 123A-123N. The integrated memory controller (INVMC) 212 controls read and write accesses to non-DRAM memory modules 119A-119N (such as non-volatile memory modules) plugged into the DEMM sockets 108A-108N within the memory channels 133A-133N.
[0031] There may be one or more memory controllers within a processor package.
[0032] Referring now to Figure 2B, another alternate multiprocessor system and mother-board IOOB' is illustrated. The multiprocessor system and mother-board IOOB' is similar to the multiprocessor system and mother-board IOOB. However in Figure 2B, the
processor package 200P" includes one or more processor elements (MP) 20 IP with two integrated memory controllers 202P and 212.
[0033] The integrated memory controller (IMC) 202P controls read and write accesses to DRAM memory modules 109A-109N plugged into the DIMM sockets 108A- 108N within the memory channels 123N coupled to the processor 200P". The integrated memory controller (INVMC) 212 controls read and write accesses to non-DRAM memory modules 119A-119N (such as non-volatile memory modules) plugged into the DIMM sockets 108A-108N within the memory channels 133N coupled to the processor 200P".
[0034] As previously discussed, constructions of the multiprocessor systems 10OA,
10OB, and 100B' may have one or more expansion connectors 121A-121N. These connectors may be used to improve system performance by increasing memory capacity with a daughter card. In some cases, they may help reduce the power consumption of the main memory of the computer system.
[0035] In one configuration, the one or more expansion connectors 121 A-121N may be used to upgrade and expand the main memory of the mother-boards 10OA, 10OB, 10OB'.
[0036] Referring now to Figure 3 A, a daughter card 300 is illustrated to upgrade the main memory in the computer systems having the mother-boards 10OA, 10OB, 100B'. The daughter card 300 includes a memory controller 302 to control non-DRAM type of memory DIMMS. The daughter card 300 may also be referred to herein as an expansion board.
[0037] One or more expansion boards 300 are respectively connected to the one or more expansion mother-board connectors 121A-121N in the mother-boards 10OA, 10OB, 10OB' via the edge connector 301. The non-DRAM memory controller 302 is coupled to the edge connector 301 via traces 306A-306N on the printed circuit board 300A. The non- DRAM memory controller 302 is connected to each of the non-DRAM memory channels 307A-307N via traces 3O3A-3O3N, which, in turn, connect to sockets 304A-304N. Non- DRAM DDvIMS 305A-305N are then inserted into the sockets 304A-304N to expand the main memory to include non-DRAM type of memory therein. That is, the main memory in the computer system is expanded to be a heterogeneous main memory with different types of memory integrated circuits therein.
[0038] Referring now to Figure 4, a diagram of a non-DRAM type of memory module 305 is illustrated. The non-DRAM type of memory module 305 may be plugged into
the memory module sockets 304A-304N in the one or more non-DRAM memory channels 307A-307N of the expansion board 300A illustrated in Figure 3 A.
[0039J In one implementation, the non-DRAM type of memory module 305 is a nonvolatile type of memory module. In this case, the non-DRAM memory controller 302 is a non-volatile memory controller. In particular, the non-volatile type of memory module may include at least one NOR-gate flash electrically erasable programmable read only memory (EEPROM) integrated circuit in one implementation.
|0040] In Figure 4, the non-DRAM type of memory module 305 includes a printed circuit board 400 having pads of edge connectors 401 (one on each side for a DIMM) formed thereon, a plurality of non-DRAM memory chips 402A-402N, and a plurality of support chips 403A-403N. The memory module 305 further includes a plurality of printed circuit board traces (e.g., printed wires) 404A-404N and 406A-406L formed on the PCB 400 coupling between the non-DRAM memory chips 402A-402N and the support chips 403A- 403N and between the support chips 403A-403N and the pads of the edge connectors 401.
[0041] In one implementation, the memory module 305 is a dual in-line memory module (DIMM) and the printed circuit board (PCB) 400 is a DIMM PCB. The non-DRAM memory chips 402A-402N may be NOR FLASH EEPROM integrated circuit chips or some other kind of non-DRAM type of memory integrated circuit chips.
[0042] The plurality of support chips 403 A-403N may be used to buffer addresses, and/or multiplex and de-multiplex data to and from the non-DRAM memory chips 402A- 403N. The plurality of support chips 403A-403N may also be referred to herein as a plurality of buffer integrated circuits 403.
[0043] In an alternate implementation, non-DRAM type of memory integrated circuits 402A-402N (e.g., NOR Flash EEPROM) and support chips 403A-403N may be directly mounted onto the printed circuit board 300A of the expansion board 300 in each memory channel 307A-307N and coupled to the traces 303 A-303N without the circuit boards 400, edge connectors 401, and sockets 304A-304N.
[0044] Referring now to Figure 3B, instead of non-DRAM type of memory modules being coupled to sockets of a printed circuit board, non-DRAM type of memory integrated circuits 312AA-312MN (e.g., NOR Flash EEPROM) and support chips 313A-313N are directly mounted onto the printed circuit board 300B as shown. The non-DRAM memory
controller 302 is also mounted on the printed circuit board 300B. The support chips 3 BASON are coupled between the memory controller 302 and the non-DRAM type of memory integrated circuits 312AA-312MN.
[0045] In one implementation, the non-DRAM type of memory integrated circuits
312AA-312MN are non-volatile memory integrated circuits, such as NOR Flash EEPROM integrated circuits. In one configuration, read and write accesses to a non-volatile memory integrated circuit is asymmetric. In this case, a write access to non-volatile memory integrated circuits takes more time than a read access to non-volatile memory integrated circuits. Some types of non-volatile memory integrated circuits, such as NOR FLASH EEPROM integrated circuits, may be configured so that read access times may be reduced to levels sufficient for use in main memory.
[0046] If the system 300' is an expansion board, the printed circuit board 300B includes an edge connector 301 to plug into an expansion socket on a mother-board. In this case, the memory controller 302 may couple to the edge connector 301.
[0047] While an expansion board may be used to increase the capacity of main memory with non-volatile memory as discussed previously, DRAM memory modules may be swapped out for non-volatile memory modules and DRAM memory controllers may be swapped out for non-volatile memory controllers.
[0048] In accordance with the teachings of U.S. provisional patent application
60/827,421 filed on September 28, 2006 by inventors Kumar Ganapathy et al., the main memory of the mother-board IOOA of Figure 1 may be upgraded to swap out DRAM memory modules with non-volatile memory modules in one or more memory channels. In doing so, relatively low power consumption characteristics may be attained by the resultant computer system. In this case (see Figure 1), non-volatile memory modules 119A-1 19N are plugged into sockets 108A-108N of the respective memory channel 133A-133N.
[0049] In one implementation (see Figure 1), one or more of the respective memory controllers of the memory channel with the non-volatile memory modules 1 19A-119N is a non-volatile memory controller 1 17 to control read and write access to the non-volatile memory modules 1 19A-1 19N. In another implementation (see Figure IA), one or more secondary memory controllers of the memory channel may be a non-volatile memory controller 132 to control read and write access to the non-volatile memory modules 119A- 119N in the respective memory channel 133A-133N. In yet another implementation (see
Figures 2A-2B), one or more processors in the multiprocessor system may be replaced with processor packages 200P', 200P" having one or more integrated memory controllers 212, 212 and 202P, one or more of which may be a non-volatile memory controller 212 to control read and write access to the non-volatile memory modules 119A-119N in a respective memory channel 133A-133N.
[0050] Referring now to Figure 6A in accordance with one implementation, a support integrated circuit chip 313 is illustrated as an instance of each of the support chips 313A- 313N illustrated in Figure 3B or support chips 403 A-403N illustrated in Figure 4. The support integrated circuit chips support (i.e., facilitate) read and write data accesses by the non-volatile memory controllers to non-volatile type of memory modules and to non-volatile memory integrated circuits.
[0051] The support chip 313 may include a many-to-one bus multiplexer 602 and a one-to-many bus demultiplexer 604. The many-to-one bus multiplexer 602 is used to write data onto a data bus 316 such as data buses 316A-316N illustrated in Figure 3B or printed circuit board traces 406A-406L illustrated in Figure 4. The one-to-many bus demultiplexer 604 may be used to read data from the data bus 316, such as data buses 316A-316N or the printed circuit board traces 406A-406L, onto one of many data buses such as data buses 314A-314N or printed circuit board traces 404A-404N coupled to the memory integrated circuits.
[0052] Referring now to Figure 6B in accordance with another implementation, a support chip 313' is illustrated as an instance of each of the support chips 313A-313N illustrated in Figure 3B or support chips 403A-403N illustrated in Figure 4. The support chip 313' may instead include a cross-bar switch 606 coupled between the plurality of data buses 314A-314N in Figure 3B or printed circuit board traces 404A-404N in Figure 4 connected to the memory integrated circuits and the data bus 316 such as data buses 316A-316N illustrated in Figure 3B or printed circuit board traces 406A-406L illustrated in Figure 4. The cross bar switch 606 is used to write data onto the data bus 316 or printed circuit board traces 406A- 406L from the memory integrated circuits. The cross bar switch 616 is used further to read data from the data bus 316 or printed circuit board traces 406A-406L and couple the data onto one of data buses 314A-314N or a plurality of printed circuit board traces 404A-404N connected to the memory integrated circuits.
[0053] Referring now to Figure 7 A, a flow chart of a method for upgrading a
computing system using an expansion board of the form shown in Figures 3 A or 3B is illustrated.
[0054] At block 702, an expansion board having a memory controller is plugged into an expansion socket on a mother-board. The memory controller is a non-DRAM memory controller to control read and write accesses to non-DRAM type of memory modules. In one implementation, the non-DRAM type of memory modules are non-volatile type of memory modules, such as NOR flash electrically erasable programmable read only memory (EEPROM) for example.
[0055] At block 704, a plurality of non-DRAM type of memory modules are plugged into memory sockets of the expansion board. The memory sockets are coupled to the memory controller by way of printed circuit board traces on the expansion board.
[0056] At block 706, to access the non-DRAM type of memory modules in the expansion board, a data communication protocol is used for the non-DRAM type of memory modules. The data communication protocol to access the non-DRAM type of memory modules may differ from the data communication protocol to access DRAM type of memory modules. If a non-volatile memory module is plugged into a memory module socket a data communication protocol for accessing non-volatile memory modules may be used to address the asymmetry between read and write performance.
[0057] In the data communication protocol for accessing non-volatile memory modules, a feedback status control signal is communicated from a non-volatile memory module to the memory controller to alleviate the non-deterministic nature of the erase and write operations in the non-volatile memory modules. With a feedback status control signal, the memory controller can avoid constantly polling the memory module as to when an erase or write operation is completed. Each feedback status control signal indicates whether or not a rank of memory in a memory module is busy or ready for another access to alleviate the non-deterministic nature of erase and write operations to non-volatile memory modules.
[0058] Referring now to Figure 7B, a method of assembling a printed circuit board assembly is illustrated.
[0059] At block 712, non-DRAM type of memory integrated circuits (e.g., NOR
Flash EEPROM) are mounted to a printed circuit board and coupled to the printed circuit board traces of the printed circuit board.
[0060] At block 714, support chips are also mounted onto the printed circuit board coupled to printed circuit board traces of the printed circuit board.
[0061J At block 716, a non-DRAM memory controller is also mounted on the printed circuit board and coupled to printed circuit board traces of the printed circuit board.
[0062] The support chips are coupled between the memory controller and the non-
DRAM type of memory integrated circuits. In one implementation, the non-DRAM type of memory integrated circuits are non-volatile memory integrated circuits, such as NOR Flash EEPROM integrated circuits.
[0063] If the printed circuit board is manufactured as an expansion board, the method of assembly of the printed circuit board may further include coupling or forming an edge connector onto or in the printed circuit board. In this case, the non-DRAM memory controller may couple to the edge connector.
[0064] Referring now to Figure 5, a block diagram of an internet server 500 and a remote client 501 coupled to the internet 502 is illustrated. The internet server 500 includes the mother-board 10OA, 10OB, 10OB' that has been upgraded by the one or more of the expansion boards 300A or 300B plugged into the one or more mother-board expansion sockets 121 A-121N. Each of the expansion boards 300A include non-volatile memory modules 305 plugged into the memory module sockets of one or more added memory channels to upgrade main memory to include non-volatile memory.
[0065] An example of the use of non-volatile memory modules in main memory is now described. The remote client 501 executes a search query 510 against a search engine running on the internet server 500 to search for data. In this case, the main memory 512 on the mother-board 100A,100B associated with internet server 500 may be more often read than it is written. This application behavior permits the use of non-volatile memory modules in lieu of DRAM memory modules. With the mother-board 10OA, 10OB, 10OB' upgraded to include non-volatile memory modules in its main memory 512, power is conserved over that of a main memory solely having DRAM memory modules. Additionally, because of the cost advantage of non-volatile memory integrated circuits over DRAM integrated circuits, the internet server 500 can be configured with the same main memory capacity for less money, or alternately, can benefit from higher main memory capacity for the same cost.
[0066] While this specification includes many specifics, these should not be
construed as limitations on the scope of the disclosure or of what may be claimed, but rather as descriptions of features specific to particular implementations of the disclosure. Certain features that are described in this specification in the context of separate implementations also may be implemented in combination in a single implementation. Conversely, various features that are described in the context of a single implementation also may be implemented in multiple implementations separately or in sub-combination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination may in some cases be excised from the combination, and the claimed combination may be directed to a sub- combination or variation of a sub-combination.
[0067] A number of implementations have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the disclosure. Other implementations are within the scope of the following claims. For example, the memory modules and the memory sockets have been described as being dual in-line memory modules (DIMM) and DIMM sockets. However, the memory modules and memory sockets may have other types of form factors such as single in-line memory modules (SIMM), for example.
Claims
1. A system comprising: a mother-board having processor sockets, memory module sockets, and one or more expansion sockets, the processor sockets being configured to receive a processor and the memory module sockets being configured to receive a memory module, each processor socket being coupled to one or more dynamic random access memory channels via corresponding printed circuit board traces, each of the memory channels having one or more memory module sockets coupled to the corresponding printed circuit board traces, the one or more expansion sockets being coupled to an interconnect fabric of the mother-board; and at least one expansion board coupled to at least one expansion socket, the at least one expansion board accommodates a first non-DRAM memory controller configured to control read and write accesses of data in at least one non-DRAM memory channel.
2. The system of cl ai m 1 , wherei n the at least one expansion board further includes one or more memory module sockets coupled to the first non-DRAM memory controller, and one or more non-volatile memory modules respectively plugged into the one or more memory module sockets.
3. The system of claim 2, wherein the one or more memory module sockets of the at least one expansion board are dual in-line memory module (DIMM) sockets, and the one or more non-volatile memory modules are non-volatile dual in-line memory modules.
4 The system of claim 2 wherein at least one memory device of the one or more non-volatile memory modules is a NOR flash electrically erasable programmable read only memory (EEPROM) integrated circuit chip.
5. The system of claim 1, wherein the at least one expansion board further includes first non-volatile memory in the at least one non-DRAM memory channel coupled to the first non-DRAM memory controller.
6. The system of claim 5, further comprising: at least another expansion board coupled to at least another expansion socket to further expand main memory of the system, the at least another expansion board includes a second non-DRAM memory controller mounted there-to to control read and write accesses of data in at least another non-DRAM memory channel.
7. The system of claim 6, wherein the at least another expansion board further includes second non-volatile memory in the at least another non-DRAM memory channel coupled to the second non-DRAM memory controller, the second non-volatile memory differs from the first non-volatile memory.
8. An apparatus comprising: a printed circuit board (PCB) having a plurality of printed circuit board traces; a memory controller mounted on the printed circuit board coupled to one or more of the plurality of printed circuit board traces; a plurality of non-volatile type of memory integrated circuits coupled to the printed circuit board; and a plurality of support integrated circuits coupled between the memory controller and the plurality of non-volatile type of memory integrated circuits.
9. The apparatus of claim 8, wherein the plurality of support integrated circuits each include a many-to-one bus multiplexer to write data onto a data bus on the printed circuit board, and a one-to-many bus demultiplexer to read data from the data bus into one or more of the non-volatile type of memory integrated circuits.
10. The apparatus of claim 8, wherein the plurality of support integrated circuits each include a cross bar switch coupled between the memory integrated circuits and a data bus coupled to the memory controller, the switch to write data onto the data bus from the memory integrated circuits, the switch to further read data from the data bus and couple the data into one or more of the memory integrated circuits.
11. The apparatus of claim 8, wherein the plurality of non-volatile type of memory integrated circuits are mounted to the printed circuit board and coupled to one or more of the printed circuit board traces, and the plurality of support integrated circuits are mounted to the printed circuit board and coupled to one or more of the printed circuit board traces.
12. The apparatus of claim 8, wherein the plurality of non-volatile type of memory integrated circuits and the plurality of support integrated circuits are mounted to a plurality of non-volatile memory modules, and the printed circuit board further includes a plurality of sockets into which the plurality of non-volatile memory modules are plugged.
13. The apparatus of claim 8, wherein the printed circuit board further has an edge connector to plug into an expansion socket on a mother-board, and the memory controller is further coupled to the edge connector.
14. The apparatus of claim 8 wherein the plurality of non-volatile type of memory integrated circuits are NOR flash electrically erasable programmable read only memory (EEPROM) integrated circuits.
15. A system comprising: a printed circuit board including a first memory channel having a plurality of DRAM memory modules plugged into a first plurality of sockets; a first memory controller to coupled to the first plurality of sockets in the first memory channel to control access to the plurality of DRAM memory modules; a second memory channel having a first plurality of non-volatile memory modules plugged into a second plurality of sockets, the first plurality of non-volatile memory modules to conserve power, and a second memory controller coupled to the second plurality of sockets in the second memory channel, the second memory controller to control access to the first plurality of non-volatile memory modules.
16. The system of claim 15, further comprising: a third memory channel having a second plurality of non-volatile memory modules plugged into a third plurality of sockets, the second plurality of non-volatile memory modules differing from the first plurality of non-volatile memory modules, the second plurality of non-volatile memory modules to conserve power and expand memory capacity of main memory; and a third memory controller coupled to the third plurality of sockets in the third memory channel, the third memory controller to control access to the second plurality of non-volatile memory modules.
17. The system of claim 15, further comprising: a processor coupled to the first memory controller and the second memory controller.
18. The system of claim 15, wherein the second memory controller is a secondary memory controller; and the system further includes a third memory controller coupled between the processor and the second memory controller.
19. The system of claim 15, wherein the first memory controller is a first integrated memory controller and the second memory controller is a second integrated memory controller, and the system further includes a processor coupled to the first memory channel and the second memory channel, the processor including the first integrated memory controller and the second integrated memory controller.
20. The system of claim 15, wherein a first data communication protocol to access the plurality of DRAM memory modules in the first memory channel differs from a second data communication protocol to access the first plurality of non-volatile memory modules in the second memory channel.
21. The system of claim 16, wherein a first data communication protocol to access the plurality of DRAM memory modules in the first memory channel differs from a second data communication protocol to access the first plurality of non-volatile memory modules in the second memory channel, and a third data communication protocol to access the second plurality of nonvolatile memory modules in the third memory channel differs from the second data communication protocol to access the first plurality of non-volatile memory modules in the second memory channel.
22. A method of upgrading a computer system, the method comprising: plugging an expansion board having a memory controller into an expansion socket on a mother-board, the memory controller to control read and write accesses to non-volatile memory modules; plugging in a plurality of non-volatile type of memory modules into memory sockets of the expansion board, the memory sockets coupled to the memory controller by printed circuit board traces; and accessing the non-volatile memory modules in the expansion board using a data communication protocol for non-volatile memory modules.
23. The method of claim 22, wherein the non-volatile memory modules include NOR flash electrically erasable programmable read only memory (EEPROM).
24. The method of claim 22, wherein the data communication protocol to access the non-volatile memory modules differs from a data communication protocol to access DRAM memory modules.
25. The method of claim 22, wherein the data communication protocol to access non-volatile memory modules includes a status signal to indicate when a non-volatile memory module is busy performing an operation.
26. The method of claim 22, wherein the data communication protocol to access non-volatile memory modules includes a status signal to indicate when a non-volatile memory module is ready to perform an operation.
27. The method of claim 24, wherein a write access time of the non-volatile memory modules differs from a write access time of the DRAM memory modules.
28. The method of claim 27, wherein a read access time of the non-volatile memory modules is substantially similar to a read access time of the DRAM memory modules.
29. A method of assembling a printed circuit board assembly, the method comprising: mounting a plurality of non-volatile memory integrated circuits to a printed circuit board coupled to printed circuit board traces of the printed circuit board; mounting a non-DRAM memory controller to the printed circuit board coupled to printed circuit board traces of the printed circuit board; wherein the non-DRAM memory controller is used to control read and write accesses to the plurality of non-volatile memory integrated circuits.
30. The method of claim 29, further comprising: mounting support chips to the printed circuit board coupled to printed circuit board traces between the non-DRAM memory controller and the plurality of nonvolatile memory integrated circuits, the support chips to buffer addresses, multiplex and de-multiplex data to and from the plurality of non-volatile memory integrated circuits.
31. The method of claim 29, wherein the plurality of non-volatile memory integrated circuits are NOR flash electrically erasable programmable read only memory (EEPROM) integrated circuits.
32. The method of claim 29, wherein a data communication protocol to access the plurality of non-volatile memory integrated circuits differs from a data communication protocol to access DRAM integrated circuits.
33. The method of claim 29, wherein a write access time of the non-volatile memory integrated circuits differs from a write access time of DRAM integrated circuits.
34. The method of claim 33, wherein a read access time of the plurality of non-volatile memory integrated circuits is substantially similar to a read access time of DRAM integrated circuits.
35. The method of claim 29, further comprising: coupling an edge connector to the printed circuit board, the edge connector in communication with the non-DRAM memory controller.
36. The method of claim 29, further comprising: forming an edge connector in the printed circuit board, the edge connector coupled to the non-DRAM memory controller.
37. A method of assembly of a computer system, the method comprising: plugging a processor package into a processor socket on a mother board, the processor package including a processor and a first integrated memory controller, the first integrated memory controller to control read and write accesses to non-volatile memory modules in a first memory channel; plugging in a plurality of non-volatile memory modules into memory sockets in the first memory channel on the mother board, the memory sockets coupled to the processor socket by printed circuit board traces; and accessing the non-volatile memory modules in the first memory channel using a data communication protocol for non-volatile memory modules.
38. The method of claim 37, wherein the non-volatile memory modules include NOR flash electrically erasable programmable read only memory (EEPROM).
39. The method of claim 37, wherein the data communication protocol to access non-volatile memory modules includes a status signal to indicate when a non-volatile memory module is busy performing an operation.
40. The method of claim 37, wherein the data communication protocol to access non-volatile memory modules includes a status signal to indicate when a non-volatile memory module is ready to perform an operation.
41. The method of claim 37, wherein the processor package further includes a second integrated memory controller, the second integrated memory controller to control read and write accesses to dynamic random access memory modules in a second memory channel.
42. The method of claim 41, wherein the data communication protocol to access the non-volatile memory modules in the first memory channel differs from a data communication protocol to access DRAM memory modules in the second memory channel.
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US82742106P | 2006-09-28 | 2006-09-28 | |
US60/827,421 | 2006-09-28 | ||
US86259706P | 2006-10-23 | 2006-10-23 | |
US60/862,597 | 2006-10-23 | ||
US11/847,986 | 2007-08-30 | ||
US11/847,986 US7761623B2 (en) | 2006-09-28 | 2007-08-30 | Main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies |
Publications (2)
Publication Number | Publication Date |
---|---|
WO2008039886A2 true WO2008039886A2 (en) | 2008-04-03 |
WO2008039886A3 WO2008039886A3 (en) | 2008-08-14 |
Family
ID=39230958
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2007/079622 WO2008039886A2 (en) | 2006-09-28 | 2007-09-27 | Main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies |
Country Status (3)
Country | Link |
---|---|
US (5) | US7761623B2 (en) |
TW (1) | TWI454923B (en) |
WO (1) | WO2008039886A2 (en) |
Families Citing this family (78)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7761625B2 (en) * | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Methods for main memory with non-volatile type memory modules, and related technologies |
US8949555B1 (en) | 2007-08-30 | 2015-02-03 | Virident Systems, Inc. | Methods for sustained read and write performance with non-volatile memory |
US9984012B2 (en) | 2006-09-28 | 2018-05-29 | Virident Systems, Llc | Read writeable randomly accessible non-volatile memory modules |
US20080082750A1 (en) * | 2006-09-28 | 2008-04-03 | Okin Kenneth A | Methods of communicating to, memory modules in a memory channel |
US7761624B2 (en) * | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Systems and apparatus for main memory with non-volatile type memory modules, and related technologies |
US7761626B2 (en) * | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Methods for main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies |
US8051253B2 (en) * | 2006-09-28 | 2011-11-01 | Virident Systems, Inc. | Systems and apparatus with programmable memory control for heterogeneous main memory |
US8074022B2 (en) | 2006-09-28 | 2011-12-06 | Virident Systems, Inc. | Programmable heterogeneous memory controllers for main memory with different memory modules |
US8189328B2 (en) * | 2006-10-23 | 2012-05-29 | Virident Systems, Inc. | Methods and apparatus of dual inline memory modules for flash memory |
WO2008055270A2 (en) * | 2006-11-04 | 2008-05-08 | Virident Systems, Inc. | Writing to asymmetric memory |
US8230145B2 (en) * | 2007-07-31 | 2012-07-24 | Hewlett-Packard Development Company, L.P. | Memory expansion blade for multiple architectures |
US8521967B1 (en) | 2008-06-24 | 2013-08-27 | Virident Systems, Inc. | Network computing systems having shared memory clouds with addresses of disk-read-only memories mapped into processor address spaces |
US9513695B2 (en) | 2008-06-24 | 2016-12-06 | Virident Systems, Inc. | Methods of managing power in network computer systems |
US8069300B2 (en) | 2008-09-30 | 2011-11-29 | Micron Technology, Inc. | Solid state storage device controller with expansion mode |
JP5473317B2 (en) * | 2008-12-24 | 2014-04-16 | ピーエスフォー ルクスコ エスエイアールエル | Memory module and layout method thereof |
US8446729B2 (en) * | 2009-03-23 | 2013-05-21 | Ocz Technology Group Inc. | Modular mass storage system and method therefor |
US9330736B2 (en) * | 2012-11-09 | 2016-05-03 | Qualcomm Incorporated | Processor memory optimization via page access counting |
WO2014098839A1 (en) * | 2012-12-19 | 2014-06-26 | Hewlett-Packard Development Company | Nvram path selection |
US9280497B2 (en) | 2012-12-21 | 2016-03-08 | Dell Products Lp | Systems and methods for support of non-volatile memory on a DDR memory channel |
US9921980B2 (en) | 2013-08-12 | 2018-03-20 | Micron Technology, Inc. | Apparatuses and methods for configuring I/Os of memory for hybrid memory modules |
US9396065B2 (en) | 2014-06-25 | 2016-07-19 | Intel Corporation | Extensible memory hub |
US10606651B2 (en) | 2015-04-17 | 2020-03-31 | Microsoft Technology Licensing, Llc | Free form expression accelerator with thread length-based thread assignment to clustered soft processor cores that share a functional circuit |
US10540588B2 (en) | 2015-06-29 | 2020-01-21 | Microsoft Technology Licensing, Llc | Deep neural network processing on hardware accelerators with stacked memory |
US10452995B2 (en) | 2015-06-29 | 2019-10-22 | Microsoft Technology Licensing, Llc | Machine learning classification on hardware accelerators with stacked memory |
US10073644B2 (en) | 2016-03-21 | 2018-09-11 | Toshiba Memory Corporation | Electronic apparatus including memory modules that can operate in either memory mode or storage mode |
US10359946B1 (en) * | 2016-05-03 | 2019-07-23 | Altera Corporation | Systems and methods for operating a flash memory in an integrated circuit |
US10839904B2 (en) | 2016-12-09 | 2020-11-17 | Rambus Inc. | Memory module for platform with non-volatile storage |
US10877898B2 (en) | 2017-11-16 | 2020-12-29 | Alibaba Group Holding Limited | Method and system for enhancing flash translation layer mapping flexibility for performance and lifespan improvements |
US10496548B2 (en) | 2018-02-07 | 2019-12-03 | Alibaba Group Holding Limited | Method and system for user-space storage I/O stack with user-space flash translation layer |
US10831404B2 (en) * | 2018-02-08 | 2020-11-10 | Alibaba Group Holding Limited | Method and system for facilitating high-capacity shared memory using DIMM from retired servers |
US11379155B2 (en) | 2018-05-24 | 2022-07-05 | Alibaba Group Holding Limited | System and method for flash storage management using multiple open page stripes |
US10921992B2 (en) | 2018-06-25 | 2021-02-16 | Alibaba Group Holding Limited | Method and system for data placement in a hard disk drive based on access frequency for improved IOPS and utilization efficiency |
WO2020000136A1 (en) | 2018-06-25 | 2020-01-02 | Alibaba Group Holding Limited | System and method for managing resources of a storage device and quantifying the cost of i/o requests |
US10996886B2 (en) | 2018-08-02 | 2021-05-04 | Alibaba Group Holding Limited | Method and system for facilitating atomicity and latency assurance on variable sized I/O |
US11327929B2 (en) | 2018-09-17 | 2022-05-10 | Alibaba Group Holding Limited | Method and system for reduced data movement compression using in-storage computing and a customized file system |
TWI684914B (en) * | 2018-12-25 | 2020-02-11 | 技嘉科技股份有限公司 | Electronic device for updating on-board data of power off status and electronic device package assembly |
US10977122B2 (en) | 2018-12-31 | 2021-04-13 | Alibaba Group Holding Limited | System and method for facilitating differentiated error correction in high-density flash devices |
US11061735B2 (en) | 2019-01-02 | 2021-07-13 | Alibaba Group Holding Limited | System and method for offloading computation to storage nodes in distributed system |
US11132291B2 (en) | 2019-01-04 | 2021-09-28 | Alibaba Group Holding Limited | System and method of FPGA-executed flash translation layer in multiple solid state drives |
US11200337B2 (en) | 2019-02-11 | 2021-12-14 | Alibaba Group Holding Limited | System and method for user data isolation |
US10970212B2 (en) | 2019-02-15 | 2021-04-06 | Alibaba Group Holding Limited | Method and system for facilitating a distributed storage system with a total cost of ownership reduction for multiple available zones |
US11061834B2 (en) | 2019-02-26 | 2021-07-13 | Alibaba Group Holding Limited | Method and system for facilitating an improved storage system by decoupling the controller from the storage medium |
US10891065B2 (en) | 2019-04-01 | 2021-01-12 | Alibaba Group Holding Limited | Method and system for online conversion of bad blocks for improvement of performance and longevity in a solid state drive |
US10922234B2 (en) | 2019-04-11 | 2021-02-16 | Alibaba Group Holding Limited | Method and system for online recovery of logical-to-physical mapping table affected by noise sources in a solid state drive |
US10908960B2 (en) | 2019-04-16 | 2021-02-02 | Alibaba Group Holding Limited | Resource allocation based on comprehensive I/O monitoring in a distributed storage system |
CN110058818B (en) * | 2019-04-18 | 2022-06-07 | 深圳忆联信息系统有限公司 | Method and system for optimizing descriptor processing sequence based on SSD |
US11169873B2 (en) | 2019-05-21 | 2021-11-09 | Alibaba Group Holding Limited | Method and system for extending lifespan and enhancing throughput in a high-density solid state drive |
US10860223B1 (en) | 2019-07-18 | 2020-12-08 | Alibaba Group Holding Limited | Method and system for enhancing a distributed storage system by decoupling computation and network tasks |
US11074124B2 (en) | 2019-07-23 | 2021-07-27 | Alibaba Group Holding Limited | Method and system for enhancing throughput of big data analysis in a NAND-based read source storage |
US11126561B2 (en) | 2019-10-01 | 2021-09-21 | Alibaba Group Holding Limited | Method and system for organizing NAND blocks and placing data to facilitate high-throughput for random writes in a solid state drive |
US11617282B2 (en) | 2019-10-01 | 2023-03-28 | Alibaba Group Holding Limited | System and method for reshaping power budget of cabinet to facilitate improved deployment density of servers |
US11449455B2 (en) | 2020-01-15 | 2022-09-20 | Alibaba Group Holding Limited | Method and system for facilitating a high-capacity object storage system with configuration agility and mixed deployment flexibility |
US11379447B2 (en) | 2020-02-06 | 2022-07-05 | Alibaba Group Holding Limited | Method and system for enhancing IOPS of a hard disk drive system based on storing metadata in host volatile memory and data in non-volatile memory using a shared controller |
US11150986B2 (en) | 2020-02-26 | 2021-10-19 | Alibaba Group Holding Limited | Efficient compaction on log-structured distributed file system using erasure coding for resource consumption reduction |
US11200114B2 (en) | 2020-03-17 | 2021-12-14 | Alibaba Group Holding Limited | System and method for facilitating elastic error correction code in memory |
US11449386B2 (en) | 2020-03-20 | 2022-09-20 | Alibaba Group Holding Limited | Method and system for optimizing persistent memory on data retention, endurance, and performance for host memory |
US11169881B2 (en) | 2020-03-30 | 2021-11-09 | Alibaba Group Holding Limited | System and method for facilitating reduction of complexity and data movement in erasure coding merging on journal and data storage drive |
US11385833B2 (en) | 2020-04-20 | 2022-07-12 | Alibaba Group Holding Limited | Method and system for facilitating a light-weight garbage collection with a reduced utilization of resources |
US11301173B2 (en) | 2020-04-20 | 2022-04-12 | Alibaba Group Holding Limited | Method and system for facilitating evaluation of data access frequency and allocation of storage device resources |
US11281575B2 (en) | 2020-05-11 | 2022-03-22 | Alibaba Group Holding Limited | Method and system for facilitating data placement and control of physical addresses with multi-queue I/O blocks |
US11494115B2 (en) | 2020-05-13 | 2022-11-08 | Alibaba Group Holding Limited | System method for facilitating memory media as file storage device based on real-time hashing by performing integrity check with a cyclical redundancy check (CRC) |
US11461262B2 (en) | 2020-05-13 | 2022-10-04 | Alibaba Group Holding Limited | Method and system for facilitating a converged computation and storage node in a distributed storage system |
US11218165B2 (en) | 2020-05-15 | 2022-01-04 | Alibaba Group Holding Limited | Memory-mapped two-dimensional error correction code for multi-bit error tolerance in DRAM |
US11556277B2 (en) | 2020-05-19 | 2023-01-17 | Alibaba Group Holding Limited | System and method for facilitating improved performance in ordering key-value storage with input/output stack simplification |
US11507499B2 (en) | 2020-05-19 | 2022-11-22 | Alibaba Group Holding Limited | System and method for facilitating mitigation of read/write amplification in data compression |
US11263132B2 (en) | 2020-06-11 | 2022-03-01 | Alibaba Group Holding Limited | Method and system for facilitating log-structure data organization |
US11354200B2 (en) | 2020-06-17 | 2022-06-07 | Alibaba Group Holding Limited | Method and system for facilitating data recovery and version rollback in a storage device |
US11422931B2 (en) | 2020-06-17 | 2022-08-23 | Alibaba Group Holding Limited | Method and system for facilitating a physically isolated storage unit for multi-tenancy virtualization |
US11354233B2 (en) | 2020-07-27 | 2022-06-07 | Alibaba Group Holding Limited | Method and system for facilitating fast crash recovery in a storage device |
US11372774B2 (en) | 2020-08-24 | 2022-06-28 | Alibaba Group Holding Limited | Method and system for a solid state drive with on-chip memory integration |
US11487465B2 (en) | 2020-12-11 | 2022-11-01 | Alibaba Group Holding Limited | Method and system for a local storage engine collaborating with a solid state drive controller |
US11734115B2 (en) | 2020-12-28 | 2023-08-22 | Alibaba Group Holding Limited | Method and system for facilitating write latency reduction in a queue depth of one scenario |
KR20220097586A (en) * | 2020-12-30 | 2022-07-08 | 삼성전자주식회사 | Memory module, main board, and server device |
US11416365B2 (en) | 2020-12-30 | 2022-08-16 | Alibaba Group Holding Limited | Method and system for open NAND block detection and correction in an open-channel SSD |
US11726699B2 (en) | 2021-03-30 | 2023-08-15 | Alibaba Singapore Holding Private Limited | Method and system for facilitating multi-stream sequential read performance improvement with reduced read amplification |
US11461173B1 (en) | 2021-04-21 | 2022-10-04 | Alibaba Singapore Holding Private Limited | Method and system for facilitating efficient data compression based on error correction code and reorganization of data placement |
US11476874B1 (en) | 2021-05-14 | 2022-10-18 | Alibaba Singapore Holding Private Limited | Method and system for facilitating a storage server with hybrid memory for journaling and data storage |
CN115565560A (en) * | 2022-01-06 | 2023-01-03 | 澜起电子科技(上海)有限公司 | Storage device with modular design and storage system comprising same |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4757533A (en) * | 1985-09-11 | 1988-07-12 | Computer Security Corporation | Security system for microcomputers |
US20020051350A1 (en) * | 2000-10-20 | 2002-05-02 | Mitsubishi Denki Kabushiki Kaisha | Load adjustment board and data processing apparatus |
US20030137862A1 (en) * | 2001-07-12 | 2003-07-24 | Brunelle Steven J. | Reversed memory module socket, motherboard and test system including same, and method of modifying motherboard |
US20040117581A1 (en) * | 2002-12-13 | 2004-06-17 | Samsung Electronics Co., Ltd. | Computer system and control method thereof |
US20040186948A1 (en) * | 1991-07-26 | 2004-09-23 | Lofgren Karl M. J. | Device and method for controlling solid-state memory system |
US20040193783A1 (en) * | 2003-03-26 | 2004-09-30 | Manish Sharma | Computer system with operating system permitting dynamic reallocation of main memory |
US20050166026A1 (en) * | 2000-01-05 | 2005-07-28 | Fred Ware | Configurable width buffered module having switch elements |
US20060149857A1 (en) * | 1997-12-05 | 2006-07-06 | Holman Thomas J | Memory system including a memory module having a memory module controller |
Family Cites Families (62)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6336180B1 (en) | 1997-04-30 | 2002-01-01 | Canon Kabushiki Kaisha | Method, apparatus and system for managing virtual memory with virtual-physical mapping |
US5012408A (en) | 1990-03-15 | 1991-04-30 | Digital Equipment Corporation | Memory array addressing system for computer systems with multiple memory arrays |
US5375222A (en) | 1992-03-31 | 1994-12-20 | Intel Corporation | Flash memory card with a ready/busy mask register |
US5404485A (en) | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
US7137011B1 (en) * | 1993-09-01 | 2006-11-14 | Sandisk Corporation | Removable mother/daughter peripheral card |
US5898857A (en) | 1994-12-13 | 1999-04-27 | International Business Machines Corporation | Method and system for interfacing an upgrade processor to a data processing system |
US5701438A (en) | 1995-09-29 | 1997-12-23 | Intel Corporation | Logical relocation of memory based on memory device type |
US5710733A (en) | 1996-01-22 | 1998-01-20 | Silicon Graphics, Inc. | Processor-inclusive memory module |
US6185704B1 (en) | 1997-04-11 | 2001-02-06 | Texas Instruments Incorporated | System signaling schemes for processor and memory module |
US20040236877A1 (en) | 1997-12-17 | 2004-11-25 | Lee A. Burton | Switch/network adapter port incorporating shared memory resources selectively accessible by a direct execution logic element and one or more dense logic devices in a fully buffered dual in-line memory module format (FB-DIMM) |
US6970968B1 (en) | 1998-02-13 | 2005-11-29 | Intel Corporation | Memory module controller for providing an interface between a system memory controller and a plurality of memory devices on a memory module |
US6207474B1 (en) | 1998-03-09 | 2001-03-27 | Micron Technology, Inc. | Method of forming a stack of packaged memory die and resulting apparatus |
US6109929A (en) * | 1998-07-29 | 2000-08-29 | Agilent Technologies, Inc. | High speed stackable memory system and device |
US6564326B2 (en) | 1999-07-06 | 2003-05-13 | Walter A. Helbig, Sr. | Method and apparatus for enhancing computer system security |
US6549959B1 (en) | 1999-08-30 | 2003-04-15 | Ati International Srl | Detecting modification to computer memory by a DMA device |
US7010642B2 (en) | 2000-01-05 | 2006-03-07 | Rambus Inc. | System featuring a controller device and a memory module that includes an integrated circuit buffer device and a plurality of integrated circuit memory devices |
JP3955712B2 (en) | 2000-03-03 | 2007-08-08 | 株式会社ルネサステクノロジ | Semiconductor device |
US6757751B1 (en) * | 2000-08-11 | 2004-06-29 | Harrison Gene | High-speed, multiple-bank, stacked, and PCB-mounted memory module |
US6785780B1 (en) | 2000-08-31 | 2004-08-31 | Micron Technology, Inc. | Distributed processor memory module and method |
US7034955B2 (en) | 2000-12-11 | 2006-04-25 | Texas Instruments Incorporated | Using a processor enhanced memory module to accelerate hardcopy image processing within existing printer controller |
US6779049B2 (en) | 2000-12-14 | 2004-08-17 | International Business Machines Corporation | Symmetric multi-processing system with attached processing units being able to access a shared memory without being structurally configured with an address translation mechanism |
WO2002058069A2 (en) | 2001-01-17 | 2002-07-25 | Honeywell International Inc. | Enhanced memory module architecture |
US7091598B2 (en) | 2001-01-19 | 2006-08-15 | Renesas Technology Corporation | Electronic circuit device |
JP4722305B2 (en) | 2001-02-27 | 2011-07-13 | 富士通セミコンダクター株式会社 | Memory system |
US20020138600A1 (en) | 2001-03-26 | 2002-09-26 | International Business Machines Corporation | Method, apparatus and program for multi-machine network install using writeable media |
US20030090879A1 (en) | 2001-06-14 | 2003-05-15 | Doblar Drew G. | Dual inline memory module |
US7293014B2 (en) * | 2001-06-18 | 2007-11-06 | Siebel Systems, Inc. | System and method to enable searching across multiple databases and files using a single search |
US6707756B2 (en) | 2002-03-12 | 2004-03-16 | Smart Modular Technologies, Inc. | System and method for translation of SDRAM and DDR signals |
US7096377B2 (en) | 2002-03-27 | 2006-08-22 | Intel Corporation | Method and apparatus for setting timing parameters |
KR100506062B1 (en) * | 2002-12-18 | 2005-08-05 | 주식회사 하이닉스반도체 | Composite Memory Device |
DE10330593B4 (en) * | 2003-07-07 | 2010-11-04 | Qimonda Ag | Integrated clock supply module for a memory module, memory module, which includes the integrated clock supply module, as well as methods for operating the memory module under test conditions |
US7657706B2 (en) | 2003-12-18 | 2010-02-02 | Cisco Technology, Inc. | High speed memory and input/output processor subsystem for efficiently allocating and using high-speed memory and slower-speed memory |
US20050251617A1 (en) | 2004-05-07 | 2005-11-10 | Sinclair Alan W | Hybrid non-volatile memory system |
US7269708B2 (en) | 2004-04-20 | 2007-09-11 | Rambus Inc. | Memory controller for non-homogenous memory system |
US7206915B2 (en) | 2004-06-03 | 2007-04-17 | Emc Corp | Virtual space manager for computer having a physical address extension feature |
TWI299497B (en) | 2004-06-24 | 2008-08-01 | Via Tech Inc | Method and related apparatus for accessing memory apparatus |
US20060026375A1 (en) * | 2004-07-30 | 2006-02-02 | Christenson Bruce A | Memory controller transaction scheduling algorithm using variable and uniform latency |
US7324352B2 (en) | 2004-09-03 | 2008-01-29 | Staktek Group L.P. | High capacity thin module system and method |
US7613870B2 (en) | 2004-11-18 | 2009-11-03 | International Business Machines Corporation | Efficient memory usage in systems including volatile and high-density memories |
US7212408B2 (en) * | 2004-12-28 | 2007-05-01 | Intel Corporation | Multi-slot socket for mounting integrated circuits on circuit board |
US20060195631A1 (en) | 2005-01-31 | 2006-08-31 | Ramasubramanian Rajamani | Memory buffers for merging local data from memory modules |
US7702839B2 (en) | 2005-04-12 | 2010-04-20 | Nokia Corporation | Memory interface for volatile and non-volatile memory devices |
US7398484B2 (en) * | 2005-04-27 | 2008-07-08 | Microsoft Corporation | Memory efficient array transposition via multi pass tiling |
JP2006338370A (en) * | 2005-06-02 | 2006-12-14 | Toshiba Corp | Memory system |
US8327104B2 (en) | 2006-07-31 | 2012-12-04 | Google Inc. | Adjusting the timing of signals associated with a memory system |
US8089795B2 (en) * | 2006-02-09 | 2012-01-03 | Google Inc. | Memory module with memory stack and interface with enhanced capabilities |
US20070047655A1 (en) * | 2005-08-26 | 2007-03-01 | Vannerson Eric F | Transpose buffering for video processing |
US7464225B2 (en) * | 2005-09-26 | 2008-12-09 | Rambus Inc. | Memory module including a plurality of integrated circuit memory devices and a plurality of buffer devices in a matrix topology |
US7640386B2 (en) | 2006-05-24 | 2009-12-29 | International Business Machines Corporation | Systems and methods for providing memory modules with multiple hub devices |
US7550834B2 (en) | 2006-06-29 | 2009-06-23 | Sandisk Corporation | Stacked, interconnected semiconductor packages |
US7411757B2 (en) * | 2006-07-27 | 2008-08-12 | Hitachi Global Storage Technologies Netherlands B.V. | Disk drive with nonvolatile memory having multiple modes of operation |
WO2008014494A2 (en) | 2006-07-28 | 2008-01-31 | Drc Computer Corporation | Fpga co-processor for accelerated computation |
US7761624B2 (en) | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Systems and apparatus for main memory with non-volatile type memory modules, and related technologies |
US8074022B2 (en) | 2006-09-28 | 2011-12-06 | Virident Systems, Inc. | Programmable heterogeneous memory controllers for main memory with different memory modules |
US8051253B2 (en) | 2006-09-28 | 2011-11-01 | Virident Systems, Inc. | Systems and apparatus with programmable memory control for heterogeneous main memory |
US7761626B2 (en) | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Methods for main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies |
US8806116B2 (en) | 2008-02-12 | 2014-08-12 | Virident Systems, Inc. | Memory modules for two-dimensional main memory |
US20080082750A1 (en) | 2006-09-28 | 2008-04-03 | Okin Kenneth A | Methods of communicating to, memory modules in a memory channel |
US7761625B2 (en) | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Methods for main memory with non-volatile type memory modules, and related technologies |
US8189328B2 (en) | 2006-10-23 | 2012-05-29 | Virident Systems, Inc. | Methods and apparatus of dual inline memory modules for flash memory |
US8301833B1 (en) * | 2007-06-01 | 2012-10-30 | Netlist, Inc. | Non-volatile memory module |
US9251899B2 (en) | 2008-02-12 | 2016-02-02 | Virident Systems, Inc. | Methods for upgrading main memory in computer systems to two-dimensional memory modules and master memory controllers |
-
2007
- 2007-08-30 US US11/847,986 patent/US7761623B2/en not_active Expired - Fee Related
- 2007-09-27 WO PCT/US2007/079622 patent/WO2008039886A2/en active Application Filing
- 2007-09-27 TW TW096136068A patent/TWI454923B/en active
-
2010
- 2010-07-06 US US12/831,233 patent/US8370547B2/en active Active
-
2013
- 2013-01-22 US US13/747,455 patent/US8972633B2/en not_active Expired - Fee Related
-
2014
- 2014-09-02 US US14/475,398 patent/US9626290B2/en active Active
-
2017
- 2017-04-17 US US15/489,282 patent/US10191842B2/en active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4757533A (en) * | 1985-09-11 | 1988-07-12 | Computer Security Corporation | Security system for microcomputers |
US20040186948A1 (en) * | 1991-07-26 | 2004-09-23 | Lofgren Karl M. J. | Device and method for controlling solid-state memory system |
US20060149857A1 (en) * | 1997-12-05 | 2006-07-06 | Holman Thomas J | Memory system including a memory module having a memory module controller |
US20050166026A1 (en) * | 2000-01-05 | 2005-07-28 | Fred Ware | Configurable width buffered module having switch elements |
US20020051350A1 (en) * | 2000-10-20 | 2002-05-02 | Mitsubishi Denki Kabushiki Kaisha | Load adjustment board and data processing apparatus |
US20030137862A1 (en) * | 2001-07-12 | 2003-07-24 | Brunelle Steven J. | Reversed memory module socket, motherboard and test system including same, and method of modifying motherboard |
US20040117581A1 (en) * | 2002-12-13 | 2004-06-17 | Samsung Electronics Co., Ltd. | Computer system and control method thereof |
US20040193783A1 (en) * | 2003-03-26 | 2004-09-30 | Manish Sharma | Computer system with operating system permitting dynamic reallocation of main memory |
Also Published As
Publication number | Publication date |
---|---|
US20170220461A1 (en) | 2017-08-03 |
TW200825751A (en) | 2008-06-16 |
US20080082731A1 (en) | 2008-04-03 |
US8370547B2 (en) | 2013-02-05 |
WO2008039886A3 (en) | 2008-08-14 |
US20130138872A1 (en) | 2013-05-30 |
TWI454923B (en) | 2014-10-01 |
US9626290B2 (en) | 2017-04-18 |
US20100274957A1 (en) | 2010-10-28 |
US7761623B2 (en) | 2010-07-20 |
US8972633B2 (en) | 2015-03-03 |
US20140379969A1 (en) | 2014-12-25 |
US10191842B2 (en) | 2019-01-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10191842B2 (en) | Apparatus with a memory controller configured to control access to randomly accessible non-volatile memory | |
US7761626B2 (en) | Methods for main memory in a system with a memory controller configured to control access to non-volatile memory, and related technologies | |
US7761625B2 (en) | Methods for main memory with non-volatile type memory modules, and related technologies | |
US7761624B2 (en) | Systems and apparatus for main memory with non-volatile type memory modules, and related technologies | |
US9767867B2 (en) | Methods of communicating to different types of memory modules in a memory channel | |
US8874843B2 (en) | Systems with programmable heterogeneous memory controllers for main memory | |
US8943245B2 (en) | Non-volatile type memory modules for main memory | |
WO2008040028A2 (en) | Systems, methods, and apparatus with programmable memory control for heterogeneous main memory | |
US8938600B2 (en) | Memory system, memory control method, and recording medium storing memory control program | |
CN102339635A (en) | Slot-type solid state disk (SSD) and data transmission method | |
US9984012B2 (en) | Read writeable randomly accessible non-volatile memory modules | |
TWI446171B (en) | Systems, methods, and apparatus with programmable memory control for heterogeneous main memory |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 07843283 Country of ref document: EP Kind code of ref document: A2 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 07843283 Country of ref document: EP Kind code of ref document: A2 |