Suche Bilder Maps Play YouTube News Gmail Drive Mehr »
Anmelden
Nutzer von Screenreadern: Klicke auf diesen Link, um die Bedienungshilfen zu aktivieren. Dieser Modus bietet die gleichen Grundfunktionen, funktioniert aber besser mit deinem Reader.

Patentsuche

  1. Erweiterte Patentsuche
VeröffentlichungsnummerUS20080109595 A1
PublikationstypAnmeldung
AnmeldenummerUS 11/929,261
Veröffentlichungsdatum8. Mai 2008
Eingetragen30. Okt. 2007
Prioritätsdatum9. Febr. 2006
Auch veröffentlicht unterUS9542352, US9542353, US20070204075, US20080120443
Veröffentlichungsnummer11929261, 929261, US 2008/0109595 A1, US 2008/109595 A1, US 20080109595 A1, US 20080109595A1, US 2008109595 A1, US 2008109595A1, US-A1-20080109595, US-A1-2008109595, US2008/0109595A1, US2008/109595A1, US20080109595 A1, US20080109595A1, US2008109595 A1, US2008109595A1
ErfinderSuresh Rajan, Keith Schakel, Michael Sebastian Smith, David Wang, Frederick Weber
Ursprünglich BevollmächtigterRajan Suresh N, Schakel Keith R, Sebastian Smith Michael J, Wang David T, Weber Frederick D
Zitat exportierenBiBTeX, EndNote, RefMan
Externe Links: USPTO, USPTO-Zuordnung, Espacenet
System and method for reducing command scheduling constraints of memory circuits
US 20080109595 A1
Zusammenfassung
A memory circuit system and method are provided. An interface circuit is capable of communication with a plurality of memory circuits and a system. In use, the interface circuit is operable to interface the memory circuits and the system for reducing command scheduling constraints of the memory circuits.
Bilder(16)
Previous page
Next page
Ansprüche(20)
1. A sub-system, comprising:
an interface circuit capable of communication with a plurality of memory circuits and a system, the interface circuit operable to interface the memory circuits and the system for reducing command scheduling constraints of the memory circuits.
2. The sub-system as set forth in claim 1, wherein the command scheduling constraints include inter-device command scheduling constraints.
3. The sub-system as set forth in claim 2, wherein the inter-device command scheduling constraints are selected from the group consisting of a rank-to-rank data bus turnaround time, and an on-die-termination (ODT) control switching time.
4. The sub-system as set forth in claim 1, wherein the command scheduling constraints include intra-device command scheduling constraints.
5. The sub-system as set forth in claim 4, wherein the intra-device command scheduling constraints are selected from the group consisting of a column-to-column delay time (tCCD), a row-to-row activation delay time (tRRD), a four-bank activation window time (tFAW), and a write-to-read turn-around time (tWTR).
6. The sub-system as set forth in claim 1, wherein the command scheduling constraints of the memory circuits are reduced by controlling a manner in which commands are issued to the memory circuits.
7. The sub-system as set forth in claim 1, wherein the memory circuits include physical memory circuits, and the interface circuit is operable to simulate at least one virtual memory circuit.
8. The sub-system as set forth in claim 7, wherein the at least one virtual memory circuit has less command scheduling constraints than the physical memory circuits.
9. The sub-system as set forth in claim 7, wherein the command scheduling constraints of the physical memory circuits are reduced by issuing commands directed to a single virtual memory circuit, to a plurality of different physical memory circuits.
10. The sub-system as set forth in claim 6, wherein the commands are selected from the group consisting of row-access commands and column-access commands.
11. The sub-system as set forth in claim 6, wherein the commands are issued to different memory circuits utilizing separate busses.
12. The sub-system as set forth in claim 1, wherein the reduction of the command scheduling constraints of the memory circuits results in an increase of in a command issue rate.
13. The sub-system as set forth in claim 1, wherein the interface circuit includes a circuit that is positioned on a dual in-line memory module (DIMM).
14. The sub-system as set forth in claim 1, wherein the interface circuit is selected from the group consisting of a buffer, a register, a memory controller, and an advancedd memory buffer (AMB).
15. The sub-system as set forth in claim 1, wherein the interface circuit and the memory circuits take the form of a stack.
16. The sub-system as set forth in claim 1, wherein the memory circuits include a plurality of dynamic random access memory (DRAM) circuits.
17. A method, comprising:
interfacing a plurality of memory circuits and a system; and
reducing command scheduling constraints of the memory circuits.
18. A system, comprising:
a plurality of memory circuits; and
an interface circuit in communication with the memory circuits, the interface circuit operable to interface the memory circuits for reducing command scheduling constraints of the memory circuits.
19. The system as set forth in claim 18, wherein the memory circuits and the interface circuit are positioned on a dual in-line memory module (DIMM).
20. the system as set forth in claim 18, wherein the memory circuits and the interface circuit are positioned on a memory module that remains in communication with a processor via a bus.
Beschreibung
    RELATED APPLICATION(S)
  • [0001]
    The application is a continuation of U.S. application Ser. No.: 11/672,921 filed Feb. 08, 2007, which, in turn, is a continuation-in-part of U.S. application Ser. No.: 11/461,437 filed Jul. 31, 2006, U.S. application Ser. No.: 11/702,960 filed Feb. 05, 2007, and U.S. application Ser. No.: 11/702,981 filed Feb. 05, 2007; and further claims priority to U.S. provisional application Ser. No.: 60/772,414 filed Feb. 09, 2006 and U.S. provisional application Ser. No.: 60/865,624 filed Nov. 13, 2006, which are each incorporated herein by reference in their entirety for all purposes.
  • FIELD OF THE INVENTION
  • [0002]
    The present invention relates to memory, and more particularly to command scheduling constraints of memory circuits.
  • BACKGROUND
  • [0003]
    Traditionally, memory circuit speeds have remained constant, while the required data transfer speeds and bandwidth of memory systems have steadily increased. Thus, it has been necessary for more commands be scheduled, issued, and pipelined in a memory system in order to increase bandwidth. However, command scheduling constraints have customarily existed in memory systems which limit the command issue rates, and thus limit various attempts to further increase bandwidth, etc. There is thus a need for addressing these and/or other issues associated with the prior art.
  • SUMMARY
  • [0004]
    A memory circuit system and method are provided. An interface circuit is capable of communication with a plurality of memory circuits and a system. In use, the interface circuit is operable to interface the memory circuits and the system for reducing command scheduling constraints of the memory circuits.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • [0005]
    FIG. 1 illustrates a system for interfacing memory circuits, in accordance with one embodiment.
  • [0006]
    FIG. 2 illustrates a method for reducing command scheduling constraints of memory circuits, in accordance with another embodiment.
  • [0007]
    FIG. 3 illustrates a method for translating an address associated with a command communicated between a system and memory circuits, in accordance with yet another embodiment.
  • [0008]
    FIG. 4 illustrates a block diagram including logical components of a computer platform, in accordance with another embodiment.
  • [0009]
    FIG. 5 illustrates a timing diagram showing an intra-device command sequence, intra-device timing constraints, and resulting idle cycles that prevent full use of bandwidth utilization in a DDR3 SDRAM memory system, in accordance with yet another embodiment.
  • [0010]
    FIG. 6 illustrates a timing diagram showing an inter-device command sequence, inter-device timing constraints, and resulting idle cycles that prevent full use of bandwidth utilization in a DDR SDRAM, DDR2 SDRAM, or DDR3 SDRAM memory system, in accordance with still yet another embodiment.
  • [0011]
    FIG. 7 illustrates a block diagram showing an array of DRAM devices connected to a memory controller, in accordance with another embodiment.
  • [0012]
    FIG. 8 illustrates a block diagram showing an interface circuit disposed between an array of DRAM devices and a memory controller, in accordance with yet another embodiment.
  • [0013]
    FIG. 9 illustrates a block diagram showing a DDR3 SDRAM interface circuit disposed between an array of DRAM devices and a memory controller, in accordance with another embodiment.
  • [0014]
    FIG. 10 illustrates a block diagram showing a burst-merging interface circuit connected to multiple DRAM devices with multiple independent data buses, in accordance with still yet another embodiment.
  • [0015]
    FIG. 11 illustrates a timing diagram showing continuous data transfer over multiple commands in a command sequence, in accordance with another embodiment.
  • [0016]
    FIG. 12 illustrates a block diagram showing a protocol translation and interface circuit connected to multiple DRAM devices with multiple independent data buses, in accordance with yet another embodiment.
  • [0017]
    FIG. 13 illustrates a timing diagram showing the effect when a memory controller issues a column-access command late, in accordance with another embodiment.
  • [0018]
    FIG. 14 illustrates a timing diagram showing the effect when a memory controller issues a column-access command early, in accordance with still yet another embodiment.
  • [0019]
    FIG. 15 illustrates a representative hardware environment, in accordance with one embodiment.
  • DETAILED DESCRIPTION
  • [0020]
    FIG. 1 illustrates a system 100 for interfacing memory circuits, in accordance with one embodiment. As shown, the system 100 includes an interface circuit 104 in communication with a plurality of memory circuits 102 and a system 106. In the context of the present description, such memory circuits 102 may include any circuits capable of serving as memory.
  • [0021]
    For example, in various embodiments, at least one of the memory circuits 102 may include a monolithic memory circuit, a semiconductor die, a chip, a packaged memory circuit, or any other type of tangible memory circuit. In one embodiment, the memory circuits 102 may take the form of dynamic random access memory (DRAM) circuits. Such DRAM may take any form including, but not limited to, synchronous DRAM (SDRAM), double data rate synchronous DRAM (DDR SDRAM, DDR2 SDRAM, DDR3 SDRAM, etc.), graphics double data rate DRAM (GDDR, GDDR2, GDDR3, etc.), quad data rate DRAM (QDR DRAM), RAMBUS XDR DRAM (XDR DRAM), fast page mode DRAM (FPM DRAM), video DRAM (VDRAM), extended data out DRAM (EDO DRAM), burst EDO RAM (BEDO DRAM), multibank DRAM (MDRAM), synchronous graphics RAM (SGRAM) and/or any other type of DRAM.
  • [0022]
    In another embodiment, at least one of the memory circuits 102 may include magnetic random access memory (MDRAM), intelligent random access memory (IRAM), distributed network architecture (DNA) memory, window random access memory (WRAM), flash memory (e.g., NAND, NOR, etc.), pseudostatic random access memory (PSRAM), wetware memory, memory based on semiconductor, atomic, molecular, optical, organic, biological, chemical, or nanoscale technology, and/or any other type of volatile or nonvolatile, random or non-random access, serial or parallel access memory circuit.
  • [0023]
    Strictly as an option, the memory circuits 102 may or may not be positioned on at least one dual in-line memory module (DIMM) (not shown). In various embodiments, the DIMM may include a registered DIMM (R-DIMM), a small outline-DIMM (SO-DIMM), a fully buffered DIMM (FB-DIMM), an unbuffered DIMM (UDIMM), single inline memory module (SIMM), a MiniDIMM, a very low profile (VLP) R-DIMM, etc. In other embodiments, the memory circuits 102 may or may not be positioned on any type of material forming a substrate, card, module, sheet, fabric, board, carrier or any other type of solid or flexible entity, form, or object. Of course, in yet other embodiments, the memory circuits 102 may or may not be positioned in or on any desired entity, form, or object for packaging purposes. Still yet, the memory circuits 102 may or may not be organized into ranks. Such ranks may refer to any arrangement of such memory circuits 102 on any of the foregoing entities, forms, objects, etc.
  • [0024]
    Further, in the context of the present description, the system 106 may include any system capable of requesting and/or initiating a process that results in an access of the memory circuits 102. As an option, the system 106 may accomplish this utilizing a memory controller (not shown), or any other desired mechanism. In one embodiment, such system 106 may include a system in the form of a desktop computer, a lap-top computer, a server, a storage system, a networking system, a workstation, a personal digital assistant (PDA), a mobile phone, a television, a computer peripheral (e.g. printer, etc.), a consumer electronics system, a communication system, and/or any other software and/or hardware, for that matter.
  • [0025]
    The interface circuit 104 may, in the context of the present description, refer to any circuit capable of interfacing (e.g. communicating, buffering, etc.) with the memory circuits 102 and the system 106. For example, the interface circuit 104 may, in the context of different embodiments, include a circuit capable of directly (e.g. via wire, bus, connector, and/or any other direct communication medium, etc.) and/or indirectly (e.g. via wireless, optical, capacitive, electric field, magnetic field, electromagnetic field, and/or any other indirect communication medium, etc.) communicating with the memory circuits 102 and the system 106. In additional different embodiments, the communication may use a direct connection (e.g. point-to-point, single-drop bus, multi-drop bus, serial bus, parallel bus, link, and/or any other direct connection, etc.) or may use an indirect connection (e.g. through intermediate circuits, intermediate logic, an intermediate bus or busses, and/or any other indirect connection, etc.)
  • [0026]
    In additional optional embodiments, the interface circuit 104 may include one or more circuits, such as a buffer (e.g. buffer chip, etc.), a register (e.g. register chip, etc.), an advanced memory buffer (AMB) (e.g. AMB chip, etc.), a component positioned on at least one DIMM, a memory controller, etc. Moreover, the register may, in various embodiments, include a JEDEC Solid State Technology Association (known as JEDEC) standard register (a JEDEC register), a register with forwarding, storing, and/or buffering capabilities, etc. In various embodiments, the register chips, buffer chips, and/or any other interface circuit 104 may be intelligent, that is, include logic that is capable of one or more functions such as gathering and/or storing information; inferring, predicting, and/or storing state and/or status; performing logical decisions; and/or performing operations on input signals, etc. In still other embodiments, the interface circuit 104 may optionally be manufactured in monolithic form, packaged form, printed form, and/or any other manufactured form of circuit, for that matter. Furthermore, in another embodiment, the interface circuit 104 may be positioned on a DIMM.
  • [0027]
    In still yet another embodiment, a plurality of the aforementioned interface circuit 104 may service, in combination, to interface the memory circuits 102 and the system 106. Thus, in various embodiments, one, two, three, four, or more interface circuits 104 may be utilized for such interfacing purposes. In addition, multiple interface circuits 104 may be relatively configured or connected in any desired manner. For example, the interface circuits 104 may be configured or connected in parallel, serially, or in various combinations thereof. The multiple interface circuits 104 may use direct connections to each other, indirect connections to each other, or even a combination thereof. Furthermore, any number of the interface circuits 104 may be allocated to any number of the memory circuits 102. In various other embodiments, each of the plurality of interface circuits 104 may be the same or different. Even still, the interface circuits 104 may share the same or similar interface tasks and/or perform different interface tasks.
  • [0028]
    While the memory circuits 102, interface circuit 104, and system 106 are shown to be separate parts, it is contemplated that any of such parts (or portion(s) thereof) may be integrated in any desired manner. In various embodiments, such optional integration may involve simply packaging such parts together (e.g. stacking the parts to form a stack of DRAM circuits, a DRAM stack, a plurality of DRAM stacks, a hardware stack, where a stack may refer to any bundle, collection, or grouping of parts and/or circuits, etc.) and/or integrating them monolithically. Just by way of example, in one optional embodiment, at least one interface circuit 104 (or portion(s) thereof) may be packaged with at least one of the memory circuits 102. In this way, the interface circuit 104 and the memory circuits 102 may take the form of a stack, in one embodiment.
  • [0029]
    For example, a DRAM stack may or may not include at least one interface circuit 104 (or portion(s) thereof). In other embodiments, different numbers of the interface circuit 104 (or portion(s) thereof) may be packaged together. Such different packaging arrangements, when employed, may optionally improve the utilization of a monolithic silicon implementation, for example.
  • [0030]
    The interface circuit 104 may be capable of various functionality, in the context of different optional embodiments. Just by way of example, the interface circuit 104 may or may not be operable to interface a first number of memory circuits 102 and the system 106 for stimulating a second number of memory circuits to the system 106. The first number of memory circuits 102 shall hereafter be referred to, where appropriate for clarification purposes, as the “physical” memory circuits 102 or memory circuits, but are not limited to be so. Just by way of example, the physical memory circuits 102 may include a single physical memory circuit. Further, the at least one stimulated memory circuit seen by the system 106 shall hereafter be referred to, where appropriate for clarification purposes, as the at least one “virtual” memory circuit.
  • [0031]
    In still additional aspects of the present embodiment, the second number of virtual memory circuits may be more than, equal to, or less than the first number of physical memory circuits 102. Just by way of example, the second number of virtual memory circuits may include a single memory circuit. Of course, however, any number of memory circuits may be stimulated.
  • [0032]
    In the context of the present description, the term simulated may refer to any simulating, emulating, disguising, transforming, modifying, changing, altering, shaping, converting, etc., which results in at least one aspect of the memory circuits 102 appearing different to the system 106. In different embodiments, such aspect may include, for example, a number, a signal, a memory capacity, a timing, a latency, a design parameter, a logical interface, a control system, a property, a behavior, and/or any other aspect, for that matter.
  • [0033]
    In different embodiments, the simulation may be electrical in nature, logical in nature, protocol in nature, and/or performed in any other desired manner. For instance, in the context of electrical simulation, a number of pins, wires, signals, etc. may be simulated. In the context of logical simulation, a particular function or behavior may be simulated. In the context of protocol, a particular protocol (e.g. DDR3, etc.) may be simulated. Further, in the context of protocol, the simulation may effect conversion between different protocols (e.g. DDR2 and DDR3) or may effect conversion between different versions of the same protocol (e.g. conversion of 4-4-4 DDR2 to 6-6-6 DDR2).
  • [0034]
    More illustrative information will now be set forth regarding various optional architectures and uses in which the foregoing system may or may not be implemented, per the desires of the user. It should be strongly noted that the following information is set forth for illustrative purposes and should not be construed as limiting in any manner. Any of the following features may be optionally incorporated with or without the exclusion of other features described.
  • [0035]
    FIG. 2 illustrates a method 200 for reducing command scheduling constraints of memory circuits, in accordance with another embodiment. As an option, the method 200 may be implemented in the context of the system 100 of FIG. 1. Of course, however, the method 200 may be implemented in any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0036]
    As shown in operation 202, a plurality of memory circuits and a system are interfaced. In one embodiment, the memory circuits and system may be interfaced utilizing an interface circuit. The interface circuit may include, for example, the interface circuit described above with respect to FIG. 1. In addition, in one embodiment, the interfacing may include facilitating communication between the memory circuits and the system. Of course, however, the memory circuits and system may be interfaced in any desired manner.
  • [0037]
    Further, command scheduling constraints of the memory circuits are reduced, as shown in operation 204. In the context of the present description, the command scheduling constraints include any limitations associated with scheduling (and/or issuing) commands with respect to the memory circuits. Optionally, the command scheduling constraints may be defined by manufacturers in their memory device data sheets, by standards organization such as the JEDEC, etc.
  • [0038]
    In one embodiment, the command scheduling constraints may include intra-device command scheduling constraints. Such intra-device command scheduling constraints may include scheduling constraints within a device. For example, the intra-device command scheduling constraints may include a column-to-column delay time (tCCD), row-to-row activation delay time (tRRD), four-band activation window time (tFAW), write-to-read turn-around time (tWTR), etc. As an option, the intra-device command-scheduling constraints may be associated with parts (e.g. column, row, bank, etc.) of a device (e.g. memory circuit) that share a resource within the memory circuit. One example of such intra-device command scheduling constraints will be described in more detail below with respect to FIG. 5 during the description of a different
  • [0039]
    In another embodiment, the command scheduling constraints may include inter-device command scheduling constraints. Such inter-device scheduling constraints may include scheduling constraints between memory circuits. Just by way of example, the inter-device command scheduling constraints may include rank-to-rank data bus turnaround times, on-die-termination (ODT) control switching times, etc. Optionally, the inter-device command scheduling constraints may be associated with memory circuits that share a resource (e.g. a data bus, etc.) which provides a connection therebetween (e.g. for communicating, etc.). One example of such inter-device command scheduling constraints will be described in more detail below with respect to FIG. 6 during the description of a different embodiment.
  • [0040]
    Further, reduction of the command scheduling restraints may include complete elimination and/or any decrease thereof. Still yet, in one optional embodiment, the command scheduling constraints may be reduced by controlling the manner in which commands are issued to the memory circuits. Such commands may include, for example, row-access commands, column-access commands, et. Moreover, in additional embodiments, the commands may optionally be issued to the memory circuits utilizing separate busses associated therewith. One example of memory circuits associated with separate busses will be described in more detail below with respect to FIG. 8 during the description of a different embodiment.
  • [0041]
    In one possible embodiment, the command scheduling constraints may be reduced by issuing commands to the memory circuits based on stimulation of a virtual memory circuit. For example, the plurality of physical memory circuits and the system may be interfaced such that that the memory circuits appear to the system as a virtual memory circuit. Such simulated virtual memory circuit may optionally include the virtual memory circuit described above with respect to FIG. 1.
  • [0042]
    In addition, the virtual memory circuit may have less command scheduling constraints than the physical memory circuits. For example, in one exemplary embodiment, the physical memory circuits may appear as a group of one or more virtual memory circuits that are free from command scheduling constraints. Thus, as an option, the command scheduling constraints may be reduced by issuing commands directed to a single virtual memory circuit, to a plurality of different physical memory circuits. In this way, idle data-bus cycles may optionally be eliminated and memory system bandwidth may be increased.
  • [0043]
    Of course, it should be noted that the command scheduling constraints may be reduced in any desired manner. Accordingly, in one embodiment, the interface circuit may be utilized to eliminate, at least in part, inter-device and/or intra-device command scheduling constraints of memory circuits. Furthermore, reduction of the command scheduling constraints of the memory circuits may result in increased command issue rates. for example, a greater amount of commands may be issued to the memory circuits by reducing limitations associated with the command scheduling constraints. More information regarding increasing command issue rates by reducing command scheduling constraints will be described with respect to FIG. 11 during the description of a different embodiments.
  • [0044]
    FIG. 3 illustrates a method 300 for translating an address associated with a command communicated between a system and memory circuits, in accordance with yet another embodiment. As an option, the method 300 may be carried out in context of the architecture and environment of FIGS. 1 and/or 2. Of course, the method 300 may be carried out in any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0045]
    As shown in operation 302, a plurality of memory circuits and a system are interfaced. In one embodiment, the memory circuits and system may be interfaced utilizing an interface circuit, such as that described above with respect to FIG. 1, for example. In one embodiment, the interfacing may include facilitating communication between the memory circuits and the system. Of course, however, the memory circuits and system may be interfaced in any desired manner.
  • [0046]
    Additionally, an address associated with a command communicated between the system and the memory circuits is translated, as shown in operation 304. Such command may include, for example a row-access command, a column-access command, and/or any other command capable of being communicated between the system and the memory circuits. As an option, the translation may be transparent to the system. In this way, the system may issue a command to the memory circuits, and such command may be translated without knowledge and/or input by the system. Of course, embodiments are contemplated where such transparency is non-existent, at least in part.
  • [0047]
    Further, the address may be translated in any desired manner. In one embodiment, the translation of the address may include shifting the address. In another embodiment, the address may be translated by mapping the address. Optionally, as described above with respect to FIGS. 1 and/or 2, the memory circuits may include physical memory circuits and the interface circuit may simulate at least one virtual memory circuit. To this end, the virtual memory circuit may optionally have a different (e.g. greater, etc.) number of row addresses associated therewith than the physical memory circuits.
  • [0048]
    Thus, in one possible embodiment, the translation may be performed as a function of the difference in the number of row addresses. For example, the translation may translate the address to reflect the number of row addresses of the virtual memory circuit. In still yet another embodiment, the translation may optionally translate the address as a function of a column address and a row address.
  • [0049]
    Thus, in one exemplary embodiment where the command includes a row-access command, the translation may be performed as a function of an expected arrival time of a column-access command. In another exemplary embodiment, where the command includes a row-access command, the translation may ensure that a column-access command addresses an open bank. Optionally, the interface circuit may be operable to delay the command communicated between the system and the memory circuits. To this end, the translation may result in sub-row activation of the memory circuits. Various examples of address translation will be described in more detail below with respect to FIG. 8 and 12 during the description of different embodiments.
  • [0050]
    Accordingly, in one embodiment, address mapping may use shifting of an address from one command to another to allow the use of memory circuits with smaller rows to emulate a larger memory circuit with larger rows. Thus, sub-row activation may be provided. Such sub-row activation may also reduce power consumption and may optionally further improve performance, in various embodiments.
  • [0051]
    One exemplary embodiment will now be set forth. It should be strongly noted that the following example is set forth for illustrative purposes only and should not be construed as limiting in any manner whatsoever. Specifically, memory storage cells of DRAM devices may be arranged into multiple banks, each bank having multiple rows, and each row having multiple columns. The memory storage capacity of the DRAM device may be equal to the number of banks times the number of rows per bank times the number of column per row times the number of storage bits per column. In commodity DRAM devices (e.g. SDRAM, DDR, DDR2, DDR3, DDR4, GDDR2, GDDR3 and GDDR4 SDRAM, etc.), the number of banks per device, the number of rows per bank, the number of columns per row, and the column sizes may be determined by a standards-forming committee, such as the Joint Electron Device Engineering Council (JEDEC).
  • [0052]
    For example, JEDEC standards require that a 1 gigabyte (Gb) DDR2 or DDR3 SDRAM device with a four-bit wide data bus have eight banks per device, 8192 rows per bank, 2048 columns per row, and four bits per column. Similarly, a 2 Gb device with a four-bit wide data bus has eight banks per device, 16384 rows per bank, 2048 columns per row, and four bits per column. A 4 Gb device with a four-bit wide data bus has eight banks per device, 32768 rows per bank, 2048 columns per row, and four bits per column. In the 1 Gb, 2 Gb and 4 Gb devices, the row size is constant, and the number of rows doubles with each doubling of device capacity. Thus, a 2 Gb or a 4 Gb device may be simulated, as described above, by using multiple 1 Gb and 2 Gb devices, and by directly translating row-activation commands to row-activation commands and column-access commands to column-access commands. In one embodiment, this emulation may be possible because the 1 Gb, 2 Gb, and 4 Gb devices have the same row size.
  • [0053]
    FIG. 4 illustrates a block diagram including logical components of a computer platform 400, in accordance with another embodiment. As an option, the computer platform 400 may be implemented in context of the architecture and environment of FIGS. 1-3. Of course, the computer platform 400 may be implemented in any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0054]
    As shown, the computer platform 400 includes a system 420. The system 420 includes a memory interface 421, logic for retrieval and storage of external memory attribute expectations 422, memory interaction attributes 423, a data processing engine 424, and various mechanisms to facilitate a user interface 425. The computer platform 400 may be comprised of wholly separate components, namely a system 420 (e.g. a motherboard, etc.), and memory circuit 410 (e.g. physical memory circuits, etc.). In addition, the computer platform 400 may optionally include memory circuits, etc.). In addition, the computer platform 400 may optionally include memory circuits 410 connected directly to the system 420 by way of one or more sockets.
  • [0055]
    In one embodiment, the memory circuits 410 may be designed to the specifics of various standards, including for example, a standard defining the memory circuits 410 to be JEDEC-compliant semiconductor memory (e.g. DRAM, SDRAM, DDR2, DDR3, etc.). The specifics of such standards may address physical interconnection and logical capabilities of the memory circuits 410.
  • [0056]
    In another embodiment, the system 420 may include a system BIOS program (not shown) capable of interrogating the physical memory circuits 410 (e.g. DIMMs) to retrieve and store memory attributes 422, 523. Further, various types of external memory circuits 410, including for example JEDEC-compliant DIMMs, may include an EEPROM device known as a serial presence detect (SPD) where the DIMM memory attributes are stored. The interaction of the BIOS with the SPD and the interaction of the BIOS with the memory circuit physical attributes may allow the system memory attribute expectations 422 and memory interaction attributes 423 become known to the system 420.
  • [0057]
    In various embodiments, the computer platform 400 may include one or more interface circuits 470 electrically disposed between the system 420 and the physical memory circuits 410. The interface circuit 470 may include several system-facing interfaces (e.g. a system address signal interface 471, a system control signal interface 472, a system clock signal interface 473, a system data signal interface 474, etc.). Similarly, the interface circuit 470 may include several memory-facing interfaces (e.g. a memory address signal interface 475, a memory control signal interface 476, a memory clock signal interface 477, a memory data signal interface 478, etc.).
  • [0058]
    Still yet, the interface circuit 470 may include emulation logic 480. The emulation logic 480 may be operable to receive and optionally store electrical signals (e.g. logic levels, commands, signals, protocol sequences, communications, etc.) from or through the system-facing interfaces, and may further be operable to process such electrical signals. The emulation logic 480 may respond to signals from system-facing interfaces by responding back to the system 420 and presenting signals to the system 420, and may slo process the signals with other information previously stored. As another option, the emulation logic 480 may present signals to the physical memory circuits 410. Of course, however, the emulation logic 480 may perform any of the aforementioned functions in any order.
  • [0059]
    Moreover, the emulation logic 480 may be operable to adopt a personality, where such personality is capable of defining the physical memory circuit attributes. In various embodiments, the personality may be effected via any combination of bonding options, strapping, programmable strapping, the wiring between the interface circuit 470 and the physical memory circuits 410. Further, the personality may be effected via actual physical attributes (e.g. value of mode register, value of extended mode register) of the physical memory circuits 410 connected to the interface circuit 470 as determined when the interface circuit 470 and physical memory circuits 410 are powered up.
  • [0060]
    FIG. 5 illustrates a timing diagram 500 showing an intra-device command sequence, intra-device timing constraints, and resulting idle cycles that prevent full use of bandwidth utilization in a DDR3 SDRAM memory system, in accordance with yet another embodiment. As an option, the timing diagram 500 may be associated with the architecture and environment of FIGS. 1-4. Of course, the timing diagram 500 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0061]
    As shown, the timing diagram 500 illustrates command cycles, timing constraints and idle cycles of memory. For example, in an embodiment involving DDR3 SDRAM memory systems, any two row-access commands directed to a single DRAM device may not necessarily be scheduled closer that tRRD. As another example, at most four row-access commands may be scheduled within tFAW to a single DRAM device. Moreover, consecutive column-read access commands and consecutive column-write access commands may not necessarily be scheduled to a given DRAM device any closer than tCCD, where tCCD equals four cycles (eight half-cycles of data) in DDR3 DRAM devices.
  • [0062]
    In the context of the present embodiment, row-access and/or row-activation commands are shown as ACT. In addition, column-access commands are shown as READ or WRITE. Thus, for example, in memory systems that require a data access in a data burst of four half-cycles, as shown in FIG. 2, the tCCD constraint may prevent column accesses from being scheduled consecutively. Further, the constraints 510, 520 imposed on the DRAM commands sent to a given DRAM device may restrict the command rate, resulting in idle cycles or bubbles 530 on the data bus, therefore reducing the bandwidth.
  • [0063]
    In another optional embodiment involving DDR3 SDRAM memory systems, consecutive column-access commands sent to different DRAM devices on the same data bus may not necessarily be scheduled any closer than a period that is the sum of the data burst duration plus additional idle cycles due to rank-to-rank data bus turn-around times. In the case of column-read access commands, two DRAM devices on the same data bus may represent two bus masters. Optionally, at least one idle cycle on the bus may be needed for one bus master to complete delivery of data to the memory controller and release control of the shared data bus, such that another bus master may gain control of the data bus and begin to send data.
  • [0064]
    FIG. 6 illustrates a timing diagram 600 showing inter-device command sequence, inter-device timing constraints, and resulting idle cycles that prevent full use of bandwidth utilization in a DDR SDRAM, DDR2 SDRAM, or DDR3 SDRAM memory system, in accordance with still yet another embodiment. As an option, the timing diagram 600 may be associated with the architecture and environment of FIGS. 1-4. Of course, the timing diagram 600 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0065]
    As shown, the timing diagram 600 illustrates commands issued to different devices that are free from constraints such as tRRD and tCCD which would otherwise be imposed on commands issue to the same device. However, as also shown, the data bus hand-off from one device to another device requires at least one idle data-bus cycle 610 on the data bus. Thus, the timing diagram 600 illustrates a limitation preventing full use of bandwidth utilization in a DDR3 SDRAM memory system. As a consequence of the command-scheduling constraints, there may be no available command sequence that allows full bandwidth utilization in a DDR3 SDRAM memory system, which also uses bursts shorter than tCCD.
  • [0066]
    FIG. 7 illustrates a block diagram 700 showing an array of DRAM devices connected to a memory controller, in accordance with another embodiment. As an option, the block diagram 700 may be associated with the architecture and environment of FIGS. 1-6. Of course, the block diagram 700 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0067]
    As shown, eight DRAM devices are connected directly to a memory controller through a shared data bus 710. Accordingly, commands from the memory controller that are directed to the DRAM devices may be issued with respect to command scheduling constraints (e.g. tRRD, tCCD, tFAW, tWTR, etc.). thus, the issuance of commands may be delayed based on such command scheduling constraints.
  • [0068]
    FIG. 8 illustrates a block diagram 800 showing an interface circuit disposed between an array of DRAM devices and a memory controller, in accordance with yet another embodiment. AS an option, the block diagram 800 may be associated with the architecture and environment of FIGS. 1-6. Of course, the block diagram 800 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0069]
    As shown, an interface circuit 810 provides a DRAM interface to the memory controller 820, and directs commands to independent DRAM devices 830. The memory devices 830 may each be associated with a different data bus 540, thus preventing inter-device constraints. In addition, individual and independent memory devices 830 may be used to emulate part of a virtual memory device (e.g. column, row, bank, etc.). Accordingly, intra-device constraints may also be prevented. To this end, the memory devices 830 connected to the interface circuit 510 may appear to the memory controller 820 as a group of one or more memory devices 530 that are free from command-scheduling constraints.
  • [0070]
    In one exemplary embodiment, N physical DRAM devices may be used to emulate M logical DRAM devices through the use of the interface circuit. The interface circuit may accept a command stream from a memory controller directed toward the M logical devices. The interface circuit may also translate the commands to the N physical devices that are connected to the interface circuit via P independent data paths. The command translation may include, for example, routing the correct command directed to one of the M logical devices to the correct device (i.e. one of the N physical devices). Collectively, the P data paths connected to the N physical devices may optionally allow the interface circuit to guarantee that commands may be executed in parallel and independently, thus preventing command-scheduling constraints associated with the N physical devices. In this way the interface circuit may eliminate idle data-bus cycles or bubbles that would otherwise be present due to inter-device and intra-device command-scheduling constraints.
  • [0071]
    FIG. 9 illustrates a block diagram 900 showing a DDR3 SDRAM interface circuit disposed between an array of DRAM devices and a memory controller, in accordance with another embodiment. As an option, the block diagram 900 may be associated with the architecture and environment of FIGS. 1-8. Of course, the block diagram 900 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0072]
    As shown, a DDR3 SDRAM interface circuit 910 eliminates idle data-bus cycles due to inter-device and intra-device scheduling constraints. In the context of the present embodiment, the DDR3 SDRAM interface circuit 910 may include a command translation circuit of an interface circuit that connects multiple DDR3 SDRAM devices with multiple independent data buses. For example, the DDR3 SDRAM interface circuit 910 may include command-and-control and address components capable of intercepting signals between the physical memory circuits and the system. Moreover, the command-and-control and address components may allow for burst merging, as described below with respect to FIG. 10.
  • [0073]
    FIG. 10 illustrates a block diagram 1000 showing a burst-merging interface circuit connected to multiple DRAM devices with multiple independent data buses, in accordance with still yet another embodiment. As an option, the block diagram 1000 may be associated with the architecture and environment of FIGS. 1-9. Of course, the block diagram 1000 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0074]
    A burst-merging interface circuit 1010 may include a data component of an interface circuit that connects multiple DRAM devices 1030 with multiple independent data buses 1040. In addition, the burst-merging interface circuit 1010 may merge multiple burst commands received within a time period. As shown, eight DRAM devices 1030 may be connected via eight independent data paths to the burst-merging interface circuit 1010. Further, the burst-merging interface circuit 1010 may utilize a single data path to the memory controller 820. It should be noted that while eight DRAM devices 1030 are shown herein, in other embodiments, 16, 24, 32, etc. devices may be connected to the eight independent data paths. In yet another embodiment, there may be two, four, eight, 16 or more independent data paths associated with the DRAM devices 1030.
  • [0075]
    The burst-merging interface circuit 1010 may provide a single electrical interface to the memory controller 1020, therefore eliminating inter-device constraints (e.g. rank-to-rank turnaround time, etc.). In one embodiment, the memory controller 1020 may be aware that it is indirectly controlling the DRAM devices 1030 through the burst-merging interface circuit 1010, and that no bus turnaround time is needed. In another embodiment, the burst-merging interface circuit 1010 may use the DRAM devices 1030 to emulate M logical devices. The burst-merging interface circuit 1010 may further translate row-activation commands and column-access commands to one of the DRAM devices 1030 in order to ensure that inter-device constraints (e.g. tRRD, tCCD, tFAW and tWTR etc.) are met by each individual DRAM device 1030, while allowing the burst-merging interface circuit 1010 to present itself as M logical devices that are free from inter-device constraints.
  • [0076]
    FIG. 11 illustrates a timing diagram 1100 showing continuous data transfer over multiple commands in a command sequence, in accordance with another embodiment. As an option, the timing diagram 1100 may be associated with the architecture and environment of FIGS. 1-10. Of course, the timing diagram 1100 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0077]
    As shown, inter-device and intra-device constraints are eliminated, such that the burst-merging interface circuit may permit continuous burst data transfers on the data bus, therefore increasing data bandwidth. For example, an interface circuit associated with the burst-merging interface circuit may present an industry-standard DRAM interface to a memory controller as one or more DRAM devices that are free of command-scheduling constraints. Further, the interface circuits may allow the DRAM devices to be emulated as being free from command-scheduling constraints without necessarily changing the electrical interface or the command set of the DRAM memory system. It should be noted that the interface circuits described herein may include any type of memory system (e.g. DDR2, DDR3, etc.).
  • [0078]
    FIG. 12 illustrates a block diagram 1200 showing a protocol translation and interface circuit connected to multiple DRAM devices with multiple independent data buses, in accordance with yet another embodiment. As an option, the block diagram 1200 may be associated with the architecture and environment of FIGS. 1-11. Of course, the block diagram 1200 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0079]
    As shown, a protocol translation and interface circuit 1210 may perform protocol translation and/or manipulation functions, and may also act as an interface circuit. For example the protocol translation and interface circuit 1210 may be included within an interface circuit connecting a memory controller with multiple memory devices.
  • [0080]
    In one embodiment, the protocol translation and interface circuit 1210 may delay row-activation commands and/or column-access commands. The protocol translation and interface circuit 1210 may also transparently perform different kinds of address mapping schemes that depend on the expected arrival time of the column-access command. In one scheme, the column-access command may be sent by the memory controller at the normal time (i.e. late arrival, as compared to a scheme where the column-access command is early).
  • [0081]
    In a second scheme, the column-access command may be sent by the memory controller before the row-access command is required (e.g. early arrival) at the DRAM device interface. In DDR2 and DDR3 SDRAM memory systems, the early arriving column-access command may be referred to as the Posted-CAS command. Thus, part of a row may be activated as needed, therefore providing sub-row activation. In addition, lower power may also be provided.
  • [0082]
    It should be noted that the embodiments of the above-described schemes may not necessarily require additional pins or new commands to be sent by the memory controller to the protocol translation and interface circuit. In this way, a high bandwidth DRAM device may be provided.
  • [0083]
    As shown, the protocol translation and interface circuit 1210 may include eight DRAM devices to be connected thereto via eight independent data paths to. For example, the protocol translation and interface circuit 1210 may emulate a single 8 Gb DRAM device with eight 1 Gb DRAM devices. The memory controller may therefore expect to see eight banks, 32768 rows per bank, 4096 columns per for, and four bits per column. When the memory controller issues a row-activation command, it may expect that 4096 columns are ready for a column-access command that follows, whereas the 1 Gb devices may only have 2048 columns per row. Similarly, the same issue of differing row sizes may arise when 2 Gb devices are used to emulate a 16 Gb DRAM device or 4 Gb devices are used to emulate a 32 Gb device, etc.
  • [0084]
    To accommodate for the difference between the row sizes of the 1 Gb and 8 Gb DRAM devices, 2 Gb and 16 Gb DRAM devices, 4 Gb and 32 Gb DRAM devices, etc., the protocol translation and interface circuit 1210 may calculate and issue the appropriate number of row-activation commands to prepare for a subsequent column-access command that may access any portion of the larger row. The protocol translation and interface circuit 1210 may be configured with different behaviors, depending on the specific condition.
  • [0085]
    In one exemplary embodiment, the memory controller may not issue early column-access commands. The protocol translation and interface circuit 1210 may activate multiple, smaller rows to match the size of the larger row in the higher capacity logical DRAM device.
  • [0086]
    Furthermore, the protocol translation and interface circuit 1210 may present a single data path to the memory controller, as shown. thus, the protocol translation and interface circuit 1210 may present itself as a single DRAM device with a single electrical interface to the memory controller. For example, if eight 1 Gb DRAM devices are used by the protocol translation and interface circuit 1210 to emulate a single, standard 8 Gb DRAM device, the memory controller may expect that the logical 8 Gb DRAM device will take over 300 ns to perform a refresh command. The protocol translation and interface circuit 1210 may also intelligently schedule the refresh commands. Thus, for example, the protocol translation and interface circuit 1210 may separately schedule refresh commands to the 1 Gb DRAM devices, with each refresh command taking 100 ns.
  • [0087]
    To this end, where multiple physical DRAM devices are used by the protocol translation and interface circuit 1210 to emulate a single larger DRAM device, the memory controller may expect that the logical device may take a relatively long period to perform a refresh command. The protocol translation and interface circuit 1210 may separately schedule refresh commands to each of the physical DRAM devices. Thus, the refresh of the larger logical DRAM device may take a relatively smaller period of time as compared with a refresh of a physical DRAM device of the same size. DDR3 memory systems may potentially require calibration sequences to ensure that the high speed data I/O circuits are periodically calibrated against thermal-variances induced timing drifts. The staggered refresh commands may also optionally guarantee I/O quiet time required to separately calibrate each of the independent physical DRAM devices.
  • [0088]
    Thus, in one embodiment, a protocol translation and interface circuit 1210 may allow for the staggering of refresh times of logical DRAM devices. DDR3 devices may optionally require different levels of zero quotient (ZQ) calibration sequences, and the calibration sequences may require that other I/O in the system are not also switching at the same time. Thus, refresh commands in a higher capacity logical DRAM device may be emulated by staggering refresh commands to different lower capacity physical DRAM devices. The staggering of the refresh commands may optionally provide a guaranteed I/O quiet time that may be required to separately calibrate each of the independent physical DRAM devices.
  • [0089]
    FIG. 13 illustrates a timing diagram 1300 showing the effect when a memory controller issues a column-access command late, in accordance with another embodiment. As an option, the timing diagram 1300 may be associated with the architecture and environment of FIGS. 1-12. Of course, the timing diagram 1300 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0090]
    As shown, in a memory system where the memory controller issues the column-access command without enough latency to cover both the DRAM device row-access latency and column-access latency, the interface circuit may send multiple row-access commands to multiple DRAM devices to guarantee that the subsequent column access will hit an open bank. In one exemplary embodiment, the physical device may have a 1 kilobyte (kb) row size and the logical device may have a 2 kb row size. In this case, the interface circuit may activate two 1 kb rows in two different physical devices (since two rows may not be activated in the same device within a span of tRRD). In another exemplary embodiment, the physical device may have a 1 kb row size and the logical device may have a 4 kb row size. In this case, four 1 kb rows may be opened to prepare for the arrival of a column-access command that may be targeted to any part of the 4 kb row.
  • [0091]
    In one embodiment, the memory controller may issue column-access commands early. The interface circuit may do this in any desired manner, including for example, using the additive latency property of DDR2 and DDR3 devices. The interface circuit may also activate one specific row in one specific DRAM device. This may allow sub-row activation for the higher capacity logical DRAM device.
  • [0092]
    FIG. 14 illustrates a timing diagram 1400 showing the effect when a memory controller issues a column-access command early, in accordance with still yet another embodiment. As an option, the timing diagram 1400 may be associated with the architecture and environment of FIGS. 1-13. Of course, the timing diagram 1400 may be associated with any desired environment. Further, the aforementioned definitions may equally apply to the description below.
  • [0093]
    In the context of the present embodiment, a memory controller may issue a column-access command early, i.e. before the row-activation command is to be issued to a DRAM device. Accordingly, an interface circuit may take a portion of the column address, combine it with the row address and form a sub-row address. to this end, the interface circuit may activate the row that is targeted by the column-access command. Just by way of example, if the physical device has a 1 kb row size and the logical device has a 2 kb row size, the early column-access command may allow the interface circuit to activate a single 1 kb row. The interface circuit can thus implement sub-row activation for a logical device with a larger row size than the physical devices without necessarily the use of additional pins or special commands.
  • [0094]
    FIG. 15 illustrates a representative hardware environment 1500, in accordance with one embodiment. As an option, the hardware environment 1500 may be implemented in the context of FIGS. 1-14. For example, the hardware environment 1500 may constitute an exemplary system.
  • [0095]
    In one exemplary embodiment, the hardware environment 1500 may include a computer system. As shown, the hardware environment 1500 includes at least one central processor 1501 which is connected to a communication bus 1502. The hardware environment 1500 also includes main memory 1504. The main memory 1504 may include, for example random access memory (RAM) and/or any other desired type of memory. Further, in various embodiments, the main memory 1504 may include memory circuits, interface circuits, etc.
  • [0096]
    the hardware environment 1500 also includes a graphics processor 1506 and a display 1508. the hardware environment 1500 may also include a secondary storage 1510. The secondary storage 1510 includes, for example, a hard disk drive and/or a removable storage drive, representing a floppy disk drive, a magnetic tape drive, a compact disk drive, etc. The removable storage drive reads from and/or writes to a removable storage unit in a well known manner.
  • [0097]
    Computer programs, or computer control logic algorithms, may be stored in the main memory 1504 and/or the secondary storage 1510. Such computer programs, when executed, enable the computer system 1500 to perform various functions. Memory 1504, storage 1510 and/or any other storage are possible examples of computer-readable media.
  • [0098]
    While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. Thus, the breadth and scope of a preferred embodiment should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
Patentzitate
Zitiertes PatentEingetragen Veröffentlichungsdatum Antragsteller Titel
US4069452 *15. Sept. 197617. Jan. 1978Dana Laboratories, Inc.Apparatus for automatically detecting values of periodically time varying signals
US4899107 *30. Sept. 19886. Febr. 1990Micron Technology, Inc.Discrete die burn-in for nonpackaged die
US4912678 *22. Sept. 198827. März 1990Mitsubishi Denki Kabushiki KaishaDynamic random access memory device with staggered refresh
US5083266 *24. Dez. 198721. Jan. 1992Kabushiki Kaisha ToshibaMicrocomputer which enters sleep mode for a predetermined period of time on response to an activity of an input/output device
US5278796 *12. Apr. 199111. Jan. 1994Micron Technology, Inc.Temperature-dependent DRAM refresh circuit
US5282177 *8. Apr. 199225. Jan. 1994Micron Technology, Inc.Multiple register block write method and circuit for video DRAMs
US5384745 *14. Apr. 199324. Jan. 1995Mitsubishi Denki Kabushiki KaishaSynchronous semiconductor memory device
US5388265 *26. Apr. 19937. Febr. 1995Intel CorporationMethod and apparatus for placing an integrated circuit chip in a reduced power consumption state
US5483497 *19. Juli 19949. Jan. 1996Fujitsu LimitedSemiconductor memory having a plurality of banks usable in a plurality of bank configurations
US5502333 *30. März 199426. März 1996International Business Machines CorporationSemiconductor stack structures and fabrication/sparing methods utilizing programmable spare circuit
US5598376 *30. Juni 199528. Jan. 1997Micron Technology, Inc.Distributed write data drivers for burst access memories
US5604714 *30. Nov. 199518. Febr. 1997Micron Technology, Inc.DRAM having multiple column address strobe operation
US5606710 *20. Dez. 199425. Febr. 1997National Semiconductor CorporationMultiple chip package processor having feed through paths on one die
US5610864 *10. Febr. 199511. März 1997Micron Technology, Inc.Burst EDO memory device with maximized write cycle timing
US5706247 *21. Nov. 19966. Jan. 1998Micron Technology, Inc.Self-enabling pulse-trapping circuit
US5717654 *10. Febr. 199710. Febr. 1998Micron Technology, Inc.Burst EDO memory device with maximized write cycle timing
US5721859 *7. Nov. 199524. Febr. 1998Micron Technology, Inc.Counter control circuit in a burst memory
US5724288 *30. Aug. 19953. März 1998Micron Technology, Inc.Data communication for memory
US5729503 *24. Juli 199517. März 1998Micron Technology, Inc.Address transition detection on a synchronous design
US5729504 *14. Dez. 199517. März 1998Micron Technology, Inc.Continuous burst edo memory device
US5859792 *12. Juni 199712. Jan. 1999Micron Electronics, Inc.Circuit for on-board programming of PRD serial EEPROMs
US5860106 *13. Juli 199512. Jan. 1999Intel CorporationMethod and apparatus for dynamically adjusting power/performance characteristics of a memory subsystem
US5870347 *11. März 19979. Febr. 1999Micron Technology, Inc.Multi-bank memory input/output line selection
US5870350 *21. Mai 19979. Febr. 1999International Business Machines CorporationHigh performance, high bandwidth memory bus architecture utilizing SDRAMs
US5872907 *7. Juni 199516. Febr. 1999International Business Machines CorporationFault tolerant design for identification of AC defects including variance of cycle time to maintain system operation
US5875142 *17. Juni 199723. Febr. 1999Micron Technology, Inc.Integrated circuit with temperature detector
US5884088 *10. Juli 199716. März 1999Intel CorporationSystem, apparatus and method for managing power in a computer system
US6014339 *29. Aug. 199711. Jan. 2000Fujitsu LimitedSynchronous DRAM whose power consumption is minimized
US6016282 *28. Mai 199818. Jan. 2000Micron Technology, Inc.Clock vernier adjustment
US6032214 *19. Febr. 199929. Febr. 2000Rambus Inc.Method of operating a synchronous memory device having a variable data output length
US6032215 *5. März 199929. Febr. 2000Rambus Inc.Synchronous memory device utilizing two external clocks
US6034916 *14. Okt. 19987. März 2000Samsung Electronics Co., Ltd.Data masking circuits and methods for integrated circuit memory devices, including data strobe signal synchronization
US6034918 *19. Febr. 19997. März 2000Rambus Inc.Method of operating a memory having a variable data output length and a programmable register
US6035365 *27. Nov. 19987. März 2000Rambus Inc.Dual clocked synchronous memory device having a delay time register and method of operating same
US6038195 *20. Nov. 199814. März 2000Rambus Inc.Synchronous memory device having a delay time register and method of operating same
US6038673 *3. Nov. 199814. März 2000Intel CorporationComputer system with power management scheme for DRAM devices
US6044032 *3. Dez. 199828. März 2000Micron Technology, Inc.Addressing scheme for a double data rate SDRAM
US6182184 *22. Febr. 200030. Jan. 2001Rambus Inc.Method of operating a memory device having a variable data input length
US6199151 *5. Juni 19986. März 2001Intel CorporationApparatus and method for storing a device row indicator for use in a subsequent page-miss memory cycle
US6208168 *26. Juni 199827. März 2001Samsung Electronics Co., Ltd.Output driver circuits having programmable pull-up and pull-down capability for driving variable loads
US6336174 *9. Aug. 19991. Jan. 2002Maxtor CorporationHardware assisted memory backup system and method
US6338108 *14. Apr. 19988. Jan. 2002Nec CorporationCoprocessor-integrated packet-type memory LSI, packet-type memory/coprocessor bus, and control method thereof
US6338113 *19. Nov. 19988. Jan. 2002Mitsubishi Denki Kabushiki KaishaMemory module system having multiple memory modules
US6353561 *17. Sept. 19995. März 2002Fujitsu LimitedSemiconductor integrated circuit and method for controlling the same
US6356105 *28. Juni 200012. März 2002Intel CorporationImpedance control system for a center tapped termination bus
US6356500 *23. Aug. 200012. März 2002Micron Technology, Inc.Reduced power DRAM device and method
US6362656 *3. Jan. 200126. März 2002Samsung Electronics Co., Ltd.Integrated circuit memory devices having programmable output driver circuits therein
US6363031 *22. Dez. 200026. März 2002Cypress Semiconductor Corp.Circuit, architecture and method for reducing power consumption in a synchronous integrated circuit
US6510097 *2. Nov. 200121. Jan. 2003Oki Electric Industry Co., Ltd.DRAM interface circuit providing continuous access across row boundaries
US6510503 *30. Okt. 199821. Jan. 2003Mosaid Technologies IncorporatedHigh bandwidth memory interface
US6526471 *18. Sept. 199825. Febr. 2003Digeo, Inc.Method and apparatus for a high-speed memory subsystem
US6526473 *16. Nov. 199925. Febr. 2003Samsung Electronics Co., Ltd.Memory module system for controlling data input and output by connecting selected memory modules to a data line
US6526484 *12. Nov. 199925. Febr. 2003Infineon Technologies AgMethods and apparatus for reordering of the memory requests to achieve higher average utilization of the command and data bus
US6674154 *27. Febr. 20026. Jan. 2004Matsushita Electric Industrial Co., Ltd.Lead frame with multiple rows of external terminals
US6684292 *28. Sept. 200127. Jan. 2004Hewlett-Packard Development Company, L.P.Memory module resync
US6697295 *7. März 200124. Febr. 2004Rambus Inc.Memory device having a programmable register
US6839290 *15. Sept. 20034. Jan. 2005Intel CorporationMethod, apparatus, and system for high speed data transfer using source synchronous data strobe
US6845055 *15. Juni 200418. Jan. 2005Fujitsu LimitedSemiconductor memory capable of transitioning from a power-down state in a synchronous mode to a standby state in an asynchronous mode without setting by a control register
US6847582 *11. März 200325. Jan. 2005Micron Technology, Inc.Low skew clock input buffer and method
US6850449 *10. Okt. 20031. Febr. 2005Nec Electronics Corp.Semiconductor memory device having mode storing one bit data in two memory cells and method of controlling same
US6986118 *26. Sept. 200310. Jan. 2006Infineon Technologies AgMethod for controlling semiconductor chips and control apparatus
US6992950 *21. Aug. 200331. Jan. 2006Mosaid Technologies IncorporatedDelay locked loop implementation in a synchronous dynamic random access memory
US7000062 *10. Febr. 200514. Febr. 2006Rambus Inc.System and method featuring a controller device and a memory module that includes an integrated circuit buffer device and a plurality of integrated circuit memory devices
US7003618 *11. März 200521. Febr. 2006Rambus Inc.System featuring memory modules that include an integrated circuit buffer devices
US7003639 *21. Juni 200421. Febr. 2006Rambus Inc.Memory controller with power management logic
US7007095 *7. Dez. 200128. Febr. 2006Redback Networks Inc.Method and apparatus for unscheduled flow control in packet form
US7007175 *4. Dez. 200128. Febr. 2006Via Technologies, Inc.Motherboard with reduced power consumption
US7317250 *30. Sept. 20048. Jan. 2008Kingston Technology CorporationHigh density memory card assembly
US7474576 *21. März 20086. Jan. 2009Kingston Technology Corp.Repairing Advanced-Memory Buffer (AMB) with redundant memory buffer for repairing DRAM on a fully-buffered memory-module
US7480774 *1. Apr. 200320. Jan. 2009International Business Machines CorporationMethod for performing a command cancel function in a DRAM
US20020004897 *27. Dez. 200010. Jan. 2002Min-Cheng KaoData processing apparatus for executing multiple instruction sets
US20020015340 *25. Juli 20017. Febr. 2002Victor BatinovichMethod and apparatus for memory module circuit interconnection
US20020019961 *17. Aug. 200114. Febr. 2002Blodgett Greg A.Device and method for repairing a semiconductor memory
US20020038405 *30. Sept. 199828. März 2002Michael W. LeddigeMethod and apparatus for implementing multiple memory buses on a memory module
US20030002262 *2. Juli 20022. Jan. 2003Martin BenisekElectronic printed circuit board having a plurality of identically designed, housing-encapsulated semiconductor memories
US20030021175 *26. Juli 200230. Jan. 2003Jong Tae KwakLow power type Rambus DRAM
US20030026159 *31. Juli 20026. Febr. 2003Infineon Technologies North America Corp.Fuse programmable I/O organization
US20030041295 *24. Aug. 200127. Febr. 2003Chien-Tzu HouMethod of defects recovery and status display of dram
US20030061458 *25. Sept. 200127. März 2003Wilcox Jeffrey R.Memory control with lookahead power management
US20030061459 *27. Sept. 200127. März 2003Nagi AbouleneinMethod and apparatus for memory access scheduling to reduce memory access latency
US20040016994 *25. Juli 200329. Jan. 2004Siliconware Precision Industries Co., Ltd.Semiconductor package and fabricating method thereof
US20040034732 *4. Apr. 200319. Febr. 2004Network Appliance, Inc.Apparatus and method for placing memory into self-refresh state
US20040034755 *16. Aug. 200219. Febr. 2004Laberge Paul A.Latency reduction using negative clock edge and read flags
US20050018495 *29. Jan. 200427. Jan. 2005Netlist, Inc.Arrangement of integrated circuits in a memory module
US20050021874 *30. Jan. 200427. Jan. 2005Georgiou Christos J.Single chip protocol converter
US20050028038 *30. Juli 20033. Febr. 2005Pomaranski Ken GaryPersistent volatile memory fault tracking
US20050044303 *28. Sept. 200424. Febr. 2005Perego Richard E.Memory system including an integrated circuit buffer device
US20050044305 *8. Juli 200424. Febr. 2005Infineon Technologies AgSemiconductor memory module
US20060010339 *24. Juni 200412. Jan. 2006Klein Dean AMemory system and method having selective ECC during low power refresh
US20060039205 *23. Aug. 200423. Febr. 2006Cornelius William PReducing the number of power and ground pins required to drive address signals to memory modules
US20060041711 *27. Nov. 200323. Febr. 2006Renesas Technology CorporationMemory module, memory system, and information device
US20060041730 *19. Aug. 200423. Febr. 2006Larson Douglas AMemory command delay balancing in a daisy-chained memory topology
US20070005998 *30. Juni 20054. Jan. 2007Sandeep JainVarious apparatuses and methods for reduced power states in system memory
US20080002447 *29. Juni 20063. Jan. 2008Smart Modular Technologies, Inc.Memory supermodule utilizing point to point serial data links
US20080010435 *14. Juni 200710. Jan. 2008Michael John Sebastian SmithMemory systems and memory modules
US20080028135 *31. Juli 200631. Jan. 2008Metaram, Inc.Multiple-component memory interface system and method
US20080028137 *25. Juli 200731. Jan. 2008Schakel Keith RMethod and Apparatus For Refresh Management of Memory Modules
US20090024789 *30. Okt. 200722. Jan. 2009Suresh Natarajan RajanMemory circuit system and method
US20090024790 *30. Okt. 200722. Jan. 2009Suresh Natarajan RajanMemory circuit system and method
Referenziert von
Zitiert von PatentEingetragen Veröffentlichungsdatum Antragsteller Titel
US77177521. Juli 200818. Mai 2010International Business Machines Corporation276-pin buffered memory module with enhanced memory system interconnect and features
US772458931. Juli 200625. Mai 2010Google Inc.System and method for delaying a signal communicated from a system to at least one of a plurality of memory circuits
US7958409 *15. Sept. 20087. Juni 2011Asustek Computer Inc.Method for recording memory parameter and method for optimizing memory
US799074627. Juli 20092. Aug. 2011Google Inc.Method and circuit for configuring memory core integrated circuit dies with memory interface integrated circuit dies
US801958930. Okt. 200713. Sept. 2011Google Inc.Memory apparatus operable to perform a power-saving operation
US804188112. Juni 200718. Okt. 2011Google Inc.Memory device with emulated characteristics
US805583315. Dez. 20068. Nov. 2011Google Inc.System and method for increasing capacity, performance, and flexibility of flash storage
US806077414. Juni 200715. Nov. 2011Google Inc.Memory systems and memory modules
US807753531. Juli 200613. Dez. 2011Google Inc.Memory refresh apparatus and method
US808087414. Sept. 200720. Dez. 2011Google Inc.Providing additional space between an integrated circuit and a circuit board for positioning a component therebetween
US80814742. Sept. 200820. Dez. 2011Google Inc.Embossed heat spreader
US80897955. Febr. 20073. Jan. 2012Google Inc.Memory module with memory stack and interface with enhanced capabilities
US809089712. Juni 20073. Jan. 2012Google Inc.System and method for simulating an aspect of a memory circuit
US811156616. Nov. 20077. Febr. 2012Google, Inc.Optimal channel design for memory devices for providing a high-speed memory interface
US811226630. Okt. 20077. Febr. 2012Google Inc.Apparatus for simulating an aspect of a memory circuit
US812220716. Juni 201021. Febr. 2012Google Inc.Apparatus and method for power management of memory circuits by a system or component thereof
US813056013. Nov. 20076. März 2012Google Inc.Multi-rank partial width memory modules
US815493528. Apr. 201010. Apr. 2012Google Inc.Delaying a signal communicated from a system to at least one of a plurality of memory circuits
US81692339. Juni 20101. Mai 2012Google Inc.Programming of DIMM termination resistance values
US818104819. Juli 201015. Mai 2012Google Inc.Performing power management operations
US820947930. Okt. 200726. Juni 2012Google Inc.Memory circuit system and method
US82132056. Okt. 20093. Juli 2012Google Inc.Memory system including multiple memory stacks
US824497130. Okt. 200714. Aug. 2012Google Inc.Memory circuit system and method
US826117413. Jan. 20094. Sept. 2012International Business Machines CorporationProtecting and migrating memory lines
US828071426. Okt. 20062. Okt. 2012Google Inc.Memory circuit simulation system and method with refresh capabilities
US832710413. Nov. 20074. Dez. 2012Google Inc.Adjusting the timing of signals associated with a memory system
US833589423. Juli 200918. Dez. 2012Google Inc.Configurable memory system with interface circuit
US834095326. Okt. 200625. Dez. 2012Google, Inc.Memory circuit simulation with power saving capabilities
US835918731. Juli 200622. Jan. 2013Google Inc.Simulating a different number of memory circuit devices
US837056618. Okt. 20115. Febr. 2013Google Inc.System and method for increasing capacity, performance, and flexibility of flash storage
US838672223. Juni 200826. Febr. 2013Google Inc.Stacked DIMM memory interface
US838683324. Okt. 201126. Febr. 2013Google Inc.Memory systems and memory modules
US839701327. März 200812. März 2013Google Inc.Hybrid memory module
US84074124. Jan. 201226. März 2013Google Inc.Power management of memory circuits by virtual memory simulation
US843832814. Febr. 20097. Mai 2013Google Inc.Emulation of abstracted DIMMs using abstracted DRAMs
US84467812. März 201221. Mai 2013Google Inc.Multi-rank partial width memory modules
US856651630. Okt. 200722. Okt. 2013Google Inc.Refresh management of memory modules
US856655630. Dez. 201122. Okt. 2013Google Inc.Memory module with memory stack and interface with enhanced capabilities
US857232012. Okt. 200929. Okt. 2013Cypress Semiconductor CorporationMemory devices and systems including cache devices for memory modules
US858233928. Juni 201212. Nov. 2013Google Inc.System including memory stacks
US858801720. Sept. 201119. Nov. 2013Samsung Electronics Co., Ltd.Memory circuits, systems, and modules for performing DRAM refresh operations and methods of operating the same
US859541913. Juli 201126. Nov. 2013Google Inc.Memory apparatus operable to perform a power-saving operation
US860120413. Juli 20113. Dez. 2013Google Inc.Simulating a refresh operation latency
US861283931. Juli 201217. Dez. 2013International Business Machines CorporationProtecting and migrating memory lines
US861567914. Sept. 201224. Dez. 2013Google Inc.Memory modules with reliability and serviceability functions
US86194521. Sept. 200631. Dez. 2013Google Inc.Methods and apparatus of stacking DRAMs
US863119317. Mai 201214. Jan. 2014Google Inc.Emulation of abstracted DIMMS using abstracted DRAMS
US863122013. Sept. 201214. Jan. 2014Google Inc.Adjusting the timing of signals associated with a memory system
US866731214. Mai 20124. März 2014Google Inc.Performing power management operations
US867124413. Juli 201111. März 2014Google Inc.Simulating a memory standard
US867542929. Aug. 201218. März 2014Google Inc.Optimal channel design for memory devices for providing a high-speed memory interface
US870524014. Sept. 201222. Apr. 2014Google Inc.Embossed heat spreader
US872598318. Juni 201013. Mai 2014Cypress Semiconductor CorporationMemory devices and systems including multi-speed access of memory modules
US873067021. Okt. 201120. Mai 2014Google Inc.Embossed heat spreader
US874532114. Sept. 20123. Juni 2014Google Inc.Simulating a memory standard
US875173214. Sept. 201210. Juni 2014Google Inc.System and method for increasing capacity, performance, and flexibility of flash storage
US876093620. Mai 201324. Juni 2014Google Inc.Multi-rank partial width memory modules
US876267514. Sept. 201224. Juni 2014Google Inc.Memory system for synchronous data transmission
US87739379. Dez. 20118. Juli 2014Google Inc.Memory refresh apparatus and method
US87968301. Sept. 20065. Aug. 2014Google Inc.Stackable low-profile lead frame package
US879777914. Sept. 20125. Aug. 2014Google Inc.Memory module with memory stack and interface with enhanced capabilites
US881106514. Sept. 201219. Aug. 2014Google Inc.Performing error detection on DRAMs
US881935614. Sept. 201226. Aug. 2014Google Inc.Configurable multirank memory system with interface circuit
US88688296. Febr. 201221. Okt. 2014Google Inc.Memory circuit system and method
US89306476. Apr. 20126. Jan. 2015P4tents1, LLCMultiple class memory systems
US894951922. Juli 20093. Febr. 2015Google Inc.Simulating a memory circuit
US897267314. Sept. 20123. März 2015Google Inc.Power management of memory circuits by virtual memory simulation
US897780615. Sept. 201210. März 2015Google Inc.Hybrid memory module
US904797626. Okt. 20062. Juni 2015Google Inc.Combined signal delay and power saving for use with a plurality of memory circuits
US91585465. Jan. 201513. Okt. 2015P4tents1, LLCComputer program product for fetching from a first physical memory between an execution of a plurality of threads associated with a second physical memory
US91646795. Jan. 201520. Okt. 2015Patents1, LlcSystem, method and computer program product for multi-thread operation involving first memory of a first memory class and second memory of a second memory class
US91707445. Jan. 201527. Okt. 2015P4tents1, LLCComputer program product for controlling a flash/DRAM/embedded DRAM-equipped system
US917158526. Nov. 201327. Okt. 2015Google Inc.Configurable memory circuit system and method
US91766715. Jan. 20153. Nov. 2015P4tents1, LLCFetching data between thread execution in a flash/DRAM/embedded DRAM-equipped system
US91829145. Jan. 201510. Nov. 2015P4tents1, LLCSystem, method and computer program product for multi-thread operation involving first memory of a first memory class and second memory of a second memory class
US91894425. Jan. 201517. Nov. 2015P4tents1, LLCFetching data between thread execution in a flash/DRAM/embedded DRAM-equipped system
US91953955. Jan. 201524. Nov. 2015P4tents1, LLCFlash/DRAM/embedded DRAM-equipped system and method
US92235075. Jan. 201529. Dez. 2015P4tents1, LLCSystem, method and computer program product for fetching data between an execution of a plurality of threads
US939078329. Okt. 201312. Juli 2016Cypress Semiconductor CorporationMemory devices and systems including cache devices for memory modules
US94177543. Aug. 201216. Aug. 2016P4tents1, LLCUser interface system, method, and computer program product
US950773926. Okt. 201529. Nov. 2016Google Inc.Configurable memory circuit system and method
US954235330. Okt. 200710. Jan. 2017Google Inc.System and method for reducing command scheduling constraints of memory circuits
US96329298. Febr. 200725. Apr. 2017Google Inc.Translating an address associated with a command communicated between a system and memory circuits
US971649718. März 201525. Juli 2017SK Hynix Inc.Calibration circuit and calibration apparatus including the same
US972745814. Sept. 20128. Aug. 2017Google Inc.Translating an address associated with a command communicated between a system and memory circuits
US20080133825 *30. Okt. 20075. Juni 2008Suresh Natarajan RajanSystem and method for simulating an aspect of a memory circuit
US20090077436 *15. Sept. 200819. März 2009Asustek Computer Inc.Method for recording memory parameter and method for optimizing memory
US20090290442 *27. Juli 200926. Nov. 2009Rajan Suresh NMethod and circuit for configuring memory core integrated circuit dies with memory interface integrated circuit dies
US20100003837 *1. Juli 20087. Jan. 2010International Business Machines Corporation276-pin buffered memory module with enhanced memory system interconnect and features
US20100005206 *1. Juli 20087. Jan. 2010International Business Machines CorporationAutomatic read data flow control in a cascade interconnect memory system
US20100005212 *1. Juli 20087. Jan. 2010International Business Machines CorporationProviding a variable frame format protocol in a cascade interconnected memory system
US20100005214 *1. Juli 20087. Jan. 2010International Business Machines CorporationEnhancing bus efficiency in a memory system
US20100005218 *1. Juli 20087. Jan. 2010International Business Machines CorporationEnhanced cascade interconnected memory system
US20100005219 *1. Juli 20087. Jan. 2010International Business Machines Corporation276-pin buffered memory module with enhanced memory system interconnect and features
US20100005220 *1. Juli 20087. Jan. 2010International Business Machines Corporation276-pin buffered memory module with enhanced memory system interconnect and features
US20100180179 *13. Jan. 200915. Juli 2010International Business Machines CorporationProtecting and migrating memory lines
US20100257304 *16. Juni 20107. Okt. 2010Google Inc.Apparatus and method for power management of memory circuits by a system or component thereof
US20100293325 *18. Juni 201018. Nov. 2010Cypress Semiconductor CorporationMemory devices and systems including multi-speed access of memory modules
Klassifizierungen
US-Klassifikation711/105, 711/E12.001, 711/167
Internationale KlassifikationG06F12/00
UnternehmensklassifikationY02B60/1235, G11C11/4093, G11C11/40618, G11C11/406, G06F13/4243, G06F13/28, Y02B60/1228
Europäische KlassifikationG11C11/406M, G11C11/406, G11C11/4093, G06F13/28, G06F13/42C3S
Juristische Ereignisse
DatumCodeEreignisBeschreibung
18. Nov. 2009ASAssignment
Owner name: GOOGLE INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:METARAM, INC.;REEL/FRAME:023525/0835
Effective date: 20090911
Owner name: GOOGLE INC.,CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:METARAM, INC.;REEL/FRAME:023525/0835
Effective date: 20090911
20. Juli 2010ASAssignment
Owner name: METARAM, INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:RAJAN, SURESH NATARAJAN;SCHAKEL, KEITH R.;SMITH, MICHAELJOHN SEBASTAIN;AND OTHERS;SIGNING DATES FROM 20070404 TO 20070413;REEL/FRAME:024716/0804