Hybrid main memory using a fine-grain level of remapping
US-9898410-B2 · Feb 20, 2018 · US
US11093406B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-11093406-B2 |
| Application number | US-202016846673-A |
| Country | US |
| Kind code | B2 |
| Filing date | Apr 13, 2020 |
| Priority date | Apr 17, 2017 |
| Publication date | Aug 17, 2021 |
| Grant date | Aug 17, 2021 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
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.
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.
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
Improving or facilitating administration, e.g. storage management · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.