A data processing system includes a memory channel and a data processor coupled to the memory channel. The data processor is adapted to access at least one rank and has refresh logic. In response to an activation of the refresh logic, the data processor generates refresh cycles to a bank of the memory channel. The data processor selects one of a first state corresponding to a first auto-refresh command that causes the data processor to auto-refresh the bank, and a second state corresponding to a second auto-refresh command that causes the data processor to auto-refresh a selected subset of the bank. The data processor initiates a switch between the first state and the second state in response to the refresh logic detecting a first condition related to the bank, and between the second state and the first state in response to the refresh logic circuit detecting a second condition.
|
21. A method controlling accesses to a memory, comprising:
receiving memory access requests;
decoding the memory access requests to provide decoded memory access requests;
storing the decoded memory access requests in a command queue;
storing auto-refresh commands in said command queue;
arbitrating among said decoded memory access requests and said auto-refresh commands in said command queue to provide selected ones of said decoded memory access requests and said auto-refresh commands to the memory; and
generating said auto-refresh commands in an on-the-fly refresh mode with a granularity that is automatically selected in response to conditions associated with a memory bank to be refreshed.
1. A memory controller having an input for receiving memory access requests, and an output for providing memory accesses to a memory system, the memory controller comprising:
a command queue for receiving the memory access requests and having a plurality of entries and an output for providing selected memory accesses;
an arbiter coupled to said command queue for selecting entries from said command queue for dispatch to the memory system; and
a refresh logic circuit coupled to said arbiter, wherein in an on-the-fly refresh mode, said refresh logic circuit generates auto-refresh commands to the memory system with a granularity that it automatically selects in response to conditions associated with a memory bank to be refreshed and issues a number of auto-refresh commands during a refresh interval that is inversely proportional to said granularity.
11. A memory controller comprising:
an interface having an input for receiving memory access requests, and an output;
a decoder coupled to said output of said interface for decoding said memory access requests and providing corresponding memory accesses in response;
a command queue having a first input coupled to said output of said decoder, a second input, and an output, and having a plurality of entries;
an arbiter coupled to said command queue for providing auto-refresh commands to said second input of said command queue selecting entries from said command queue for dispatch to a memory system;
a second queue having an input coupled to said output of said command queue, and an output for coupling to a memory channel; and
a refresh logic circuit coupled to said arbiter, wherein in an on-the-fly refresh mode, said refresh logic circuit generates auto-refresh commands to the memory system with a granularity that it automatically selects in response to conditions associated with a memory bank to be refreshed and issues a number of auto-refresh commands during a refresh interval that is inversely proportional to said granularity, and provides said auto-refresh commands to said arbiter.
2. The memory controller of
3. The memory controller of
4. The memory controller of
5. The memory controller of
6. The memory controller of
7. The memory controller of
8. The memory controller of
9. The memory controller of
10. The memory controller of
12. The memory controller of
13. The memory controller of
14. The memory controller of
15. The memory controller of
16. The memory controller of
17. The memory controller of
18. The memory controller of
19. The memory controller of
20. The memory controller of
22. The method of
generating a number of auto-refresh commands during a refresh interval that is inversely proportional to said granularity.
23. The method of
when in a first state, providing a first auto-refresh command (REF1) during said refresh interval that causes a memory to auto-refresh all of said memory bank; and
when in a second state, providing two second auto-refresh commands (REF2) during said refresh interval each of which causes said memory to auto-refresh one-half of said memory bank.
24. The method of
when in a third state, providing four refresh four (REF4) commands during said refresh interval each of which causes said memory to auto-refresh one-fourth of said memory bank.
25. The method of
transitioning between said first state and said second state in response to a number of pending refreshes to said memory bank in said command queue.
26. The method of
transitioning between said first state and said second state in response to said number of pending refreshes to said bank in said command queue being above a predetermined threshold.
27. The method of
transitioning between said first state and said second state when said command queue stores no access request to said memory bank.
28. The method of
transitioning between said second state and said first state only after issuing a number of auto-refresh commands corresponding to a portion of said memory bank that is being refreshed at one time in said second state.
|
This application is a continuation of U.S. patent application Ser. No. 15/164,721, filed May 25, 2016, and entitled “Fine Granularity Refresh,” which is incorporated by reference herein in its entirety.
The present disclosure relates generally to data processing systems, and more particularly to refreshing memory systems in data processing systems.
A variety of techniques have been developed to increase the overall processing speed of computer systems. Vast improvements in integrated circuit processing technologies have contributed to the ability to increase computer processing speeds and memory capacity, thereby contributing to the overall improved performance of computer systems. The ability to produce integrated circuits with sub-micron features enables the amount of electrical components, such as capacitors, per integrated circuit to also increase.
Dynamic random access memory (DRAM) chips, comprised of large arrays of capacitors with sub-micron features, are utilized for main memory in computer systems. DRAM is typically inexpensive and high density, thereby enabling large amounts of DRAM to be integrated per device. Due to the inherit nature of capacitors, DRAM must continuously be refreshed or the data stored within the capacitor will be lost. Each capacitor slowly leaks charge, and if the DRAM is not refreshed, eventually the capacitors will leak enough charge and encounter irreversible data corruption.
Most DRAM chips sold today are compatible with various double data rate (DDR) DRAM standards promulgated by the Joint Electron Devices Engineering Council (JEDEC). The standards provided by JEDEC provide a refresh cycle time that prevents the access of data for a period of time. Increasing DDR DRAM device density within a computer system increases the amount of time required for refresh, and thereby increases computer processing latency.
In order to address these issues, JEDEC adopted a feature in the DDR version four (DDR4) standard known as 1X , 2X , and 4X refresh mode. In these modes, a DDR4 memory can refresh a selected bank, one half of the selected bank, or one fourth of the selected bank, respectively, in response to a single refresh (REF) command. A mode register, mode register 3 (MR3), is used to select between these modes. Moreover, MR3 can also be programmed to support “on-the-fly” modes in which the choice of 1X or 2X , or the choice of 1X or 4X , can be performed dynamically and indicated by an unused address bit.
In the following description, the use of the same reference numerals in different drawings indicates similar or identical items. Unless otherwise noted, the word “coupled” and its associated verb forms include both direct connection and indirect electrical connection by means known in the art, and unless otherwise noted any description of direct connection implies alternate embodiments using suitable forms of indirect electrical connection as well.
As will be described below in one form, a data processing system includes a memory channel having at least one rank, and a data processor coupled to the memory channel having refresh logic. In response to an activation of the refresh logic, the data processor generates refresh cycles to a bank of the memory channel. The data processor selects one of a first state and a second state, wherein the first state corresponds to a first auto-refresh command that causes the data processor to auto-refresh the bank, and the second state corresponds to a second auto-refresh command that causes the data processor to auto-refresh a selected subset of the bank. The data processor initiates a switch between the first state and the second state in response to the refresh logic detecting a first condition related to the bank, and initiates a switch between the second state and the first state in response to the refresh logic circuit detecting a second condition.
In another form, a data processor includes a memory accessing agent and a memory controller coupled to the memory accessing agent and adapted to couple to a memory system. The memory controller includes a refresh logic circuit for generating refresh cycles to a memory of the memory system. The memory controller has an on-the-fly mode that includes a first state and a second state. The first state corresponds to a first auto-refresh command (e.g. REF1) that causes the memory to auto-refresh a bank. The second state corresponds to a second auto-refresh command (e.g. REF2 or REF4) that causes the memory to auto-refresh a selected subset of the bank. The memory controller switches between the first state and the second state in response to the refresh logic circuit detecting a first condition related to the bank. The memory controller switches between the second state and the first state in response to the refresh logic circuit detecting a second condition.
In yet another form, there is described a method for managing refresh of a memory in a memory system via a memory controller. A first auto-refresh command is generated when the memory controller is in a first state, wherein the first auto-refresh command causes the memory controller to auto-refresh a bank. A second auto-refresh command is generated when the memory controller is in a second state, wherein the second auto-refresh command causes the memory to auto-refresh a selected subset of the bank. In response to the memory controller detecting a first condition a switch between the first state and the second state is made. In response to the memory controller detecting a second condition, a switch between the second state and the first state is made.
Memory system 120 includes a memory channel 130 and a memory channel 140. Memory channel 130 includes a set of dual inline memory modules (DIMMs) connected to a DDRx bus 132, including representative DIMMs 134, 136, and 138 that in this example correspond to separate ranks. Likewise memory channel 140 includes a set of DIMMs connected to a DDRx bus 142, including representative DIMMs 144, 146, and 148.
PCIe system 150 includes a PCIe switch 152 connected to the PCIe root complex in data processor 110, a PCIe device 154, a PCIe device 156, and a PCIe device 158. PCIe device 156 in turn is connected to a system basic input/output system (BIOS) memory 157. System BIOS memory 157 can be any of a variety of non-volatile memory types, such as read-only memory (ROM), flash electrically erasable programmable ROM (EEPROM), and the like.
USB system 160 includes a USB hub 162 connected to a USB master in data processor 110, and representative USB devices 164, 166, and 168 each connected to USB hub 162. USB devices 164, 166, and 168 could be devices such as a keyboard, a mouse, a flash EEPROM port, and the like.
Disk drive 170 is connected to data processor 110 over a SATA bus and provides mass storage for the operating system, application programs, application files, and the like.
Data processing system 100 is suitable for use in modern computing applications by providing a memory channel 130 and a memory channel 140. Each of memory channels 130 and 140 can connect to state-of-the-art DDR memories such as DDR version four (DDR4), low power DDR4 (LPDDR4), graphics DDR version five (gDDR5), and high bandwidth memory (HBM), and can be adapted for future memory technologies. These memories provide high bus bandwidth and high speed operation. At the same time, they also provide low power modes to save power for battery-powered applications such as laptop computers, and also provide built-in thermal monitoring.
CPU core complex 210 includes a CPU core 212 and a CPU core 214. In this example, CPU core complex 210 includes two CPU cores, but in other embodiments CPU core complex can include an arbitrary number of CPU cores. Each of CPU cores 212 and 214 is bidirectionally connected to a system management network (SMN), which forms a control fabric, and to data fabric 250, and is capable of providing memory access requests to data fabric 250. Each of CPU cores 212 and 214 may be unitary cores, or may further be a core complex with two or more unitary cores sharing certain resources such as caches.
Graphics core 220 is a high performance graphics processing unit (GPU) capable of performing graphics operations such as vertex processing, fragment processing, shading, texture blending, and the like in a highly integrated and parallel fashion. Graphics core 220 is bidirectionally connected to the SMN and to data fabric 250, and is capable of providing memory access requests to data fabric 250. In this regard, APU 200 may either support a unified memory architecture in which CPU core complex 210 and graphics core 220 share the same memory space, or a memory architecture in which CPU core complex 210 and graphics core 220 share a portion of the memory space, while graphics core 220 also uses a private graphics memory not accessible by CPU core complex 210.
Display engines 230 render and rasterize objects generated by graphics core 220 for display on a monitor. Graphics core 220 and display engines 230 are bidirectionally connected to a common memory management hub 240 for uniform translation into appropriate addresses in memory system 120, and memory management hub 240 is bidirectionally connected to data fabric 250 for generating such memory accesses and receiving read data returned from the memory system.
Data fabric 250 includes a crossbar switch for routing memory access requests and memory responses between any memory accessing agent and memory controllers 290. It also includes a system memory map, defined by BIOS, for determining destinations of memory accesses based on the system configuration, as well as buffers for each virtual connection.
Peripheral controllers 260 include a USB controller 262 and a SATA interface controller 264, each of which is bidirectionally connected to a system hub 266 and to the SMN bus. These two controllers are merely exemplary of peripheral controllers that may be used in APU 200.
Peripheral bus controllers 270 include a system controller or “Southbridge” (SB) 272 and a PCIe controller 274, each of which is bidirectionally connected to an input/output (I/O) hub 276 and to the SMN bus. I/O hub 276 is also bidirectionally connected to system hub 266 and to data fabric 250. Thus for example a CPU core can program registers in USB controller 262, SATA interface controller 264, SB 272, or PCIe controller 274 through accesses that data fabric 250 routes through I/O hub 276.
SMU 280 is a local controller that controls the operation of the resources on APU 200 and synchronizes communication among them. SMU 280 manages power-up sequencing of the various processors on APU 200 and controls multiple off-chip devices via reset, enable and other signals. SMU 280 includes one or more clock sources not shown in
APU 200 also implements various system monitoring and power saving functions. In particular one system monitoring function is thermal monitoring. For example, if APU 200 becomes hot, then SMU 280 can reduce the frequency and voltage of CPU cores 212 and 214 and/or graphics core 220. If APU 200 becomes too hot, then it can be shut down entirely. Thermal events can also be received from external sensors by SMU 280 via the SMN bus, and SMU 280 can reduce the clock frequency and/or power supply voltage in response.
Interface 512 has a first bidirectional connection to data fabric 250 over an external bus, and has an output. In memory controller 500, this external bus is compatible with the advanced extensible interface version four specified by ARM Holdings, PLC of Cambridge, England, known as “AXI4”, but can be other types of interfaces in other embodiments. Interface 512 translates memory access requests from a first clock domain known as the FCLK (or MEMCLK) domain to a second clock domain internal to memory controller 500 known as the UCLK domain. Similarly, queue 514 provides memory accesses from the UCLK domain to the DFICLK domain associated with the DFI interface.
Address generator 522 decodes addresses of memory access requests received from data fabric 250 over the AXI4 bus. The memory access requests include access addresses in the physical address space represented in a normalized format. Address generator 522 converts the normalized addresses into a format that can be used to address the actual memory devices in memory system 120, as well as to efficiently schedule related accesses. This format includes a region identifier that associates the memory access request with a particular rank, a row address, a column address, a bank address, and a bank group. On startup, the system BIOS queries the memory devices in memory system 120 to determine their size and configuration, and programs a set of configuration registers associated with address generator 522. Address generator 522 uses the configuration stored in the configuration registers to translate the normalized addresses into the appropriate format. Command queue 520 is a queue of memory access requests received from the memory accessing agents in data processing system 100, such as CPU cores 212 and 214 and graphics core 220. Command queue 520 stores the address fields decoded by address generator 522 as well other address information that allows arbiter 538 to select memory accesses efficiently, including access type and quality of service (QoS) identifiers. CAM 524 includes information to enforce ordering rules, such as write after write (WAW) and read after write (RAW) ordering rules.
Replay queue 530 is a temporary queue for storing memory accesses picked by arbiter 538 that are awaiting responses, such as address and command parity responses, write cyclic redundancy check (CRC) responses for DDR4 DRAM or write and read CRC responses for gDDR5 DRAM. Replay queue 530 accesses ECC check block 542 to determine whether the returned ECC is correct or indicates an error. Replay queue 530 allows the accesses to be replayed in the case of a parity or CRC error of one of these cycles.
Refresh logic 532 includes state machines for various powerdown, refresh, and termination resistance (ZQ) calibration cycles that are generated separately from normal read and write memory access requests received from memory accessing agents. For example, if a memory rank is in precharge powerdown, it must be periodically awakened to run refresh cycles. Refresh logic 532 generates refresh commands periodically to prevent data errors caused by leaking of charge off storage capacitors of memory cells in DRAM chips. In addition, refresh logic 532 periodically calibrates ZQ to prevent mismatch in on-die termination resistance due to thermal changes in the system.
Arbiter 538 is bidirectionally connected to command queue 520 and is the heart of memory channel controller 510. It improves efficiency by intelligent scheduling of accesses to improve the usage of the memory bus. Arbiter 538 uses timing block 534 to enforce proper timing relationships by determining whether certain accesses in command queue 520 are eligible for issuance based on DRAM timing parameters. For example, each DRAM has a minimum specified time between activate commands, known as “tRC”. Timing block 534 maintains a set of counters that determine eligibility based on this and other timing parameters specified in the JEDEC specification, and is bidirectionally connected to replay queue 530. Page table 536 maintains state information about active pages in each bank and rank of the memory channel for arbiter 538, and is bidirectionally connected to replay queue 530.
In response to write memory access requests received from interface 512, ECC generation block 544 computes an ECC according to the write data. DB 546 stores the write data and ECC for received memory access requests. It outputs the combined write data/ECC to queue 514 when arbiter 538 picks the corresponding write access for dispatch to the memory channel.
Power controller 550 generally includes an interface 552 to an advanced extensible interface, version one (AXI), an APB interface 554, and a power engine 560. Interface 552 has a first bidirectional connection to the SMN, which includes an input for receiving an event signal labeled “EVENT_n” shown separately in
Memory channel controller 510 includes circuitry that allows it to pick memory accesses for dispatch to the associated memory channel. In order to make the desired arbitration decisions, address generator 522 decodes the address information into predecoded information including rank, row address, column address, bank address, and bank group in the memory system, and command queue 520 stores the predecoded information. Configuration registers 562 store configuration information to determine how address generator 522 decodes the received address information. Arbiter 538 uses the decoded address information, timing eligibility information indicated by timing block 534, and active page information indicated by page table 536 to efficiently schedule memory accesses while observing other criteria such as QoS requirements. For example, arbiter 538 implements a preference for accesses to open pages to avoid the overhead of precharge and activation commands required to change memory pages, and hides overhead accesses to one bank by interleaving them with read and write accesses to another bank. In particular during normal operation, arbiter 538 normally keeps pages open in different banks until they are required to be precharged prior to selecting a different page.
In operation, a memory controller such as memory controller 500 of
Refresh logic 532 implements on-the-fly mode using a first state, REF1 state 604, and a second state, either REF2 state 606 or REF4 state 608. REF1 state 604 corresponds to the use of a first auto-refresh command, REF1, which causes the memory to auto-refresh a whole bank in response to a refresh (REF) command. REF2 state 606 corresponds to the use of a second auto-refresh command, REF2, which causes the memory to auto-refresh a selected subset of the bank, in this example one-half of the bank, in response to the REF command. REF4 state 608 also corresponds to the use of a third auto-refresh command, REF4, which causes the memory to auto-refresh a smaller selected subset of the bank, in this case one-fourth of the bank, in response to the REF command. Memory controller 290 switches between REF1 state 604 and REF2 state 606 or REF4 state 608 in response to detecting a first condition (condition 618 or condition 622, respectively) related to a bank to be refreshed. Memory controller 290 switches from REF2 state 606 or REF4 state 608 to REF1 state 604 in response to detecting a second condition (condition 624 or condition 620, respectively).
In general, refresh logic 532 issues refresh commands at a rate sufficient to refresh each memory bank within a period of time indicated by the refresh interval parameter tREFI. The number of refresh commands issued during each tREFI period depends on the type of refresh commands issued in the current refresh state. Refresh logic 532 provides one REF1 command to the bank during each tREFI period if the bank is in REF1 state 604, two REF2 commands to the bank during each tREFI period if the bank is in REF2 state 606, or four REF4 commands to the bank during each tREFI period if the bank is in REF4 state 608.
Refresh logic 532 is in self refresh state 602 when the corresponding memory is in a low power state. When memory controller 500 causes the memory to exit the low power state, refresh logic 532 transitions from self refresh state 602 to a selected one of REF1 state 604, REF2 state 606, and REF4 state 608. Memory controller 290 remains in its current state as indicated state transitions 632, 634, and 636 for REF1 state 604, REF2 state 606, and REF4 state 608 until certain conditions are met.
Any of a number of conditions for switching between the refresh states can be used alone or in various combinations. In the illustrated embodiment, these conditions include the number of pending refreshes to a bank, the number of pending memory access requests in command queue 520 of
To take one simple example, refresh logic 532 can switch between REF1 state 604 and the REF2 state 606 if a number of pending memory access requests for the bank is above a threshold amount. This condition indicates that lower latency and hence a finer granularity of refresh is preferred. On the other hand, if refresh logic 532 is in REF2 state 606 but determines that an even number of REF2 commands has been issued and there are no pending memory access requests to the bank, then it changes from REF2 state 606 back to REF1 state 604 to preserve efficiency. A precondition for refresh logic 532 making a state transition from REF2 state 606 or REF4 state 608 is that the number of refreshes issued corresponds to the portion of the bank that is being refreshed at one time. Accordingly refresh logic 532 is connected to arbiter 538 as shown in
REF1 state 700 corresponds to the use of a first auto-refresh command, REF1 command, that causes the memory to auto-refresh one or more banks 702. When REF1 command is executed, REF1 bank 704 is refreshed, resulting in refreshed bank 706.
REF2 state 710 corresponds to the use of a second auto-refresh command, REF2 command, that causes the memory to auto-refresh a first subset and a second subset of bank 702 within a period known as the refresh interval (tREFI), as shown with REF2_1 bank 714 and REF2_2 bank 716. REF2_1 bank 714 and REF2_2 bank 716 are each a separate half subset of bank 702.
REF4 state 720 also corresponds to the use of a third auto-refresh command, REF4 command, that causes the memory to auto-refresh a first subset, a second subset, a third subset, and a fourth subset of bank 702 within a tREFI period. REF4_1 bank 724, REF4_2 bank 726, REF4_3 bank 728, and REF4_4 bank 730 correspond to the refreshed first subset, second subset, third subset, and fourth subset of bank 702. REF4_1 bank 724, REF4_2 bank 726, REF4_3 bank 728, and REF4_4 bank 730 are each separate quarter subsets of bank 702 within REF4 state 720.
The number of refreshes must correspond to a total number of subsets before a state change can occur. In one embodiment, a first auto-refresh command, REF1, is received causing the memory to auto-refresh a whole bank such as bank 702. In response to detecting a first condition a switch is made from REF1 700 to REF2 710 or to REF4 720. When a REF2 command is received, the total number of refreshes must be a multiple of two, before the condition is satisfied. When a REF4 command is received, the total number of refreshes must be a multiple of four, before the condition is satisfied.
By providing these different refresh modes with finer granularity than the REF1 mode, and using characteristics of pending memory access requests already tracked by memory controller 500 to make state change decisions on-the-fly, memory controller 500 is able to reduce the latency of incoming memory access requests during periods of high system bus usage, while refreshing memory banks more efficiently during periods of low system bus usage.
Some or all of the method illustrated in
While particular embodiments have been described, various modifications to these embodiments will be apparent to those skilled in the art. Memory controller 500 may interface to other types of memory besides DDRx memory, such as high bandwidth memory (HBM), RAMbus DRAM (RDRAM), and the like. While the illustrated embodiment showed each rank of memory corresponding to separate DIMMs, in other embodiments each DIMM can support multiple ranks. Moreover, the memory channel may comprise a plurality of ranks of double rate version four DDR4 memory.
Accordingly, it is intended by the appended claims to cover all modifications of the disclosed embodiments that fall within the scope of the disclosed embodiments.
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6226709, | Oct 24 1997 | Hewlett Packard Enterprise Development LP | Memory refresh control system |
6496906, | Dec 04 1998 | Advanced Micro Devices, Inc. | Queue based memory controller |
8873326, | Aug 30 2012 | SK Hynix Inc. | Memory device |
9412433, | Jan 22 2014 | Nanya Technology Corp. | Counter based design for temperature controlled refresh |
9418723, | Dec 23 2014 | TAHOE RESEARCH, LTD | Techniques to reduce memory cell refreshes for a memory device |
9576637, | May 25 2016 | Advanced Micro Devices, Inc.; Advanced Micro Devices, INC | Fine granularity refresh |
20080172534, | |||
20130138911, | |||
20140133255, | |||
20150162071, | |||
20150221358, | |||
20160027498, | |||
20160180917, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 25 2016 | BALAKRISHNAN, KEDARNATH | Advanced Micro Devices, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040992 | /0743 | |
Jan 17 2017 | Advanced Micro Devices, Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Aug 04 2021 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
Feb 20 2021 | 4 years fee payment window open |
Aug 20 2021 | 6 months grace period start (w surcharge) |
Feb 20 2022 | patent expiry (for year 4) |
Feb 20 2024 | 2 years to revive unintentionally abandoned end. (for year 4) |
Feb 20 2025 | 8 years fee payment window open |
Aug 20 2025 | 6 months grace period start (w surcharge) |
Feb 20 2026 | patent expiry (for year 8) |
Feb 20 2028 | 2 years to revive unintentionally abandoned end. (for year 8) |
Feb 20 2029 | 12 years fee payment window open |
Aug 20 2029 | 6 months grace period start (w surcharge) |
Feb 20 2030 | patent expiry (for year 12) |
Feb 20 2032 | 2 years to revive unintentionally abandoned end. (for year 12) |