Storage system with multiple components and method for use therewith

US11211141B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11211141-B2
Application numberUS-202016888622-A
CountryUS
Kind codeB2
Filing dateMay 29, 2020
Priority dateAug 26, 2016
Publication dateDec 28, 2021
Grant dateDec 28, 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.

A storage system with several integrated components and method for use therewith are provided. In one embodiment, a storage system comprising: a plurality of non-volatile memory devices; a controller in communication with the plurality of non-volatile memory devices; a plurality of data buffers in communication with the controller and configured to store data sent between the controller and an input/output bus; and a command and address buffer configured to store commands and addresses sent from a host, wherein the command and address buffer is further configured to synchronize data flow into and out of the plurality of data buffer; wherein at least three of the above components are integrated with each other.

First claim

Opening claim text (preview).

What is claimed is: 1. A storage system, comprising: non-volatile memories; data buffers; a driver; and a controller; wherein the controller is configured to determine whether a host and the storage system have agreed to use, for data to be read from the non-volatile memories, non-deterministic reads or deterministic reads, wherein when the controller determines that the host and the storage system have agreed to use the non-deterministic reads, the controller is configured to cause holding each data read, from the non-volatile memories, for a send command to be received from the host, and preventing transmission of the each read data to the host until receiving the respective send command, otherwise, the controller is configured to determine that the host and the storage system have agreed to use the deterministic reads, and the controller is configured to cause transmitting the each read data, from the non-volatile memories, to the host when an elapsed time does not exceed a pre-determined time, wherein the driver is configured to receive, from the host, a read command, an address and a read identifier, configured to provide, to the controller, the read command, the address and the read identifier, and configured to provide, to the data buffers, the read command and the read identifier but not the address, wherein the controller is configured to read requested data from the non-volatile memories and configured to provide the requested data and the read identifier to the data buffers, and wherein the data buffers are configured to place the requested data into an allocated space identified by the read identifier, for transmission to the host. 2. The storage system of claim 1 , wherein the non-deterministic reads are defined to complete transmitting the each read data to the host irrespective of the pre-determined time, and wherein the deterministic reads are defined to complete transmitting the each read data to the host only within the pre-determined time. 3. The storage system of claim 1 , comprising: one or more first memories configured to store data sent between the controller and an input/output interface; and at least one second memory configured to store commands received from the host, wherein the one or more first memories are configured to be used for the non-deterministic reads and for the deterministic reads, and wherein the at least one second memory is configured to be used for the non-deterministic reads and for the deterministic reads. 4. The storage system of claim 1 , wherein when the host and the storage system have agreed to use the non-deterministic reads, for all data to be read from the non-volatile memories for transmission to the host, then with respect to determining when to transmit the each read data, the controller is prevented from using, a determination whether the elapsed time exceeds the pre-determined time, to transmit the each read data to the host, and wherein when the host and the storage system have agreed to use the deterministic reads, for all the data to be read from the non-volatile memories for transmission to the host, then with respect to determining when to transmit the each read data, the controller is prevented from using, the respective send command received, to transmit the each read data to the host. 5. The storage system of claim 1 , wherein physical and command layers of the storage system are configured to be compatible with one or more of the following: unbuffered dual in-line memory module, registered dual in-line memory module, and load-reduced dual in-line memory module, and wherein the controller is configured to communicate with the host using a clock-data parallel interface, and wherein the driver is a registered clock driver. 6. The storage system of claim 1 , wherein the controller is configured to cause: receiving a write command from the host, wherein the host is allowed only a certain number of outstanding write commands as tracked by a write counter in the host; performing an operation having an undetermined duration from a perspective of the host; writing data to the non-volatile memories; and after the data to the non-volatile memories has been written, sending a write counter increase signal to the host. 7. The storage system of claim 1 , wherein the pre-determined time has been agreed by the host and the storage system, and wherein the controller is configured to determine whether the host and the storage system have agreed to use either the non-deterministic reads for all data to be read from the non-volatile memories, or the deterministic reads for all data to be read from the non-volatile memories. 8. The storage system of claim 1 , wherein the data buffers are configured to allocate space before receiving the requested data and configured to reference the allocated space with the read identifier, wherein the controller is configured to provide, to the driver, a completion signal and the read identifier, and wherein the driver is configured to provide, to the host, a ready signal and the read identifier, configured to receive a corresponding send command from the host, and in response, configured to send a request to the controller to have the data buffers transmit, to the host, the requested data associated with the read identifier. 9. The storage system of claim 1 , wherein the data buffers have the allocated space having an identifier correlated to the read identifier within the driver, wherein the controller is configured to provide, to the driver, a completion signal and the read identifier, and wherein the driver is configured to provide, to the host, a ready signal and the read identifier, configured to receive a corresponding send command from the host, and in response, configured to send a request to the controller to have the data buffers transmit, to the host, the requested data associated with the read identifier. 10. The storage system of claim 8 , wherein the storage system comprises a response buffer, wherein the data buffers are configured to allocate space before receiving the requested data and configured to reference the allocated space with the read identifier, wherein the response buffer is configured to provide, to the host, a ready signal, wherein the driver is configured to receive a corresponding send command from the host, and in response, configured to send a request to the controller to have the data buffers transmit, to the host, the requested data associated with the read identifier. 11. A method for a storage system comprising non-volatile memories, data buffers, a driver and a controller and, the method comprising: determining, by the controller, whether a host and the storage system have agreed to use, for data to be read from the non-volatile memories, non-deterministic reads or deterministic reads, wherein the determining comprises determining, by the controller, that the host and the storage system have agreed to use the non-deterministic reads but not the deterministic reads, and the controller performs operations comprising: holding each data read, from the non-volatile memories, for a send command to be received from the host; and preventing transmission of the each read data to the host until receiving the respective send command, wherein the storage system comprises one or more first memories, and the method comprises storing, in the one or more first memories, the each data read from the non-volatile memories for the non-deterministic reads, wherein the one or more first memories are used for the non-deterministic reads and are to be used for the deterministic reads, and wherein the method comprises: receiving, by the

Assignees

Inventors

Classifications

  • G11C29/52Primary

    Protection of memory contents; Detection of errors in memory contents · CPC title

  • Supports for storage elements {, e.g. memory modules}; Mounting or fixing of storage elements on such supports · CPC title

  • using arrangements adapted for a specific error detection or correction feature · CPC title

  • in relation to life time, e.g. increasing Mean Time Between Failures [MTBF] · CPC title

  • Data buffering arrangements · 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 US11211141B2 cover?
A storage system with several integrated components and method for use therewith are provided. In one embodiment, a storage system comprising: a plurality of non-volatile memory devices; a controller in communication with the plurality of non-volatile memory devices; a plurality of data buffers in communication with the controller and configured to store data sent between the controller and an …
Who is the assignee on this patent?
Sandisk Technologies Llc
What technology area does this patent fall under?
Primary CPC classification G11C29/52. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Dec 28 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 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).