Method and device for storage management

US11093406B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11093406-B2
Application numberUS-202016846673-A
CountryUS
Kind codeB2
Filing dateApr 13, 2020
Priority dateApr 17, 2017
Publication dateAug 17, 2021
Grant dateAug 17, 2021

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.

In a method and apparatus for storage management, a method includes: creating a plurality of profiles for address mapping, the profiles comprising a part of mapping relation in the total mapping table and creating an index for a part of the plurality of profiles to accelerate the lookup speed. A corresponding device and computer program product are also disclosed.

First claim

Opening claim text (preview).

We claim: 1. A method of storage management, comprising: creating profiles for address mapping and storing the profiles in a cache, each profile containing a part of an address mapping table stored on a non-volatile storage device and indicating (1) a logical starting address of an initial logical block of a plurality of logical blocks, (2) a physical starting address corresponding to the logical starting address, and (3) the number of the plurality of logical blocks, the profiles being stored in the cache in an order of the corresponding logical starting addresses; creating first and second records for respective first and second physical extents, each record indicating a physical starting address of the respective physical extent and number of physical blocks therein, at least a part of the plurality of logical blocks being indicated by first and second profiles each being mapped to the respective first and second physical extents; and in response to a physical end address of the first physical extent and a physical starting address of the second physical extent being continuous, merging the first record and the second record to generate a third record and storing the third record in the cache, the third record indicating the physical starting address of the first physical extent and a sum of the numbers of physical blocks from the first and second records. 2. The method of claim 1 , further including creating an index for a part of the plurality of profiles in the cache, comprising: selecting the part of profiles randomly to create the index. 3. The method of claim 1 , further including creating an index for a part of the plurality of profiles in the cache, comprising: selecting, based on an access frequency, the part of profiles to create the index. 4. The method of claim 1 , further comprising: in response to the physical end address of the first physical extent and the physical starting address of the second physical extent being non-continuous, storing the first record and the second record in the cache. 5. The method of claim 1 , further comprising: receiving a request for a target profile, the request indicating an index associated with the target profile; and searching the target profile in the cache based on the index. 6. The method of claim 5 , further comprising: in response to the target profile being absent in the cache, creating the target profile based on the address mapping table. 7. The method of claim 6 , wherein the request comprises a request to modify a part of the address mapping table contained in the target profile, and the method further comprises: in response to the target profile being present in the cache, updating the part of the address mapping table contained in the target profile. 8. The method of claim 1 , further comprising: in response to the number of idle profiles in the cache being lower than a first threshold, triggering reclaiming of the plurality of profiles; and in response to the number of idle profiles in the cache being greater than a second threshold, ceasing the reclaiming. 9. The method of claim 8 , wherein triggering reclaiming of the plurality of profiles comprises: reclaiming, among the plurality of profiles, profiles not having been changed with respect to the address mapping table. 10. The method of claim 8 , wherein triggering reclaiming of the plurality of profiles comprises: reclaiming, among the plurality of profiles, profiles having been changed with respect to the address mapping table, comprising: storing, in the non-volatile storage device, changed address mapping in the changed profiles. 11. The method of claim 8 , further comprising: removing an index of a reclaimed profile. 12. An electronic device, comprising: a processor; and a memory coupled to the processor, the memory having instructions stored therein which, when executed by the processor, cause the electronic device to perform acts comprising: creating profiles for address mapping and storing the profiles in a cache, each profile containing a part of an address mapping table stored on a non-volatile storage device and indicating (1) a logical starting address of an initial logical block of a plurality of logical blocks, (2) a physical starting address corresponding to the logical starting address, and (3) the number of the plurality of logical blocks, the profiles being stored in the cache in an order of the corresponding logical starting addresses; creating first and second records for respective first and second physical extents, each record indicating a physical starting address of the respective physical extent and number of physical blocks therein, at least a part of the plurality of logical blocks being indicated by first and second profiles each being mapped to the respective first and second physical extents; and in response to a physical end address of the first physical extent and a physical starting address of the second physical extent being continuous, merging the first record and the second record to generate a third record and storing the third record in the cache, the third record indicating the physical starting address of the first physical extent and a sum of the numbers of physical blocks from the first and second records. 13. The device of claim 12 , wherein the acts further include creating an index for a part of the plurality of profiles in the cache, comprising: selecting the part of profiles randomly to create the index. 14. The device of claim 12 , wherein the acts further include creating an index for a part of the plurality of profiles in the cache, comprising: selecting, based on an access frequency, the part of profiles to create the index. 15. The device of claim 12 , wherein the acts further comprise: in response to the physical end address of the first physical extent and the physical starting address of the second physical extent being non-continuous, storing the first record and the second record in the cache. 16. The device of claim 12 , wherein the acts further comprise: receiving a request for a target profile, the request indicating an index associated with the target profile; searching the target profile in the cache based on the index. 17. The device of claim 16 , wherein the acts further comprise: in response to the target profile being absent in the cache, creating the target profile based on the address mapping table. 18. The device of claim 17 , wherein the request comprises a request to modify a part of the address mapping table contained in the target profile, and the acts further comprise: in response to the target profile being present in the cache, updating the part of the address mapping table contained in the target profile. 19. The device of claim 12 , wherein the acts further comprise: in response to the number of idle profiles in the cache being lower than a first threshold, triggering reclaiming of the plurality of profiles; in response to the number of idle profiles in the cache being greater than a second threshold, ceasing the reclaiming. 20. The device of claim 12 , wherein the acts further comprise: reclaiming, among the plurality of profiles, profiles not having been changed with respect to the address mapping table.

Assignees

Inventors

Classifications

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

  • Organizing or formatting or addressing of data · CPC title

  • Virtual address space management · CPC title

  • using page tables, e.g. page table structures · CPC title

  • G06F3/0604Primary

    Improving or facilitating administration, e.g. storage management · 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 US11093406B2 cover?
In a method and apparatus for storage management, a method includes: creating a plurality of profiles for address mapping, the profiles comprising a part of mapping relation in the total mapping table and creating an index for a part of the plurality of profiles to accelerate the lookup speed. A corresponding device and computer program product are also disclosed.
Who is the assignee on this patent?
Emc Ip Holding Co Llc
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 Aug 17 2021 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 2 related publications on this page (citations in our corpus or others sharing the same primary CPC).