I/O device and computing host interoperation
First Claim
1. A method comprising:
- at a storage device and from a computing host, receiving a command comprising a specification, the specification comprising at least one of a plurality of non-standard specifications, the non-standard specifications comprising one or more non-standard command modifiers; and
in response to the specification comprising a particular one of the non-standard command modifiers, executing the command according to the particular non-standard command modifier, and storing an indication of the particular non-standard command modifier in an entry of a map associated with a logical block address (LBA) of the command,wherein at least one of the non-standard specifications identifies a particular one of a plurality of data destinations, the data destinations comprising a plurality of data bands,wherein the data bands are dynamically changeable in number, arrangement, size and type and correspond to one or more of a database journal data band, a hot data band, and a cold data band,wherein the database journal data band is reserved for database journal type data,wherein in response to the computing host writing a relatively long sequential stream, the hot data band grows in size, andwherein a shadow copy of the map is stored in a memory of the computing host.
5 Assignments
0 Petitions
Accused Products
Abstract
An I/O device is coupled to a computing host. In some embodiments, the device is enabled to utilize memory of the computing host not directly coupled to the device to store information such as a shadow copy of a map of the device and/or state of the device. Storage of the shadow copy of the map enables one or both of the device and the computing host to utilize the shadow copy of the map, such as to decrease read latency. Storage of the state enables the device to save volatile state that would otherwise be lost when the device enters a low-power state. In some embodiments, the device implements one or more non-standard modifiers of standard commands. The non-standard modifiers modify the execution of the standard commands, providing features not present in a host protocol having only the standard commands.
-
Citations
22 Claims
-
1. A method comprising:
-
at a storage device and from a computing host, receiving a command comprising a specification, the specification comprising at least one of a plurality of non-standard specifications, the non-standard specifications comprising one or more non-standard command modifiers; and in response to the specification comprising a particular one of the non-standard command modifiers, executing the command according to the particular non-standard command modifier, and storing an indication of the particular non-standard command modifier in an entry of a map associated with a logical block address (LBA) of the command, wherein at least one of the non-standard specifications identifies a particular one of a plurality of data destinations, the data destinations comprising a plurality of data bands, wherein the data bands are dynamically changeable in number, arrangement, size and type and correspond to one or more of a database journal data band, a hot data band, and a cold data band, wherein the database journal data band is reserved for database journal type data, wherein in response to the computing host writing a relatively long sequential stream, the hot data band grows in size, and wherein a shadow copy of the map is stored in a memory of the computing host. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A method comprising:
-
at a storage device and from a computing host, receiving a command comprising a specification, the specification comprising at least one of a plurality of non-standard specifications, the non-standard specifications comprising one or more non-standard command modifiers; in response to the specification comprising a particular one of the non-standard command modifiers, executing the command according to the particular non-standard command modifier, the executing of the command according to the particular non-standard command modifier comprising storing an indication of the non-standard command modifier with data of the command in an entry of a map associated with a logical block address (LBA) of the command; and subsequent to the executing the command and without having received a trim command, accessing the indication to determine to trim, rather than to recycle, all or any portions of the data, wherein at least one of the non-standard specifications identifies a particular one of a plurality of data destinations, the data destinations comprising a plurality of data bands, wherein the data bands are dynamically changeable in number, arrangement, size and type and correspond to one or more of a database journal data band, a hot data band, and a cold data band, wherein the hot data band is used at least for data originating from the computing host, wherein in response to the computing host writing a relatively long sequential stream, the hot data band grows in size, and wherein a shadow copy of the map is stored in a memory of the computing host. - View Dependent Claims (9, 10, 11)
-
-
12. A storage device comprising:
-
an external interface configured to receive a command from a computing host, the command comprising a specification, the specification comprising at least one of a plurality of non-standard specifications, the non-standard specifications comprising one or more non-standard command modifiers; and a storage controller configured to execute, in response to the specification comprising a particular one of the non-standard command modifiers, the command according to the particular non-standard command modifier, and to store an indication of the particular non-standard command modifier in an entry of a map associated with a logical block address (LBA) of the command, wherein at least one of the non-standard specifications identifies a particular one of a plurality of data destinations, the data destinations comprising a plurality of data bands, wherein the data bands are dynamically changeable in number, arrangement, size and type and correspond to one or more of a database journal data band, a hot data band, and a cold data band, wherein the hot data band is used at least for data originating from the computing host, wherein in response to the computing host writing a relatively long sequential stream, the hot data band grows in size, and wherein a shadow copy of the map is stored in a memory of the computing host. - View Dependent Claims (13, 14, 15, 16, 17, 18)
-
-
19. A storage device comprising:
-
an external interface configured to receive a command from a computing host, the command comprising a specification, the specification comprising at least one of a plurality of non-standard specifications, the non-standard specifications comprising one or more non-standard command modifiers; and a storage controller configured to execute, in response to the specification comprising a particular one of the non-standard command modifiers, the command according to the particular non-standard command modifier, the storage controller executing the command according to the particular non-standard command modifier further configured to store an indication of the non-standard command modifier with data of the command in an entry of a map associated with a logical block address (LBA) of the command, wherein the storage controller is further configured to, subsequent to the executing the command and without having received a trim command, access the indication to determine to trim, rather than to recycle, at least one portion of the data, wherein at least one of the non-standard specifications identifies a particular one of a plurality of data destinations, the data destinations comprising a plurality of data bands, wherein the data bands are dynamically changeable in number, arrangement, size and type and correspond to one or more of a database journal data band, a hot data band, and a cold data band, wherein the hot data band is used at least for data originating from the computing host, wherein in response to the computing host writing a relatively long sequential stream, the hot data band grows in size, and wherein a shadow copy of the map is stored in a memory of the computing host. - View Dependent Claims (20, 21, 22)
-
Specification