SLC cache management

US10545685B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10545685-B2
Application numberUS-201715690869-A
CountryUS
Kind codeB2
Filing dateAug 30, 2017
Priority dateAug 30, 2017
Publication dateJan 28, 2020
Grant dateJan 28, 2020

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Disclosed in some examples are memory devices which feature customizable Single Level Cell (SLC) and Multiple Level Cell (MLC) configurations. The SLC memory cells serve as a high-speed cache providing SLC level performance with the storage capacity of a memory device with MLC memory cells. The proportion of cells configured as MLC vs the proportion that are configured as SLC storage may be configurable, and in some examples, the proportion may change during usage based upon configurable rules based upon memory device metrics. In some examples, when the device activity is below an activity threshold, the memory device may skip the SLC cache and place the data directly into the MLC storage to reduce power consumption.

First claim

Opening claim text (preview).

The invention claimed is: 1. A memory device, the memory device comprising: an array of memory cells, the memory cells in the array configurable as either a multi-level cell (MLC) configuration or a single level cell (SLC) configuration; a controller, the controller executing firmware instructions, which cause the controller to perform operations comprising: receiving, from a host device, over a communications interface, a behavior profile for an SLC cache of the memory device, the behavior profile describing at least one of: one or more rules for determining, based upon a performance metric of the memory device, a size of the SLC cache or one or more rules for reconfiguring the SLC cache; configuring memory cells of the array as belonging either to an SLC cache pool or an MLC storage pool based upon the behavior profile; receiving a write command to write data to the memory device; writing the data to the SLC cache pool; and subsequent to writing the data to the SLC cache pool, transferring the data to the MLC storage pool; subsequent to transferring the data to the MLC storage pool, receiving, from the host device, over the communications interface, an updated behavior profile for the SLC cache of the memory device, and responsive to receiving the updated behavior profile, reconfiguring the memory cells of the array as belonging to an SLC cache pool or an MLC storage pool according to the updated behavior profile. 2. The memory device of claim 1 , wherein the communications interface is a Universal Flash Storage interface. 3. The memory device of claim 1 , wherein the behavior profile comprises a target logical block addressing (LBA) saturation threshold and a corresponding target size of the SLC cache, and wherein the operations further comprise: determining that a current LBA saturation exceeds the target LBA saturation threshold, and in response, adjusting the configuration of the memory cells in the array such that a number of the memory cells in the SLC cache produces an SLC cache size that is the target size. 4. The memory device of claim 1 , wherein the write command is received from a host over an interface implemented according to a Universal Flash Storage (UFS) standard. 5. The memory device of claim 1 , wherein the operations of receiving the behavior profile of the SLC cache of the memory device and configuring memory cells of the array as belonging either to the SLC cache pool or the MLC storage pool based upon the behavior profile are performed upon a first execution of a firmware object containing the firmware instructions. 6. The memory device of claim 1 , wherein the behavior profile comprises a target activity threshold and a corresponding target size of the SLC cache, and wherein the operations further comprise: determining that a current activity threshold exceeds the target activity threshold, and in response, adjusting the configuration of the memory cells in the array such that a number of the memory cells in the SLC cache produces an SLC cache size that is the target size. 7. The memory device of claim 1 , wherein the behavior profile includes a write activity threshold and wherein the operations further comprise: receiving a second write command to write second data to the memory device; and determining that write activity of the memory device is below the write activity threshold, and in response, writing the second data to the MLC storage pool, bypassing the SLC cache. 8. The memory device of claim 7 , wherein the write activity threshold is a number of pending write requests. 9. A method comprising: at a memory device comprising an array of memory cells, the memory cells in the array configurable as either a multi-level cell (MLC) configuration or a single level cell (SLC) configuration, using a controller, performing operations comprising: receiving, from a host device, over a communications interface, a behavior profile for an SLC cache of the memory device, the behavior profile describing at least one of: rules for determining, based upon a performance metric of the memory device, a size of the SLC cache or one or more rules for reconfiguring the SLC cache; configuring memory cells of the array as belonging either to an SLC cache pool or an MLC storage pool based upon the behavior profile; receiving a write command to write data to the memory device; writing the data to the SLC cache pool; and subsequent to writing the data to the SLC cache pool, transferring the data to the MLC storage pool; subsequent to transferring the data to the MLC storage pool, receiving, from the host device, over the communications interface, an updated behavior profile for the SLC cache of the memory device; and responsive to receiving the updated behavior profile, reconfiguring the memory cells of the array as belonging to an SLC cache pool or an MLC storage pool according to the updated behavior profile. 10. The method of claim 9 , wherein the communications interface is a Universal Flash Storage interface. 11. The method of claim 9 , wherein the behavior profile comprises a target logical block addressing (LBA) saturation threshold and a corresponding target size of the SLC cache, and wherein the operations further comprise: determining that a current LBA saturation exceeds the target LBA saturation threshold, and in response, adjusting the configuration of the memory cells in the array such that a number of the memory cells in the SLC cache produces an SLC cache size that is the target size. 12. The method of claim 9 , wherein the write command is received from a host over an interface implemented according to a Universal Flash Storage (UFS) standard. 13. The method of claim 9 , wherein the operations of receiving the behavior profile of the SLC cache of the memory device and configuring memory cells of the array as belonging either to the SLC cache pool or the MLC storage pool based upon the behavior profile are performed upon a first execution of a firmware object containing the firmware instructions. 14. The method of claim 9 , wherein the behavior profile comprises a target activity threshold and a corresponding target size of the SLC cache, and wherein the operations further comprise: determining that a current activity threshold exceeds the target activity threshold, and in response, adjusting the configuration of the memory cells in the array such that a number of the memory cells in the SLC cache produces an SLC cache size that is the target size. 15. The method of claim 9 , wherein the behavior profile includes a write activity threshold and wherein the operations further comprise: receiving a second write command to write second data to the memory device; and determining that write activity of the memory device is below the write activity threshold, and in response, writing the second data to the MLC storage pool, bypassing the SLC cache. 16. The method of claim 15 , wherein the write activity threshold is a number of pending write requests. 17. A machine-readable medium comprising instructions, that when executed by a machine, cause the machine to perform operations comprising: receiving, from a host device, over a communications interface, a behavior profile for an SLC cache of a memory device, the behavior profile describing at least one of: rules for determining, based upon a performance metric of the memory device, a size of the SLC cache or one or more rules for reconfiguring the SLC cache; configuring memory cells of an array of memory cells as belonging either to an SLC cache pool or an MLC storage pool based upon

Assignees

Inventors

Classifications

  • Temporary buffering, e.g. using volatile buffer or dedicated buffer blocks · CPC title

  • Allocation control and policies · CPC title

  • in block erasable memory, e.g. flash memory · CPC title

  • Plural cache memories · CPC title

  • Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10545685B2 cover?
Disclosed in some examples are memory devices which feature customizable Single Level Cell (SLC) and Multiple Level Cell (MLC) configurations. The SLC memory cells serve as a high-speed cache providing SLC level performance with the storage capacity of a memory device with MLC memory cells. The proportion of cells configured as MLC vs the proportion that are configured as SLC storage may be con…
Who is the assignee on this patent?
Micron Technology Inc
What technology area does this patent fall under?
Primary CPC classification G06F12/0246. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jan 28 2020 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).