The present disclosure relates generally to non-volatile memory devices, and more particularly to power saving techniques for non-volatile memory devices.
Many solid state drive (SSD) devices provide a power saving mode of operation that provides a significant reduction in power consumed by the SSD drive as compared to an active mode of operation of the SSD device. In many usage scenarios, the SSD is put into the power-saving mode very frequently. In the power saving mode, much of the circuitry in the SSD device is shut down to conserve power. However, typical SSD devices include a volatile memory (e.g., static random-access memory (SRAM)) that stores information that is used by the SSD device during the active mode; At least some of the information stored in the volatile memory is needed in order for the SSD to enter and exit the power save mode frequently and quickly, and resume normal operation quickly when exiting the power save mode, it is necessary for the SSD to maintain, while in the power save mode, a large amount of data and state information that is normally stored in the volatile memory. For example, the volatile memory may store information such as i) cached or buffered write data received from a host and that is to be eventually written to non-volatile memory of the SSD, ii) internal data structures used by firmware being executed by one or more central processing units (CPUs) of the SSD device, etc. Thus, the entire volatile memory cannot simply be shut down when the SSD device goes into the power save mode.
At least when other circuitry of the SSD device (such as processors, control circuitry, etc.) is shut down in the power saving mode, the volatile memory (such as SRAM) is responsible for a significant amount of power consumed by the SSD device. In one approach to reduce the amount of power consumed by the volatile memory during the power saving mode, banks of the volatile memory that do not store information necessary for transitioning the SSD device back to the normal mode and resuming operation are shut down, whereas other banks of the volatile memory that do store information necessary for transitioning the SSD device back to the normal mode are put into a retention mode in which the stored information is retained but power consumption is reduced as compared to a normal mode of operation of the volatile memory.
To enable more of the volatile memory to be shut down (as opposed to being put into the retention mode) to further reduce power consumption, some information can be moved from the volatile memory to the non-volatile memory. However, moving information from the volatile memory to the non-volatile memory and vice versa significantly increases the amount of time necessary to transition from the active mode to the power saving mode (sometime referred to as “entrance latency”), and vice versa (sometime referred to as “resume latency”). Additionally, an SSD device typically transitions to and from the power saving mode relatively frequently, and because the non-volatile memory of an SSD typically can be written only a finite number of times during its lifetime, the repeated moving of information to the non-volatile memory when transitioning to power saving mode may reduce the lifespan of the SSD device. Similarly, the repeated reading of information from the non-volatile memory when exiting the power saving mode may cause wear on the non-volatile memory and consequently cause read disturb errors to increase.
In an embodiment, an apparatus for reducing power consumed by a solid state drive (SSD) device comprises a controller that includes at least one of i) a processor and a memory, the processor being configured to execute machine readable instructions stored in the memory, and ii) hardware circuitry. The controller is configured to, in response to determining that the SSD device is to transition to a power saving mode: transfer information from at least some of a volatile memory of an SSD device controller of the SSD device to a host memory of a host computer via a communication interface; and transition the at least some of the volatile memory to an OFF state to reduce power consumption of the SSD device. The controller is further configured to, in response to determining that the SSD device is to transition from the power saving mode to a normal operating mode: transition the at least some of the volatile memory to an ON state in which the at least some of the volatile memory is configured to retain data; and transfer the information from the host memory to the volatile memory of the SSD device controller via the communication interface.
In another embodiment, a method for reducing power consumed by an SSD device having non-volatile memory and volatile memory includes, in response to determining that the SSD device is to transition to a power saving mode: controlling direct memory access (DMA) circuitry to transfer information from the volatile memory of the SSD device to a host memory of a host computer via a communication interface; and generating control signals to transition at least some of the volatile memory of the SSD device to the OFF state to reduce power consumption of the SSD device. The method also includes, in response to determining that the SSD device is to transition from the power saving mode to a normal operating mode: generating control signals to transition the at least some of the volatile memory of the SSD device to an ON state in which the volatile memory is capable of retaining data; and controlling the DMA circuitry to transfer the information from the host memory to the volatile memory of the SSD device via the communication interface.
In embodiments described below, a controller of a solid state drive (SSD) device transfers information in a volatile memory of the SSD device (sometimes referred to herein as “SSD volatile memory”) to a memory of a host (sometimes referred to herein as “host memory”) in connection with the SSD device transitioning from a normal operating mode to a power saving mode. The information that is transferred includes information (sometimes referred to herein as “dynamic information” for brevity) that cannot simply be discarded and is necessary for the SSD device to transition back to the normal operating mode from the power saving mode and resume operation, such as one or more of i) cached write data that has not yet been written to non-volatile memory (NVM) of the SSD device, ii) state information of one or more controllers of the SSD drive, etc. By transferring the dynamic information from the SSD volatile memory to the host memory, some or all of the SSD volatile memory can be powered down during the power saving mode to increase power savings as compared to some prior art SSD devices in which a significantly larger portion of the volatile memory is kept powered on in order to retain the dynamic information, at least according to some embodiments. Also, by transferring the dynamic information to the host memory, entrance latency and/or wear on the NVM is reduced as compared to some prior art SSD devices in which dynamic information is transferred to the NVM when transitioning to the power saving mode, at least according to some embodiments.
Similarly, in embodiments described below, the controller of the SSD device transfers the dynamic information from the host memory back to the SSD volatile memory in connection with the SSD device transitioning from the power saving mode back to the normal operating mode. Because the dynamic information is transferred from the host memory, resume latency and/or wear on the NVM is reduced as compared to some prior art SSD devices in which dynamic information is transferred to the NVM when transitioning to the power saving mode and then transferred from the NVM when transitioning back to the normal operating mode, at least according to some embodiments.
The host computing device 104 comprises a host central processing unit (CPU) 116 communicatively coupled to a host memory 120. The host memory 120 includes a host memory buffer (HMB) 124. When the SSD device 108 is in a normal operating mode, the HMB 124 buffers read data that has been read from the SSD device 108, according to some embodiments. In other embodiments, the HMB 124 additionally or alternatively buffers write data to be written to the SSD device 108. As will be described in more detail below, the SSD device 108 also transfers dynamic information from volatile memory of the SSD device 108 to the HMB 124 in connection with the SSD device 108 transitioning to a power saving mode, and transfers the dynamic information from the HMB 124 back to the volatile memory of the SSD device 108 in connection with the SSD device 108 transitioning back to the normal operating mode.
The SSD device 108 comprises an SSD device controller 132 communicatively coupled to one or more NVM chips 136 (sometimes referred to herein as “the NVM chips 136” for brevity). Although six NVM chips 136 are illustrated in
The SSD device controller 132 comprises an NVM controller 140 that is configured to write data to and read data from the NVM chips 136, according to an embodiment. In some embodiments, the NVM controller 140 is also configured to perform functions related to redundant array of independent disks (RAID) storage of data in the NVM chips 136, as will be described further below.
The NVM controller 140 generally is configured to operate in accordance with non-volatile memory technology of the NVM chips 136. For example, the NVM controller 140 comprises a NAND flash controller when the NVM chips 136 comprise one or more NAND flash chips, according to an embodiment. The NVM controller 140 comprises another suitable type of NVM controller (e.g., a PCM controller, an FRAM controller, an MRAM controller, etc.) when the NVM chips 136 comprise one or more suitable NVM chips other than NAND flash chips (e.g., one or more PCM chips, one or more FRAM chips, one or more MRAM chips, etc.), according to another embodiment.
The NVM controller 140 comprises a processor that executes machine readable instructions that cause the NVM controller 140 to perform functions such as described above, in some embodiments. The NVM controller 140 additionally or alternatively comprises hardware circuitry (e.g., a hardware state machine) configured to perform functions such as described above, in some other embodiments.
In an embodiment in which the NVM controller 140 is configured to perform functions related to RAID storage, the NVM controller 140 comprises one or more RAID buffers 144 that store data that is in the process of being striped to the NVM chips 136. The one or more RAID buffers 144 are implemented using volatile memory such as one or more registers, random access memory (RAM) such as static RAM (SRAM), dynamic RAM (DRAM), or another suitable RAM, etc., according to various embodiments. Losing data stored in the one or more RAID buffers when the SSD 108 goes into the power saving mode can compromise data reliability and may lead to significant data loss. However, because of memory access speed requirements of the NVM controller 140, lifetime write limits of NVMs such as flash memories, and/or cost constraints, it is impractical to use an NVM for the buffers 144, at least in some embodiments.
The SSD device controller 132 also comprises one or more central processing units (CPUs) 152 that are configured to perform functions such as one or more of i) wear leveling to distribute writes evenly across NVM blocks in the NVM chips 136, ii) garbage collection, iii) mapping host side logical block addresses (LBAs) to physical addresses of the NVM chips 136, etc., according to various embodiments.
In an embodiment, each of the CPUs 152 includes respective tightly coupled memory (TCM) 156 that stores one or both of i) machine readable instructions being executed by the CPU 152, and ii) data upon which the CPU 152 is operating. In some embodiments, multiple CPUs 152 are coupled to shared TCM 160 that stores data upon which the multiple CPUs 152 are operating.
The TCMs 156 and the shared TCM 160 are implemented using volatile memory such as one or more registers, RAM such as SRAM, DRAM, or another suitable RAM, etc., according to various embodiments. Losing instructions and/or data stored in the TCMs 156 and the shared TCM 160 when the SSD 108 goes into the power saving mode may cause the one or more CPUs 152 to crash and/or generate incorrect data and/or control signals. However, because of memory access speed requirements of the CPUs 152, lifetime write limits of NVMs such as flash memories, and/or cost constraints, it is impractical to use NVMs for the TCMs 156, 160, at least in some embodiments.
The SSD device controller 132 also comprises a system controller 168 that performs functions associated with general control of the SSD Device 108 and control of communications with the host 104, according to an embodiment. The system controller 168 includes a communication interface controller 172 that is configured to perform functions associated with the communication interface 112. For example, in embodiments in which the communication interface 112 corresponds to the PCIe standard, the communication interface controller 172 comprises a PCIe controller that is configured to control communications with the host 104 via the communication interface 112. In embodiments in which the communication interface 112 does not correspond to the PCIe standard, the communication interface controller 172 is configured to control communications via another suitable communication interface 112, such as Infiniband, RapidIO, CXL, etc.
In some embodiments in which the SSD device 108 communicates with the host 104 according to the non-volatile memory express (NVMe) standard, the system controller 168 also includes an NVMe controller 176 that is configured to control communications with the host 104 according to the NVMe standard. For example, in embodiments in which the communication interface 112 corresponds to the PCIe standard, the communication interface controller 172 comprises a PCIe controller that is configured to control communications with the host 104 via the communication interface 112. In embodiments in which the communication interface 112 does not correspond to the PCIe standard, the communication interface controller 172 is configured to control communications via another suitable communication interface 112, such as Infiniband, RapidIO, CXL, etc.
The system controller 168 also comprises an HMB controller 180 that performs functions associated with transferring data from volatile memory of the SSD device 108 to the HMB 124 via the communication interface 112 in connection with the SSD device 108 transitioning to the power saving mode. In connection with the SSD device 108 transitioning from the power saving mode to a normal operating mode, the HMB controller 180 performs functions associated with transferring data back to the volatile memory of the SSD device 108 from the HMB 124 via the communication interface 112. In an embodiment, the HMB controller 180 comprises direct memory access (DMA) circuitry for transferring data between the volatile memory of the SSD device 108 and the HMB 124. Operation of the HMB controller 180 will be described in more detail below.
The system controller 168 comprises one or more processors that execute machine readable instructions that cause the one or more processors to perform functions such as described above, in some embodiments. For example, in an embodiment, each of the communication interface controller 172, the NVMe controller 176, and the HMB controller 180 comprises a respective processor. In another embodiment, at least two of the communication interface controller 172, the NVMe controller 176, and the HMB controller 180 comprises a single processor. The system controller 168 additionally comprises hardware circuitry (e.g., one or more hardware state machines) configured to perform functions such as described above, in some other embodiments.
The SSD device controller 132 also comprises a volatile memory 184 such as one or more SRAMs, one or more DRAMs, etc. The NVM controller 140, the one or more CPUs 152, and the system controller 168 are communicatively coupled to the volatile memory 184 via a suitable fabric 188. The volatile memory 184 comprises machine readable instructions (e.g., firmware code, software code, etc.) and/or data 190 (FW code/data 190) corresponding to one or more of i) the NVM controller 140, ii) the one or more CPUs 152, and iii) the system controller 168. For example, machine readable instructions that are executed by one or more of i) the NVM controller 140, ii) the one or more CPUs 152, and iii) the system controller 168, are stored in the volatile memory 184, in some embodiments. Similarly, data upon which one or more of i) the NVM controller 140, ii) the one or more CPUs 152, and iii) the system controller 168, operates are stored in the volatile memory 184, in some embodiments. Losing information in the FW code/data 190 may cause one or processors (corresponding to one or more of i) the NVM controller 140, ii) the one or more CPUs 152, and iii) the system controller 168) to crash and/or generate incorrect data and/or control signals. However, because of memory access speed requirements of the NVM controller 140, the one or more CPUs 152, and/or the system controller 168, lifetime write limits of NVMs such as flash memories, and/or cost constraints, it is impractical to use an NVM for the memory 184, at least in some embodiments.
In some embodiments, the volatile memory 184 additionally or alternatively stores a cache 192 (or buffer) that stores i) write data that that is to be written to the NVM chips 136 and that was transferred from the host 104 via the communication interface 112, and/or ii) read data that was read from the NVM chips 136 and is to be transferred to the host 104 via the communication interface 112. Losing data in the buffer 192 may cause errors in writing and/or reading data to/from the NVM chips 136.
In some embodiments, the volatile memory 184 additionally or alternatively stores metadata 194 maintained by a flash translation layer (FTL) (the FTL metadata 194) that is being implemented by one or both of i) the NVM controller 140, and ii) the one or more CPUs 152. The FTL metadata includes information that tracks various information (e.g., one or more of read disturb counters, write cursors, RAID buffers, defect list, block information, system metadata, etc.) about the FTL that is being updated at run-time. Losing FTL metadata 194 when the SSD device 108 goes into the power saving mode may cause errors in data being written to the NVM chips 136 and reduce the reliability of data stored on the NVM chips 136.
As mentioned above, the HMB controller 180 performs functions associated with transferring data from volatile memory of the SSD device 108 to the HMB 124 via the communication interface 112 in connection with the SSD device 108 transitioning to the power saving mode, and performs functions associated with transferring data back to the volatile memory of the SSD device 108 from the HMB 124 via the communication interface 112 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode, according to some embodiments.
As discussed previously, the SSD device 108 comprises one or more volatile memories that store dynamic information, such as the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), the one or more TCMs 156/160, and the volatile memory 184. In an embodiment, the HMB controller 180 transfers dynamic information stored in one of, or any suitable combination of two or more of, the volatile memor(ies) of the SSD device 108 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode, such as from the normal operating mode. After the dynamic information stored in the one of, or any suitable combination of two or more of, the volatile memor(ies) of the SSD device 108 are transferred to the HMB 124, some or all of the volatile memor(ies) of the SSD device 108 are shut down to conserve power, as will be described in more detail below.
In an embodiment, the HMB controller 180 transfers dynamic information from the volatile memory 184 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode. For example, in various illustrative embodiments, the HMB controller 180 transfers one of, or any suitable combination of two or more of, i) the firmware code and/or data 190, ii) the cache 192, iii) the FTL metadata 194, etc. In an embodiment, after the dynamic information is transferred from the volatile memory 184 to the HMB 124, some or all of the volatile memory 184 is shut down to conserve power, as will be described in more detail below.
Additionally or alternatively, the HMB controller 180 transfers dynamic information from one of, or any suitable combination of two or more of, the TCMs 156/160 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode. In one embodiment, the HMB controller 180 transfers dynamic information from one of, or any suitable combination of two or more of, the TCMs 156/160 to the volatile memory 184 in connection with the SSD device 108 transitioning to the power saving mode, and then transfers the dynamic information (including the dynamic information that was originally stored in the TCMs 156/160) from the volatile memory 184 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode. In another embodiment, the HMB controller 180 transfers dynamic information from one of, or any suitable combination of two or more of, the TCMs 156/160 directly to the HMB 124 via the interface 112 (i.e., without first storing the dynamic information from the one or more TCMs 156/160 in the volatile memory 184) in connection with the SSD device 108 transitioning to the power saving mode. Direct transfer from the TCMs 156/160 to the HMB 124 will reduce entrance latency as compared to transfer from the TCMs 156/160 to volatile memory 184, and then from the volatile memory 184 to the HMB 124, at least in some embodiments.
In an embodiment, after the dynamic information is transferred from the one or more TCMs 156/160 to the HMB 124, some or all of the one or more TCMs 156/160 are shut down to conserve power, as will be described in more detail below.
Additionally or alternatively, the HMB controller 180 transfers dynamic information from the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode. In one embodiment, the HMB controller 180 transfers dynamic information from the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) to the volatile memory 184 in connection with the SSD device 108 transitioning to the power saving mode, and then transfers the dynamic information (including the dynamic information that was originally stored in the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144)) from the volatile memory 184 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning to the power saving mode. In another embodiment, the HMB controller 180 transfers dynamic information from the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) directly to the HMB 124 via the interface 112 (i.e., without first storing the dynamic information from the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) in the volatile memory 184) in connection with the SSD device 108 transitioning to the power saving mode. Direct transfer from the volatile memory of (or coupled to) the NVM controller 140 to the HMB 124 will reduce entrance latency as compared to transfer from the volatile memory of (or coupled to) the NVM controller 140 to volatile memory 184, and then from the volatile memory 184 to the HMB 124, at least in some embodiments.
In an embodiment, after the dynamic information is transferred from the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) to the HMB 124, some or all of the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) are shut down to conserve power, as will be described in more detail below.
In an embodiment, the HMB controller 180 includes DMA circuitry 204 that is configured to transfer dynamic information from the volatile memory 184 to the HMB 124 via the interface 112. In another embodiment, the DMA circuitry 204 additionally is configured to transfer dynamic information from one or both of i) one or more of the TCMs 156/160 to the volatile memory 184, and ii) the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), to the volatile memory 184. In another embodiment, the DMA circuitry 204 additionally is configured to transfer dynamic information from one or both of i) one or more of the TCMs 156/160 to the volatile memory 184, and ii) the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), directly to the HMB 124 via the interface 112. As discussed above, direct transfer to the HMB 124 will reduce entrance latency, as compared to transfer via the volatile memory 184.
In an embodiment, the HMB controller 180 transfers dynamic information that was temporarily stored in the HMB 124 to one of, or any suitable combination of two or more of, the volatile memor(ies) of the SSD device 108 to the HMB 124 via the interface 112 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. Prior to the dynamic information being transferred, the volatile memor(ies) (or portions thereof) of the SSD device 108 that were shut down to conserve power are transitioned back to a normal operating mode, as will be described in more detail below.
In an embodiment, the HMB controller 180 transfers dynamic information from the HMB 124 to the volatile memory 184 via the interface 112 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. For example, in various illustrative embodiments, the HMB controller 180 transfers dynamic information from the HMB 124 to one of, or any suitable combination of two or more of, i) the firmware code and/or data 190, ii) the cache 192, iii) the FTL metadata 194, etc.
Additionally or alternatively, the HMB controller 180 transfers dynamic information from the HMB 124 to one of, or any suitable combination of two or more of, the TCMs 156/160 via the interface 112 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. In one embodiment, the HMB controller 180 transfers the dynamic information from the HMB 124 to the volatile memory 184, and then transfers the dynamic information from the volatile memory 184 to one of, or any suitable combination of two or more of, the TCMs 156/160 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. In another embodiment, the HMB controller 180 transfers dynamic information from the HMB 124 directly to one of, or any suitable combination of two or more of, the TCMs 156/160 via the interface 112 (i.e., without first storing the dynamic information in the volatile memory 184) in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode.
Additionally or alternatively, the HMB controller 180 transfers dynamic information from the HMB 124 to the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), via the interface 112 in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. In one embodiment, the HMB controller 180 transfers dynamic information from the HMB 124 to the volatile memory 184, and then transfers the dynamic information from the volatile memory 184 to the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode. In another embodiment, the HMB controller 180 transfers dynamic information from the HMB 124 directly to the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144) via the interface 112 (i.e., without first storing the dynamic information in the volatile memory 184) in connection with the SSD device 108 transitioning from the power saving mode to the normal operating mode.
In an embodiment in which the HMB controller 180 includes the DMA circuitry 204, the DMA circuitry 204 is configured to transfer dynamic information from the HMB 124 to the volatile memory 184 via the interface 112. In another embodiment, the DMA circuitry 204 additionally is configured to transfer dynamic information from the volatile memory 184 to one or both of i) one or more of the TCMs 156/160 to the volatile memory 184, and ii) the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), to the volatile memory 184. In another embodiment, the DMA circuitry 204 additionally is configured to transfer dynamic information from the HMB 124 directly to one or both of i) one or more of the TCMs 156/160 to the volatile memory 184, and ii) the volatile memory of (or coupled to) the NVM controller 140 (e.g., the RAID buffer(s) 144), via the interface 112.
In an embodiment, each of the memory blocks 408, 412, and 416 comprises a memory block of size 128 kilobytes (kB). In other embodiments, each of the memory blocks 408, 412, and 416 comprises a memory block of another suitable size other than 128 kB, such as 16 kB, 32 kB, 64 kB, 96 kB, 256 kB, etc. In other embodiments, at least some of the memory blocks 408, 412, and 416 have different suitable sizes.
Each of the memory blocks 408, 412, and 416 is configured to receive a control signal that is used to transition the memory block amongst a set of multiple operating states (only control signals to memory blocks 408 are illustrated in
In some embodiments, the set of multiple operating states includes a retention state (instead of or in addition to the OFF state) in which reading and writing of data is not permitted, but where data already stored in the memory block is maintained. When in the retention state, the memory block consumes less power (e.g., at least 40% less, at least 50% less, at least 60% less, etc.) as compared to the ON state, but consumes more power as compared to the OFF state.
Referring now to
Although two memory blocks 408-1 and 408-2 are shaded in
Although
Although
In an embodiment, each of the memory blocks 454-1, 454-3, and 454-5 comprises a memory block of size 96 kB, and each of the memory blocks 454-2, 454-4, 454-6, and 454-7 comprises a memory block of size 64 kB. In other embodiments, the memory blocks 454 comprise memory blocks of other suitable sizes. In another embodiment, all of the memory blocks 454 have a same size. In another embodiment, the memory block 454-7 has a size that is different than the memory blocks 454-1 through 454-6.
Each of the memory blocks 454 is configured to receive a control signal that is used to transition the memory block amongst a set of multiple operating states. In an embodiment, the set of multiple operating states includes the ON state and the OFF state discussed above with reference to
Referring now to
Although the memory block 454-7 is shaded in
Although
Referring again to
Referring now to
In some embodiments, encryption, error detection, and/or error correction techniques are used in connection with transferring dynamic information from volatile memor(ies) of the SSD device 108 to the HMB 124.
The HMB controller 604 is the same as or similar to the HMB controller 180 described above, except the HMB controller 604 includes DMA circuitry 608 that includes, or is coupled to, encryption/decryption circuitry 612 that is configured to encrypt dynamic information that is being transferred from volatile memor(ies) of the SSD device 108 to the HMB 124. In an embodiment, the HMB controller 604 also includes, or is coupled to, buffers 616 that are used in conjunction with encrypting the dynamic information. For example, the HMB controller 604 uses a ping-pong method for encrypting the dynamic information and transferring encrypted dynamic information to the HMB 124. In an embodiment, the encryption/decryption circuitry 612 encrypts dynamic information from a volatile memory in a first buffer 1616 (Buffer A). Then, the DMA circuitry 608 transfers the encrypted dynamic information from Buffer A to the HMB 124 while the encryption/decryption circuitry 612 encrypts dynamic information from the volatile memory in a second buffer 1616 (Buffer B). Then, the DMA circuitry 608 transfers the encrypted dynamic information from Buffer B to the HMB 124 while the encryption/decryption circuitry 612 encrypts dynamic information from the volatile memory in Buffer A, and so on. In other words, the encryption/decryption circuitry 612 alternates between encrypting dynamic information in Buffer A and encrypting dynamic information in Buffer B, and the DMA circuitry 608 alternates between transferring the encrypted dynamic information in Buffer B and transferring the encrypted dynamic information in Buffer A. The encryption/decryption circuitry 612 is also configured to decrypt dynamic information that is being transferred back from the HMB 124 to the volatile memor(ies) of the SSD device 108 in a similar manner.
The HMB controller 704 is the same as or similar to the HMB controller 180 described above, except the HMB controller 704 includes encryption/decryption circuitry 708 that is configured to perform in-line encryption of dynamic information that is being transferred from volatile memor(ies) of the SSD device 108 to the HMB 124, and to perform in-line decryption of dynamic information that is being transferred from the HMB 124 to the volatile memor(ies) of the SSD device 108.
The HMB controller 804 is the same as or similar to the HMB controller 180 described above, except the HMB controller 804 includes error detection circuitry 808 that is configured to generate respective error detection information for units of dynamic information that are being transferred from volatile memor(ies) of the SSD device 108 to the HMB 124, and to append the error detection information to respective units of dynamic information so that the error detection information is also stored in the HMB 124. As an illustrative example, the error detection circuitry 808 generates respective error detection information for each 128 kB unit of dynamic information and appends the respective error detection information to each 128 kB unit of dynamic information. In other embodiments, the units of dynamic information have another suitable size.
In an embodiment, the error detection circuitry 808 is configured to generate cyclic redundancy check (CRC) information according to a suitable CRC generation algorithm.
In connection with transferring dynamic information back from the HMB 124 to the volatile memor(ies) of the SSD device 108, the error detection circuitry 808 is also configured to generate respective error detection information for units of dynamic information that are being transferred from the HMB 124, and to compare the generated error detection information to the error detection information that is appended to the respective units of dynamic information in order to detect errors/changes to the dynamic information. In some embodiments, the error detection circuitry 808 is also configured to remove appended error detection information from units of dynamic information that are being transferred from the HMB 124 at least for the units of dynamic information that the error detection circuitry 808 has determined do not contain errors/changes.
The HMB controller 904 is the same as or similar to the HMB controller 180 described above, except the HMB controller 904 includes error correction code circuitry 908 that is configured to encode, according to an error correction code, units of dynamic information that are being transferred from volatile memor(ies) of the SSD device 108 to the HMB 124 with redundancy information so that the encoded dynamic information is stored in the HMB 124. As an illustrative example, the error correction code circuitry 908 encodes each 32 byte unit of dynamic information according to a suitable error correction code. In other embodiments, the units of dynamic information that are encoded have another suitable size.
In an embodiment, the error correction code circuitry 908 is configured to generate redundancy information according to a Reed-Solomon error correction encoding method. In an embodiment that utilizes the Reed-Solomon error correction encoding method, the error correction code circuitry 908 is configured to encode each 32 byte unit to generate four bytes of redundancy information that is appended to the 32 byte unit. In other embodiments, the error correction code circuitry 908 is configured to encode the dynamic information according to another suitable error correction code such as another block code (e.g., a Golay code, a Hamming code, a Bose-Chaudhuri-Hocquenghem (BCH) code, a low density parity check (LDPC) code, etc.), a convolutional code, a turbo code, etc., and/or using units of data of a suitable size other than 32 bytes.
In connection with transferring dynamic information back from the HMB 124 to the volatile memor(ies) of the SSD device 108, the error correction code circuitry 908 is also configured to apply an error correction method to units of dynamic information that are being transferred from the HMB 124 and that were encoded according to the error correction code. In some embodiments that utilize a block code, the error correction code circuitry 908 is also configured to remove appended redundancy information from units of dynamic information that are being transferred from the HMB 124 at least for the units of dynamic information that did not include errors/changes and/or that the error correction code circuitry 908 was able to correct.
In various other embodiments, methods described with reference to
At block 1004, an SSD device (e.g., the SSD device 108) determines that the SSD device is to transition to a power saving mode. For example, in an embodiment, the SSD device controller 132 determines that the SSD device 108 is to transition to the power saving mode. In an embodiment, the system controller 168 determines that the SSD device 108 is to transition to the power saving mode. In another embodiment, another controller and/or other hardware circuitry of the SSD device controller 132 determines that the SSD device 108 is to transition to the power saving mode.
At block 1008, in response to determining at block 1004 that the SSD device is to transition to a power saving mode, dynamic information is transferred from volatile memory of the SSD device to host memory of a host computer via a communication interface. In an embodiment, the SSD device transfers the dynamic information at block 1008 to save the dynamic information while at least some of the volatile memory is put into an OFF state. For example, the SSD device controller 132 transfers dynamic information from volatile memory of the SSD device 108 to the HMB 124 via the communication interface 112, according to an embodiment. In an embodiment, the HMB controller 180 transfers dynamic information from volatile memory of the SSD device 108 to the HMB 124 via the communication interface 112.
As discussed above, the dynamic information includes information that cannot simply be discarded and is necessary for the SSD device to transition back to the normal operating mode from the power saving mode and resume operation, at least in some embodiments, such as one or more of i) cached write data that has not yet been written to NVM of the SSD device, ii) state information of one or more controllers of the SSD device, etc. In various illustrate embodiments, the dynamic information includes one of, or any suitable combination of two or more of: i) RAID data stored in buffers (e.g., the RAID buffers 144) of the SSD device and that is in the process of being striped to NVM chips of the SSD device, ii) data and/or code stored in tightly coupled memory of one or more CPUs of the SSD device, iii), data and/or code stored in another memory separate from the TCM memory of the one or more CPUs of the SSD device, iv) write data that that is to be written to NVM chips and that was transferred from the host via the communication interface, v) FTL metadata, etc.
Transferring dynamic information at block 1008 comprises transferring dynamic information from the volatile memory 184 to the HMB 124, according to an embodiment. In other embodiments, transferring dynamic information at block 1008 additionally or alternatively comprises one of, or any suitable combination of two or more of: i) transferring dynamic information from one or more TCMs of one or more CPUs of the SSD device to the host memory, ii) transferring dynamic information from one or more RAID buffers to the host memory, etc.
Transferring dynamic information at block 1008 comprises transferring dynamic information from a first volatile memory of the SSD device to a second volatile memory of the SSD device, and then transferring the dynamic information from the second volatile memory to the host memory, according to an embodiment. In an embodiment, transferring dynamic information at block 1008 comprises transferring dynamic information from TCM of a CPU of the SSD device to the host memory without first transferring the dynamic information from the TCM to a RAM of the SSD device.
At block 1012, in response to determining at block 1004 that the SSD device is to transition to a power saving mode and after transferring the dynamic information at block 1008, at least some of the volatile memory of the SSD device is transitioned to the OFF state. In an embodiment, the SSD device controller 132 generates control signals that transition at least some of the volatile memory of the SSD device to the OFF state. In an embodiment, the system controller 168 generates control signals that transition at least some of the volatile memory of the SSD device to the OFF state.
In an embodiment, transitioning at least some of the volatile memory of the SSD device to the OFF state at block 1012 comprises transitioning some of the volatile memory of the SSD device to the OFF state while other volatile memory of the SSD device is transitioned to a retention state.
At block 1016, the SSD device determines that the SSD device is to transition from the power saving mode to a normal operating mode. For example, in an embodiment, the SSD device controller 132 determines that the SSD device 108 is to transition from the power saving mode to the normal operating mode. In an embodiment, the system controller 168 determines that the SSD device 108 is to transition from the power saving mode to the normal operating mode. In another embodiment, another controller and/or other hardware circuitry of the SSD device controller 132 determines that the SSD device 108 is to transition from the power saving mode to the normal operating mode.
At block 1020, in response to determining at block 1016 that the SSD device is to transition from the power saving mode to the normal operating mode, at least some of the volatile memory of the SSD device is transitioned from the OFF state to an ON state. In an embodiment, transitioning at least some of the volatile memory of the SSD device from the OFF state to an ON state at block 1020 comprises transitioning the volatile memory that was transitioned to the OFF state at block 1012 to the ON state.
In an embodiment, the SSD device controller 132 generates control signals that transition at least some of the volatile memory of the SSD device from the OFF state to the ON state at block 1020. In an embodiment, the system controller 168 generates control signals that transition at least some of the volatile memory of the SSD device from the OFF state to the ON state at block 1020.
At block 1024, in response to determining at block 1016 that the SSD device is to transition from the power saving mode to the normal operating mode and after transitioning at least some of the volatile memory of the SSD device from the OFF state to an ON state at block 1020, dynamic information is transferred from the host memory to the volatile memory of the SSD device. In an embodiment, the SSD device transfers the dynamic information at block 1024 to restore the dynamic information to the volatile memory of the SSD device. For example, the SSD device controller 132 transfers dynamic information from the HMB 124 to the volatile memory of the SSD device 108 via the communication interface 112, according to an embodiment. In an embodiment, the HMB controller 180 transfers the dynamic information from the HMB 124 to the volatile memory of the SSD device 108 via the communication interface 112.
In an embodiment, transferring dynamic information from the host memory to the volatile memory of the SSD device at block 1024 comprises transferring the dynamic information that was transferred to the host memory at block 1008 back to the volatile memory of the SSD device.
In another embodiment, the method 1000 further comprises i) encrypting at least some of the dynamic information that is transferred to the host memory at block 1008, and ii) decrypting at least some of the dynamic information transferred from the host memory at block 1024.
In another embodiment, the method 1000 further comprises i) generating error detection information for at least some of the dynamic information that is transferred to the host memory at block 1008, and ii) using the error detection information to detect changes and/or errors in the at least some of the dynamic information that is transferred from the host memory at block 1024.
In another embodiment, the method 1000 further comprises i) encoding at least some of the dynamic information that is transferred to the host memory at block 1008 according to an error correction code, and ii) using the error correction code to correct changes and/or errors in the at least some of the dynamic information that is transferred from the host memory at block 1024.
At least some of the various blocks, operations, and techniques described above may be implemented utilizing hardware, a processor executing firmware instructions, a processor executing software instructions, or any combination thereof. When implemented utilizing a processor executing software or firmware instructions, the software or firmware instructions may be stored in any computer readable memory such as on a magnetic disk, an optical disk, or other storage medium, in a RAM or ROM or flash memory, processor, hard disk drive, optical disk drive, tape drive, etc. The software or firmware instructions may include machine readable instructions that, when executed by one or more processors, cause the one or more processors to perform various acts.
When implemented in hardware, the hardware may comprise one or more of discrete components, an integrated circuit, an application-specific integrated circuit (ASIC), a programmable logic device (PLD), etc.
While the present invention has been described with reference to specific examples, which are intended to be illustrative only and not to be limiting of the invention, changes, additions and/or deletions may be made to the disclosed embodiments without departing from the scope of the invention.
The present application is a continuation of U.S. application Ser. No. 17/469,450, filed on Sep. 8, 2021, entitled “Reduced Power Consumption by SSD Using Host Memory Buffer,” which claims the benefit of U.S. Provisional Patent Application No. 63/076,260, entitled “Reduced Lowest Power Consumption Using Host Memory Buffer (HMB) in SSD,” filed on Sep. 9, 2020. Both of the applications referenced above are hereby incorporated by reference herein their entireties.
Number | Name | Date | Kind |
---|---|---|---|
7814329 | Hutchison et al. | Oct 2010 | B1 |
8074112 | Chang et al. | Dec 2011 | B1 |
8856423 | Sutardja | Oct 2014 | B1 |
9081716 | Karmarkar | Jul 2015 | B1 |
9213401 | Sakarda | Dec 2015 | B2 |
9563382 | Hahn et al. | Feb 2017 | B2 |
11625173 | Therene | Apr 2023 | B1 |
20130031388 | Sakarda | Jan 2013 | A1 |
20130191582 | Shiwalkar et al. | Jul 2013 | A1 |
20140351675 | Tiziani | Nov 2014 | A1 |
20160026406 | Hahn et al. | Jan 2016 | A1 |
20170242606 | Maiko et al. | Aug 2017 | A1 |
20190179685 | Ki | Jun 2019 | A1 |
20220197368 | Liang et al. | Jun 2022 | A1 |
Number | Date | Country | |
---|---|---|---|
63076260 | Sep 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17469450 | Sep 2021 | US |
Child | 18132731 | US |