Flushing pages from solid-state storage device

US10417137B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10417137-B2
Application numberUS-201715712483-A
CountryUS
Kind codeB2
Filing dateSep 22, 2017
Priority dateSep 23, 2016
Publication dateSep 17, 2019
Grant dateSep 17, 2019

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.

Embodiments of the present disclosure relate to a method and device for flushing pages from a solid-state storage device. Specifically, the present disclosure discloses a method of flushing pages from a solid-state storage device comprising: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and flushing pages from the solid-state storage device with an upper limit of the first number in the flushing cycle. The present disclosure also discloses a device for flushing pages from a solid-state storage device and a computer program product for implementing steps of a method of flushing pages from a solid-state storage device.

First claim

Opening claim text (preview).

We claim: 1. A method of flushing pages from a solid-state storage device, comprising: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of the first number. 2. The method according to claim 1 , further comprising: determining, based on a central processing unit (CPU) time, a start time and an end time of building the flushing transaction; and determining, based on a difference between the start time and the end time, the period length required for building the flushing transaction. 3. The method according to claim 1 , further comprising: determining a second number based on a response time of the solid-state storage device to one flushing transaction, the second number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of a smaller one of the first and second numbers. 4. The method according to claim 1 , wherein flushing the pages comprises: in response to a page to be flushed being a clean page, invalidating metadata corresponding to the page; and in response to the page to be flushed being a dirty page, copying data of the page into a hard disk; and invalidating the metadata corresponding to the page. 5. The method according to claim 4 , wherein copying the data of the page into the hard disk comprises: determining a third number based on a response time of the hard disk to one flushing transaction, the third number indicating a maximum number of flushing transactions that can be executed in parallel in the hard disk during the flushing cycle; and during the flushing cycle, flushing the page into the hard disk with an upper limit of the third number. 6. The method according to claim 4 , further comprising: maintaining a first list and a second list in the solid-state storage device, the first list indicating clean pages, and the second list indicating dirty pages; and performing the flushing of the pages using the first list and the second list. 7. The method according to claim 4 , wherein the flushing of the clean page precedes the flushing of the dirty page. 8. An electronic device comprising: a processor; and a memory coupled to the processor and storing instructions executable by the processor, the instructions, when being executed by the processor, causing the electronic device to: determine a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and during the flushing cycle, flush pages from a solid-state storage device with an upper limit of the first number. 9. The electronic device according to claim 8 , wherein the instructions, when being executed by the processor, further cause the electronic device to: determine, based on a central processing unit (CPU) time, a start time and an end time of building the flushing transaction; and determine, based on a difference between the start time and the end time, the period length required for building the flushing transaction. 10. The electronic device according to claim 8 , wherein the instructions, when being executed by the processor, further cause the electronic device to: determine a second number based on a response time of the solid-state storage device to one flushing transaction, the second number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushing cycle, flush the pages from the solid-state storage device with an upper limit of a smaller one of the first number and the second number. 11. The electronic device according to claim 8 , wherein the instructions causing the electronic device to flush the pages include instructions causing the electronic device to: in response to a page to be flushed being a clean page, invalidate metadata corresponding to the page; and in response to the page to be flushed being a dirty page, copy data of the page into a hard disk; and invalidate metadata corresponding to the page. 12. The electronic device according to claim 11 , wherein the instructions causing the electronic device to copy the data of the page into the hard disk include instructions causing the electronic device to: determine a third number based on a response time of the hard disk to one flushing transaction, the third number indicating a maximum number of flushing transactions that can be executed in parallel in the hard disk during the flushing cycle; and during the flushing cycle, flush the page into the hard disk with an upper limit of the third number. 13. The electronic device according to claim 11 , wherein the instructions, when being executed by the processor, further cause the electronic device to: maintain a first list and a second list in the solid-state storage device, the first list indicating clean pages, and the second list indicating dirty pages; and perform the flushing of the pages using the first list and the second list. 14. The electronic device according to claim 11 , wherein the instructions causing the electronic device to flush the pages include instructions causing the electronic device to perform the flushing of the clean page before the flushing of the dirty page. 15. A computer program product for flushing pages from a solid-state storage device, the computer program product comprising: a non-transitory computer readable medium encoded with computer-executable program code for flushing pages from the solid-state storage device, the code configured to enable the execution of: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first number indicating a maximum number of flushing transactions that can be built in the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of the first number. 16. The computer program product according to claim 15 , wherein the code is further configured to enable the execution of: determining, based on a central processing unit (CPU) time, a start time and an end time of building the flushing transaction; and determining, based on a difference between the start time and the end time, the period length required for building the flushing transaction. 17. The computer program product according to claim 15 , wherein the code is further configured to enable the execution of: determining a second number based on a response time of the solid-state storage device to one flushing transaction, the second number indicating a maximum number of flushing transactions that can be executed in parallel in the solid-state storage device during the flushing cycle; and during the flushing cycle, flushing the pages from the solid-state storage device with an upper limit of a smaller one of the first and second numbers. 18. The computer program product according to claim 15 , wherein flushing the pages comprises: in response to a page to be flushe

Assignees

Inventors

Classifications

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 US10417137B2 cover?
Embodiments of the present disclosure relate to a method and device for flushing pages from a solid-state storage device. Specifically, the present disclosure discloses a method of flushing pages from a solid-state storage device comprising: determining a first number based on a period length of one flushing cycle and a period length required for building one flushing transaction, the first num…
Who is the assignee on this patent?
Emc Ip Holding Co Llc
What technology area does this patent fall under?
Primary CPC classification G06F12/0804. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Sep 17 2019 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).