Storage controller and an operation method of the storage controller
US-2023185463-A1 · Jun 15, 2023 · US
US12131058B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-12131058-B2 |
| Application number | US-202217726755-A |
| Country | US |
| Kind code | B2 |
| Filing date | Apr 22, 2022 |
| Priority date | Apr 22, 2022 |
| Publication date | Oct 29, 2024 |
| Grant date | Oct 29, 2024 |
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.
A data storage device includes a memory device and a controller coupled to the memory device. The controller includes a decoder multiplexer (mux) module, a plurality of request/response channels coupled to the decoder mux module, an arithmetic pipeline module coupled to the plurality of request/response channels, an arbiter module coupled to the plurality of request/response channels and the arithmetic pipeline module, a mux/arbiter module coupled to the arithmetic pipeline module, a random access memory (RAM) access module coupled to the decoder mux module and the mux/arbiter module, and a RAM coupled to the mux/arbiter module. The controller is configured to determine a pipeline depth value and a calculation parallelism value of the arithmetic pipeline module and configure the arithmetic pipeline module based on the determining.
Opening claim text (preview).
What is claimed is: 1. A data storage device, comprising: a memory device; and a controller coupled to the memory device, wherein the controller comprises: a decoder module; a plurality of response channels coupled to the decoder module; an arithmetic pipeline module coupled to the plurality of response channels; an arbiter module coupled to the plurality of response channels and the arithmetic pipeline module; a mux module coupled to the arithmetic pipeline module; a random access memory (RAM) access module coupled to the decoder module and the mux module; and a RAM coupled to the mux module. 2. The data storage device of claim 1 , wherein the controller is configured to store static parameters and deliver the static parameters to the arithmetic pipeline module, wherein the arithmetic pipeline module is disposed in a calculation accelerator module of the controller. 3. The data storage device of claim 1 , wherein the controller is configured to determine a calculation configuration based on a received input and provide the calculation configuration to the arithmetic pipeline module of a calculation module of the controller. 4. The data storage device of claim 3 , wherein one or more static parameters are provided to the arithmetic pipeline module based on the calculation configuration. 5. The data storage device of claim 3 , wherein the calculation configuration comprises one or more definitions to set a structure of the arithmetic pipeline module and set an order of calculations of the arithmetic pipeline module. 6. The data storage device of claim 5 , wherein the structure of the arithmetic pipeline module is configurable based on calculation parallelism value and pipeline depth value, wherein the structure comprises a plurality of stages, and wherein a number of the plurality of stages is configurable based on the calculation parallelism value and the pipeline depth value. 7. The data storage device of claim 6 , wherein the controller is configured to, for each stage of the plurality of stages, perform a plurality of arithmetic calculations based on the order of calculations. 8. The data storage device of claim 7 , wherein results of the plurality of arithmetic calculations are provided to a next stage of the plurality of stages, and wherein last results of the plurality of arithmetic calculations are sent to the plurality of response channels. 9. The data storage device of claim 1 , wherein the controller is configured to use the plurality of response channels to activate the arithmetic pipeline module and to receive calculation results from the arithmetic pipeline module. 10. The data storage device of claim 1 , wherein the controller further comprises a plurality of central processing units (CPUs), and wherein each CPU is associated with a request/response channel of the plurality of response channels. 11. The data storage device of claim 1 , wherein the arbiter module is configured to: arbitrate between the plurality of response channels when a threshold number of outstanding requests of the arithmetic pipeline module is exceeded; and provide an outstanding request to the arithmetic pipeline module based on the arbitrating. 12. The data storage device of claim 1 , wherein the controller is configured to store configurations/databases that are greater than a threshold size in the RAM.
Improving or facilitating administration, e.g. storage management · CPC title
Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP] · CPC title
Improving I/O performance · CPC title
Command handling arrangements, e.g. command buffers, queues, command scheduling · 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
Related publications grouped by family.
Answers are generated from the same data shown on this page.