Storage module and host device for storage module defragmentation

US9658777B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9658777-B2
Application numberUS-201414249049-A
CountryUS
Kind codeB2
Filing dateApr 9, 2014
Priority dateFeb 5, 2014
Publication dateMay 23, 2017
Grant dateMay 23, 2017

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.

A storage module and host device for storage module defragmentation are disclosed. In one embodiment, a host controller sends a storage module a first set of logical block addresses of a file stored in the storage module. The host controller receives a metric from the storage module indicative of a fragmentation level of the file in physical blocks of memory in the storage module. If the metric is greater than a threshold, the host controller reads the file and then writes it back to the storage module using a different set of logical block addresses. To avoid sending the file back and forth, in another embodiment, the host controller sends the fragmentation threshold and the different set of logical block addresses to the storage module. The storage module then moves the file itself if the metric indicative of the fragmentation level is greater than the threshold. Other embodiments are provided.

First claim

Opening claim text (preview).

What is claimed is: 1. A storage module comprising: a memory; and a storage controller operatively in communication with the memory, wherein the storage controller is configured to: receive, from a host controller, a query for a metric indicative of a level of fragmentation of a file stored in the memory, wherein the query comprises a first set of logical block addresses of the file; generate the metric indicative of the level of fragmentation level of the file in physical blocks of the memory in the storage module; send the metric to the host controller; and receive, from the host controller, a second set of logical block addresses in the memory for a new location of the file and an instruction as to what writing mode to use to write the file to the memory. 2. The storage module of claim 1 , wherein the metric comprises a number of physical blocks in the storage module containing the file. 3. The storage module of claim 1 , wherein the metric comprises a hot/cold indication. 4. The storage module of claim 1 , wherein the metric comprises a mapping efficiency indication. 5. The storage module of claim 1 , wherein the storage controller is further configured to: receive an indication that multiple non-consecutive logical block address ranges are part of the file. 6. The storage module of claim 5 , wherein a command is used by the host controller to indicate to the storage module when multiple non-consecutive logical block address ranges are part of the same file. 7. The storage module of claim 5 , wherein the indication that multiple non-consecutive logical block address ranges are part of the file comprises a flag. 8. The storage module of claim 5 , wherein the indication is sent after the host controller allocates a logical block address range and determines, for each contiguous extent, whether new data is written to the extent. 9. The storage module of claim 1 , wherein the memory of the storage module is a three-dimensional memory. 10. The storage module of claim 1 , wherein the storage module is embedded in a host containing the host controller. 11. The storage module of claim 1 , wherein the storage module is removably connected to a host containing the host controller. 12. The storage module of claim 1 , wherein the storage module is a solid-state drive. 13. A method for storage module defragmentation, the method comprising: performing the following in a storage module operatively in communication with a host controller and comprising a memory: receiving, from the host controller, a query for a metric indicative of a level of fragmentation of a file stored in the storage module, wherein the query comprises a first set of logical block addresses of the file; generating the metric indicative of the level of fragmentation level of the file in physical blocks of the memory in the storage module; sending the metric to the host controller; and receiving, from the host controller, a second set of logical block addresses for a new location of the file and an instruction as to what writing mode to use to write the file to the memory. 14. The method of claim 13 , wherein the metric comprises a number of physical blocks in the storage module containing the file. 15. The method of claim 13 , wherein the metric comprises a hot/cold indication. 16. The method of claim 13 , wherein the metric comprises a mapping efficiency indication. 17. The method of claim 13 further comprising: receiving an indication that multiple non-consecutive logical block address ranges are part of the file. 18. The method of claim 17 , wherein a command is used by the host controller to indicate to the storage module when multiple non-consecutive logical block address ranges are part of the same file. 19. The method of claim 17 , wherein the indication that multiple non-consecutive logical block address ranges are part of the file comprises a flag. 20. The method of claim 17 , wherein the indication is sent after the host controller allocates a logical block address range and determines, for each contiguous extent, whether new data is written to the extent. 21. The method of claim 13 , wherein the memory of the storage module is a three-dimensional memory. 22. The method of claim 13 , wherein the storage module is embedded in a host containing the host controller. 23. The method of claim 13 , wherein the storage module is removably connected to a host containing the host controller. 24. The method of claim 13 , wherein the storage module is a solid-state drive. 25. A host device comprising: an interface through which to operatively communicate with a storage module comprising a memory; and a controller operatively in communication with the interface, wherein the controller is configure to: send, to the storage module, a query for a metric indicative of a level of fragmentation of a file stored in the storage module, wherein the query comprises a first set of logical block addresses of the file; receive, from the storage module, the metric indicative of the level of fragmentation level of the file in physical blocks of the memory in the storage module; and send, to the storage module, a second set of logical block addresses for a new location of the file and an instruction as to what writing mode to use to write the file to the memory. 26. The host device of claim 25 , wherein the metric comprises a number of physical blocks in the storage module containing the file. 27. The host device of claim 25 , wherein the metric comprises a hot/cold indication. 28. The host device of claim 25 , wherein the metric comprises a mapping efficiency indication. 29. The host device of claim 25 , wherein the controller is further configured to: send an indication that multiple non-consecutive logical block address ranges are part of the file. 30. The host device of claim 29 , wherein a command is used by the host device to indicate to the storage module when multiple non-consecutive logical block address ranges are part of the same file. 31. The host device of claim 29 , wherein the indication that multiple non-consecutive logical block address ranges are part of the file comprises a flag. 32. The host device of claim 29 , wherein the indication is sent after the host controller allocates a logical block address range and determines, for each contiguous extent, whether new data is written to the extent. 33. The host device of claim 25 , wherein the memory of the storage module is a three-dimensional memory. 34. The host device of claim 25 , wherein the storage module is embedded in the host device. 35. The host device of claim 25 , wherein the storage module is removably connected to the host device. 36. The host device of claim 25 , wherein the storage module is a solid-state drive. 37. A method for storage module defragmentation, the method comprising: performing the following in a host controller operatively in communication with a storage module comprising a memory: sending, to the storage module, a query for a metric indicative of a level of fragmentation of a file stored in the storage module, wherein the query comprises a first set of logical block addresses of the file; receiving, from th

Assignees

Inventors

Classifications

  • Details of de-fragmentation performed by the file system (saving storage space on storage systems G06F3/0608; management of blocks in storage devices G06F3/064) · CPC title

  • G06F3/061Primary

    Improving I/O performance · CPC title

  • One time programmable [OTP] memory, e.g. PROM, WORM · CPC title

  • Management of files · CPC title

  • Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP] · 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 US9658777B2 cover?
A storage module and host device for storage module defragmentation are disclosed. In one embodiment, a host controller sends a storage module a first set of logical block addresses of a file stored in the storage module. The host controller receives a metric from the storage module indicative of a fragmentation level of the file in physical blocks of memory in the storage module. If the metric…
Who is the assignee on this patent?
Sandisk Technologies Llc
What technology area does this patent fall under?
Primary CPC classification G06F3/061. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue May 23 2017 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).