US20120265962A1 - High-performance sas target - Google Patents
High-performance sas target Download PDFInfo
- Publication number
- US20120265962A1 US20120265962A1 US13/439,863 US201213439863A US2012265962A1 US 20120265962 A1 US20120265962 A1 US 20120265962A1 US 201213439863 A US201213439863 A US 201213439863A US 2012265962 A1 US2012265962 A1 US 2012265962A1
- Authority
- US
- United States
- Prior art keywords
- storage
- data
- memory
- command
- hash
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B5/00—Recording by magnetisation or demagnetisation of a record carrier; Reproducing by magnetic means; Record carriers therefor
- G11B5/02—Recording, reproducing, or erasing methods; Read, write or erase circuits therefor
- G11B5/09—Digital recording
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0661—Format or protocol conversion arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0611—Improving I/O performance in relation to response time
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0617—Improving the reliability of storage systems in relation to availability
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0619—Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/068—Hybrid storage device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0688—Non-volatile semiconductor memory arrays
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0689—Disk arrays, e.g. RAID, JBOD
Definitions
- the present invention relates generally to data storage, and particularly to methods and systems for enhanced data storage using serial storage protocols.
- SSDs Solid State Drives
- SAS Serial Attached SCSI
- the SCSI protocol is described, for example, in “Information Technology—SCSI Architecture Model—5 (SAM-5),” INCITS document T10/2104-D, revision 01, Jan. 28, 2009, which is incorporated herein by reference.
- the SAS protocol is described, for example, in “Information Technology—Serial Attached SCSI—2 (SAS-2),” INCITS document T10/1760-D, revision 15a, Feb. 22, 2009, which is incorporated herein by reference.
- An embodiment of the present invention that is described herein provides a method for data storage.
- the method includes pre-configuring a hardware-implemented front-end of a storage device with multiple contexts of respective connections conducted between one or more hosts and the storage device.
- Storage commands which are received in the storage device and are associated with the connections having the pre-configured contexts, are executed in a memory of the storage device using the hardware-implemented front-end.
- software of the storage device is triggered to configure the context in the hardware-implemented front-end, and the storage command is then executed using the hardware-implemented front-end in accordance with the context configured by the software.
- the storage commands are received in accordance with a Serial Attached Storage (SAS) storage protocol.
- the storage device includes a Solid State Disk (SSD).
- triggering the software includes issuing an interrupt to a Central Processing Unit (CPU) that runs the software.
- triggering the software includes causing the software to replace a previously-configured context in the hardware-implemented front-end with the context associated with the identified storage command.
- executing the storage commands includes carrying out the storage commands without involvement of the CPU.
- a data storage apparatus including a CPU and a hardware-implemented front-end.
- the hardware-implemented front-end is pre-configured with multiple contexts of respective connections conducted between one or more hosts and the apparatus, and is arranged to execute in a memory of the apparatus storage commands that are received in the apparatus and are associated with the connections having the pre-configured contexts, and, upon identifying a storage command associated with a context that is not pre-configured in the hardware-implemented front-end, to trigger software running in the CPU to configure the context in the hardware-implemented front-end, and then to execute the storage command in accordance with the context configured by the software.
- a method for data storage includes, in a hardware-implemented front-end of a storage device, opening at least one connection, executing in a memory of the storage device storage commands associated with at least one connection, closing the at least one connection after executing the storage commands, and caching one or more contexts of respective one or more connections that were most recently closed.
- a storage command associated with a given connection that is not currently open is received.
- the given connection is checked against the cached contexts.
- the given connection Upon identifying that the given connection is one of the one or more connections that were most recently closed, the given connection is re-opened using one of the cached contexts and the storage command is executed using the hardware-implemented front-end in accordance with the one of the contexts.
- the storage commands are received in accordance with a SAS storage protocol.
- the storage device includes a SSD.
- closing the at least one connection includes closing each connection following a predefined inactivity period on the connection.
- executing the storage commands includes carrying out the storage commands without involvement of a CPU of the storage device.
- a data storage apparatus including an interface and a hardware-implemented front-end.
- the interface is arranged to communicate with one or more hosts.
- the hardware-implemented front-end is arranged to open at least one connection, to execute in a memory of the apparatus storage commands associated with the at least one connection, to close the at least one connection after executing the storage commands, to cache one or more contexts of respective one or more connections that were most recently closed, to receive a storage command associated with a given connection that is not currently open, to check the given connection against the cached contexts, and, upon identifying that the given connection is one of the one or more connections that were most recently closed, to re-open the given connection using one of the cached contexts and to execute the storage command in accordance with the one of the cached contexts.
- a method for data storage in a storage device that communicates with a host over a storage interface for executing a storage command in a memory of the storage device.
- the method includes estimating an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface.
- a data size to be prefetched from the memory, in order to complete uninterrupted execution of the storage command, is calculated in the storage device based on the estimated data under-run.
- the storage command is executed in the memory while prefetching from the memory data of at least the calculated data size.
- the storage command is received in accordance with a SAS storage protocol.
- the storage device includes a SSD.
- executing the storage command includes transferring the data from the storage device to the host, and calculating the data size includes determining the minimal data size that causes the data to be transferred in successive time slots.
- executing the storage command includes transferring the data from the storage device to the host, and the method includes re-transmitting the data to the host upon a failure to transfer the data successfully using the calculated data size.
- calculating the data size includes setting the data size depending on a type of the memory from which the data is fetched.
- a data storage apparatus including an interface and storage circuitry.
- the interface is arranged to communicate with a host over a storage interface for executing a storage command in a memory of the apparatus.
- the storage circuitry is arranged to estimate an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface, to calculate, based on the estimated data under-run, a data size to be prefetched from the memory in order to complete uninterrupted execution of the storage command, and to execute the storage command in the memory while prefetching from the memory data of at least the calculated data size.
- a method for data storage in a storage device that executes storage commands in a memory of the storage device.
- the method includes maintaining a hash table that stores tags of active connections and is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table includes entries holding one or more of the tags associated with the respective hash values.
- a storage command which is associated with a new connection and includes a tag of the new connection, is received in the storage device.
- the hash function is applied to the tag so as to produce a hash value.
- a lookup is performed in the hash table using the hash value.
- an indication is output that the new connection has a duplicate tag with an existing active connection.
- the storage command and the connection conform to a SAS storage protocol.
- the storage device includes a SSD.
- each of the entries in the hash table holds no more than a predefined number, N, of the tags, and the method includes declining the new connection upon detecting that all the N tags in the entry associated with the hash value are already occupied.
- declining the new connection includes sending a declination message to a host that initiated the storage command. Sending the declination message may include sending a SAS “task set full” message.
- a data storage apparatus including an interface and storage circuitry.
- the interface is arranged to receive storage commands for execution in a memory of the apparatus.
- the storage circuitry is arranged to maintain a hash table that stores tags of active connections and is accessed by hash values produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table includes entries holding one or more of the tags associated with the respective hash values, to receive via the interface a storage command that is associated with a new connection and includes a tag of the new connection, to apply the hash function to the tag so as to produce a hash value, to perform a lookup in the hash table using the hash value, and, upon detecting that the tag of the new connection matches one of the tags in an entry of the hash table associated with the hash value, to output an indication that the new connection has a duplicate tag with an existing active connection.
- FIG. 1 is a block diagram that schematically illustrates a data storage system, in accordance with an embodiment of the present invention
- FIGS. 2 and 3 are flow charts that schematically illustrate methods for configuring connections, in accordance with embodiments of the present invention
- FIG. 4 is a flow chart that schematically illustrates a method for data transmission, in accordance with an embodiment of the present invention
- FIG. 5 is a block diagram that schematically illustrates a hash-based duplicate tag detection mechanism, in accordance with an embodiment of the present invention.
- FIG. 6 is a flow chart that schematically illustrates a method for hash-based duplicate tag detection, in accordance with an embodiment of the present invention.
- Embodiments of the present invention that are described herein provide improved methods and systems for carrying out storage commands using storage protocols such as SAS.
- storage protocols such as SAS.
- each storage command belongs to a connection that is opened between the storage device and a host.
- a storage device comprises a hardware-implemented front-end and a Central Processing Unit (CPU), which jointly execute storage commands in a memory.
- CPU Central Processing Unit
- the hardware front-end and the CPU are embodied in an SSD controller, and the memory comprises multiple Flash memory devices.
- the CPU pre-configures the hardware front-end with multiple contexts that define operational parameters of respective connections.
- the hardware front-end executes storage commands belonging to these connections autonomously, using the pre-configured contexts, without involving the CPU software. If, however, the hardware front-end identifies a storage command whose context is not pre-configured, it triggers the CPU software to configure the context of this connection in the hardware front-end, and then executes the command using the configured context.
- This technique enables the storage device to execute the majority of storage commands purely in hardware, without a need to re-configure the hardware front-end on every command. As a result, processing latency in the storage device can be reduced and storage throughput can be increased considerably.
- the storage device is not limited in the total number of simultaneously-supported connections: Connections that are not pre-configured in the hardware front-end can be configured by the CPU as needed, although they will typically exhibit higher latency.
- the hardware front-end caches the contexts of one or more most-recently-used connections, even after the connections are closed.
- the hardware front-end checks whether this command belongs to one of the connections that were most recently closed. If so, the hardware front-end re-opens the connection using the cached context, and executes the command, without having to involve the CPU. In some scenarios, this technique reduces the computational and latency overhead associated with opening of connections, and therefore increases storage throughput, while imposing only modest hardware requirements.
- the storage device estimates the expected data under-run, and calculates a data size that is to be prefetched from the memory in order to complete uninterrupted execution of storage commands. The storage device then executes storage commands while prefetching at least the calculated data size.
- each connection is assigned a tag, and the tags of active (open) connections must differ from one another at any given time.
- Duplicate tags i.e., different connections assigned the same tag, are regarded as a failure event.
- the storage device stores tags of currently-active connections in a hash table.
- the table is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands.
- Each entry of the hash table holds one or more tags associated with a respective hash value.
- the storage device adds the tag of the new connection to the appropriate entry of the hash table, i.e., to the entry associated with the hash value produced from the tag assigned to the new connection.
- the storage device detects duplicate tags by comparing the tag of the new connection to the tags that are already stored in the corresponding entry of the hash table. If a match is found, the storage device reports an error message indicating the duplicate tag.
- each hash table entry is limited in size to hold no more than a predefined number, N, of tag values. If, when checking the tag of a new connection, the storage device finds that the corresponding hash table entry is already fully-populated with N tag values, the storage device declines the new connection. The storage device may decline the connection, for example, by sending a “task set full” SAS message to the host. This technique enables the storage device to avoid duplicate tag scenarios using a manageable-size hash table.
- FIG. 1 is a block diagram that schematically illustrates a data storage system 20 , in accordance with an embodiment of the present invention.
- System 20 comprises a storage device, in the present example a Solid state Drive (SSD) 24 , which stores data on behalf of one or more hosts 28 .
- SSD Solid state Drive
- System 20 may comprise, for example, an enterprise storage system comprising multiple SSDs 24 , a computing device such as a notebook or laptop computer, or any other suitable system.
- SSD 24 communicates with hosts 28 using the Serial Attached SCSI (SAS) protocol, cited above.
- SAS Serial Attached SCSI
- the storage device is referred to as a target and the hosts are referred to as initiators.
- the embodiment of FIG. 1 shows a single storage device (target) that communicates with three hosts (initiators) via an expander 32 ,
- system 20 may comprise any desired number of storage devices of any suitable kind, which communicate with any desired number of hosts using any suitable storage protocol.
- Some of the disclosed techniques may be applied, for example, in alternative storage protocols such as Serial Advanced Technology Attachment (SATA) or NVM express.
- SATA Serial Advanced Technology Attachment
- NVM express NVM express.
- serial storage protocols such as SAS
- some of the disclosed techniques can also be used in parallel storage protocols, as well.
- SSD 24 comprises a physical layer unit (PHY) 36 , which functions as an interface between the SSD and the hosts and applies various physical-layer functions such as serial-to-parallel conversion.
- An SSD controller 40 manages the operation of SSD 24 .
- the SSD controller stores and retrieves data in multiple non-volatile memory devices, such as Flash memory devices 48 .
- the data exchanged between the SSD controller and the Flash memory devices is buffered in one or more Random Access Memory (RAM) buffers 44 .
- RAM Random Access Memory
- SSD 24 receives from each host 28 memory access commands, e.g., read and write commands, and executes the commands in memory devices 48 .
- memory access commands e.g., read and write commands
- each command is part of a connection that is opened between the SSD and a host.
- the SSD may carry out multiple open connections with multiple respective hosts simultaneously.
- SSD controller 40 comprises a hardware-implemented front-end (H/W FE) 52 , and a front-end Central Processing Unit (CPU) 56 .
- H/W FE receives the memory access commands from PHY 36 and executes the commands using Direct Memory Access (DMA) in memory devices 48 .
- DMA Direct Memory Access
- CPU 56 configures the H/W FE appropriately, for example configures suitable DMA connection contexts for processing the connections that are currently active between the SSD and the hosts.
- SSD 24 Some of the elements of SSD 24 , such as PHY 36 and H/W FE 52 , are implemented in hardware. Other elements of SSD 24 , such as CPU 56 , are implemented using a microprocessor that runs suitable software. In some embodiments, CPU 56 comprises a general-purpose processor, which is programmed in software to carry out the functions described herein. The software may be downloaded to the processor in electronic form, over a network, for example, or it may, alternatively or additionally, be provided and/or stored on non-transitory tangible media, such as magnetic, optical, or electronic memory.
- FIG. 1 is an exemplary system configuration, which is shown purely for the sake of conceptual clarity. Any other suitable data storage system configuration can also be used. Elements that are not necessary for understanding the principles of the present invention have been omitted from the figure for clarity. H/W FE 52 and CPU 56 (or any other suitable SSD controller configurations) are sometimes referred to collectively as storage circuitry that carries out the disclosed techniques.
- memory devices 48 and SSD controller 40 are implemented as separate Integrated Circuits (ICs). In alternative embodiments, however, the memory devices and the SSD controller may be integrated on separate semiconductor dies in a single Multi-Chip Package (MCP) or System on Chip (SoC), and may be interconnected by an internal bus. Further alternatively, some or all of the SSD circuitry may reside on the same die on which one or more of the memory devices are disposed. Further alternatively, some or all of the functionality of SSD controller 40 can be implemented in software and carried out by hosts 28 . In some embodiments, a host 28 and SSD controller 40 may be fabricated on the same die, or on separate dies in the same device package.
- MCP Multi-Chip Package
- SoC System on Chip
- each SAS storage command is part of a connection that is opened between the SSD and a certain host.
- the SSD may close a connection, for example, when a transaction is completed or when no storage commands associated with the connection are received for a certain time period.
- the SSD may handle multiple open connections with multiple respective hosts simultaneously.
- the SSD may respond by sending multiple “transfer ready” (XFER_READY) messages to the multiple hosts, indicating that the SSD is ready to receive the data transfer of the multiple write commands.
- XFER_READY transfer ready
- the data of the various write commands may arrive at the SSD in any order, for example in successive order, out-of-order or in an interleaved manner.
- SSD controller 40 defines a respective context for each connection.
- the context defines the state of the connection by specifying operational parameters such as, for example, the type of storage command being executed, the current offset of the data being transferred relative to the beginning of the data, a memory address in which the transferred data is to be stored or buffered, received data and command buffers, tag tables, end-to-end protection state variables, encryption/decryption state variables, compression state variables, and/or any other suitable parameters related to the connection.
- H/W FE 52 executes storage commands purely in hardware using DMA, without involving CPU 56 .
- CPU 56 configures the H/W FE with the connection context (also referred to as a DMA context, or simply context for brevity).
- connection context also referred to as a DMA context, or simply context for brevity.
- CPU 56 It is possible in principle for CPU 56 to re-configure H/W FE 52 with the appropriate connection context on reception of each storage command. This sort of solution, however, incurs considerable latency overhead. The latency overhead of this solution is especially severe when the SSD receives data on multiple connections in an interleaved manner. In such a scenario, CPU 56 would have to repeatedly re-configure H/W FE 52 to alternate from one connection context to another.
- CPU 56 pre-configures H/W FE 52 with multiple contexts of multiple respective connections.
- the H/W FE in these embodiments may comprise multiple context caches for storing the parameters of the various pre-configured connections.
- the H/W FE is able to execute the command using the pre-configured context of this connection without involving CPU 56 .
- H/W FE 52 may be designed to support any desired number of pre-configured connection context, such as two, four or eight contexts.
- H/W FE 52 if H/W FE 52 identifies that a certain received storage command belongs to a connection whose context is not pre-configured therein, the H/W FE triggers the software of CPU 56 to configure this context so as to be able to execute the command.
- the H/W FE may trigger the CPU software in any suitable way, for example by issuing an interrupt to the CPU. After configuring the new context, H/W FE may execute the storage command using this context.
- the newly-configured context overwrites one of the previously-configured contexts in H/W FE 52 , since the number of configured contexts in the H/W FE is limited.
- CPU 56 and/or H/W FE 52 may decide which previously-configured context to overwrite using any suitable criterion.
- the above-described technique enables SSD controller to handle various multiple-connection scenarios efficiently. For example, when the storage commands belong to a small number of connections (less than the number of connections that can be configured simultaneously in H/W FE 52 ), the H/W FE executes the commands with high throughput without a need for any configuration on the part of CPU 56 . When the storage commands arrive in order, i.e., one connection after another without interleaving, the H/W FE is able to execute the commands with little or no configuration overhead on the CPU. In these scenarios, the CPU is invoked mainly upon completion of transactions and for handling error events.
- FIG. 2 is a flow chart that schematically illustrates a method for configuring connections in SSD controller 40 of SSD 24 , in accordance with an embodiment of the present invention.
- the method begins with the software of CPU 56 pre-configuring H/W FE 52 with multiple connection contexts, at a pre-configuration step 60 .
- SSD controller 40 receives data associated with a storage command from a certain host (initiator) 28 , at a data input step 64 .
- the data is provided to H/W FE 52 .
- the H/W FE checks whether the data belongs to one of the connections whose contexts are currently configured in the H/W FE, at a connection checking step 68 .
- H/W FE 52 processes the data (e.g., stores the data in memory devices 48 ) in accordance with the context, at a processing step 72 . If the connection context is not configured, H/W FE 52 generates an interrupt to CPU 56 , at a CPU triggering step 76 . In response to the interrupt, the software of CPU 56 configures H/W FE 52 with the appropriate connection context, at a configuration step 80 . As noted above, CPU 56 typically stores the state of an existing context that is to be overridden by the new context, retrieves the state of the new context and configures the new context in H/W FE 52 . The method then proceeds to step 72 for processing the data.
- the storage commands received in SSD 24 are associated with a relatively small number of connections.
- a certain connection is closed following an inactivity period on the connection, and then an additional storage command of the same connection arrives.
- the storage performance e.g., latency and throughput
- the SSD controller is able to re-open a recently-closed connection immediately and with small overhead, without involving the CPU software.
- H/W FE 52 opens one or more connections, executes storage commands that are associated with the open connections, and closes the connections after executing the commands.
- the H/W FE caches the contexts of one or more of the connections that were most recently closed.
- the H/W FE checks whether the connection is one of the most-recently-closed connections whose contexts are cached. If so, the H/W FE re-opens the connection using the cached context and executes the command.
- any suitable number of connection contexts can be cached in H/W FE 52 .
- FIG. 3 is a flow chart that schematically illustrates a method for configuring connections, in accordance with an embodiment of the present invention. This example refers to caching of a single most-recently used context. Caching of multiple contexts can be implemented in a similar manner.
- the method begins with SSD controller 40 receiving data from one or more hosts (initiators) 28 , at a data reception step 90 .
- H/W FE 52 checks whether the data belongs to the most-recently-closed connection, at a recent connection checking step 94 .
- H/W FE 52 re-opens the connection using the hardware-cached context, at a connection re-opening step 98 .
- the connection re-opening in this case is performed solely in hardware without involving the CPU.
- H/W FE 52 issues an interrupt to CPU 56 , at an interrupt generation step 106 .
- the software of CPU 56 configures H/W FE 52 with the connection context, at a context configuration step 110 .
- CPU 56 typically stores the state of the existing context for later use, retrieves the state of the new context and configures the new context in H/W FE 52 .
- the H/W FE then opens the connection at step 98 .
- H/W FE 52 executes the storage command using the applicable context and closes the connection, at an execution step 102 .
- gaps in the data transfer of an IU from the SSD (target) to a host (initiator) may be created for several reasons, for example when a data under-run occurs between fetching the data for from memory and transfer of the data over the storage interface.
- the frame will typically contain invalid data and its transfer is likely to fail (e.g., cause Cyclic redundancy Check—CRC—failure).
- data under-run refers to any scenario in which the storage device circuitry (e.g., SSD controller) is unable to fetch data from memory with sufficient speed or bandwidth, so as to allow the data to be transferred without gaps at the clock speed of the storage interface.
- Data under-runs are often temporary in nature, and may occur for various reasons, for example due to bus congestion, temporary management or other processing load, or for any other reason.
- H/W FE 52 of the SSD when transferring data from SSD 24 to a host, prefetches a certain amount of data from memory in order to avoid potential gaps in the data.
- the data size to be prefetched from memory (sometimes referred to as prefetch depth) has an impact on performance: An exceedingly high prefetched data size causes an unnecessary increase in latency. Setting the prefetch depth too low, on the other hand, may increase the probability of creating gaps and thus causing transfer errors and retransmission.
- SSD controller 40 of SSD sets the data size to be prefetched at an optimal value that is based on the expected data under-run. This setting is able to optimize the trade-off between error performance and latency.
- FIG. 4 is a flow chart that schematically illustrates a method for SAS data transmission, in accordance with an embodiment of the present invention.
- the method begins with SSD controller 40 estimating the temporary data under-run of the SAS interface, at an under-run estimation step 120 .
- the SSD controller may estimate the under-run in various ways. For example, the probability of encountering an under-run may be estimated based on the statistical properties (e.g., histogram) of the latency of fetching data from memory devices 48 .
- the latency may be estimated, for example, using off-line characterization or on-line measurements.
- SSD controller 40 sets the data size to be prefetched from memory devices 48 based on the estimated data under-run, at a prefetch depth setting step 124 .
- the data size is calculated so as to enable uninterrupted completion of storage command execution (e.g., data transfer to the host).
- the prefetch depth is set based on the histogram of the data fetching latency described above.
- the SSD controller may set the prefetch depth such that the probability of causing data under-run in an IU does not exceed a specified probability threshold (e.g., 99.9%, 99.99% or any other suitable threshold value).
- a specified probability threshold e.g., 99.9%, 99.99% or any other suitable threshold value.
- the prefetched data size may depend, for example, on the total length of the data (e.g., IU size).
- SSD controller 40 When executing storage commands, e.g., when transferring data from memory devices 48 to a host, SSD controller 40 prefetches data from the memory devices according to the data size set above, at a prefetching step 128 .
- the SSD controller sets the prefetch depth depending on the type of memory from which the data is retrieved.
- data prefetching may be deactivated altogether for one type of memory, and activated for another memory type.
- data prefetching may be activated when the data is retrieved from internal Read Access Memory (RAM), and deactivated when the data is retrieved from external shared Double Data Rate (DDR) memory.
- RAM Read Access Memory
- DDR Double Data Rate
- the optimal setting of prefetch depth does not guarantee error-free data transfer. In other words, even with optimal prefetch depth setting, there remains some finite probability that a gap will be created due to data under-run. In such a case, the frame CRC will typically fail and the frame will be retransmitted.
- each connection for a SAS command or task is assigned an initiator tag.
- the tag field comprises 16 bits, i.e., it is able to support a total of 65536 64-bit tag values per initiator-target pair.
- no more than 256 different tags are typically active at any given time.
- the tags are required to be unique at any given time. In other words, it is not permitted for two connections that are active at the same time to be assigned the same tag.
- An event of this sort is referred to as a duplicate tag, and is regarded as a severe error.
- SSD controller 40 carries out a process for detecting duplicate tags using a hash table data structure.
- the SSD controller stores in the hash table tags of currently-active connections.
- the table is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands.
- Each entry of the hash table holds one or more tags associated with a respective hash value.
- the SSD controller adds the tag of the new connection to the appropriate entry of the hash table, i.e., to the entry associated with the hash value produced from the tag assigned to the new connection.
- the SSD controller detects duplicate tags by comparing the tag of the new connection to the tags that are already stored in the corresponding entry of the hash table. If a match is found, the SSD controller reports an error message indicating the duplicate tag.
- each hash table entry is limited in size to hold no more than a predefined number, N, of tag values. If, when checking the tag of a new connection, the SSD controller finds that the corresponding hash table entry is already fully-populated with N tag values, the storage device declines the new connection.
- the hash table can be kept at a manageable size.
- the size N can be set as a design parameter—to trade-off hash table size (and thus memory size) against probability of collision in the hash table (and thus storage performance). N may be set to any suitable entry size.
- connections whose tags cannot be added to the limited-size hash table are declined, and thus duplicate tags are avoided.
- the storage device may decline a connection in various ways, such as by sending a “task set full” SAS message to the host.
- the host will typically postpone the connection setup and will retry at a later time.
- FIG. 5 is a block diagram that schematically illustrates hash-based duplicate tag detection circuitry 130 , in accordance with an embodiment of the present invention.
- Circuitry 130 is typically implemented in SSD controller 40 , for example in H/W FE 52 .
- an equivalent mechanism can be implemented in software, e.g., in CPU 56 , or using a combination of hardware and software elements.
- Circuitry 130 comprises a hash key calculation module 134 , which applies a hash function to tags extracted from incoming storage commands. For a given tag, module 134 outputs a hash key (also referred to as hash value) that was calculated over the tag by the hash function. The hash value is used as a key or index for accessing a hash table 138 .
- table 138 comprises multiple entries corresponding to the various hash values, and each entry is able to hold up to N tag values.
- Table 138 may be stored in any suitable location, such as in memory devices 48 or in an internal memory of SSD controller 40 . If the tag of the incoming storage command matches one of the tag values in the hash table entry corresponding to the hash value, circuitry 138 outputs a duplicate tag error indication.
- FIG. 6 is a flow chart that schematically illustrates a method for hash-based duplicate tag detection, in accordance with an embodiment of the present invention.
- the method begins with SSD controller 40 receiving a storage command from a host, at a command reception step 140 .
- the command belongs to a new connection that is to be set-up, and comprises a tag field having a certain tag value.
- Module 134 in the SSD controller calculates a hash value for the tag extracted from the command using the hash function, at a hash calculation step 144 .
- the SSD controller looks-up hash table 138 , in order to check whether the tag of the incoming command matches the tag of a currently-active connection, at a duplicate checking step 148 .
- the SSD controller compares the tag of the incoming commands against the tag values stored in the hash table entry indexed by the hash value calculated above.
- SSD controller 40 If a match is found, SSD controller 40 outputs a duplicate tag error indication, at a duplicate tag indication step 152 . Otherwise, the SSD controller checks whether all N possible tag values in the hash table entry are already occupied, at an entry status checking step 156 . If the entry is fully populated, there is no space to add the tag of the incoming command to the hash table. Thus, SSD controller 40 declines the new connection, at a declination step 160 . The SSD controller may decline the command connection, for example by sending a SAS “task set full” message to the host.
- SSD controller 40 adds the tag of the incoming command to the hash table entry, at a tag addition step 164 , and processes the command, at a command processing step 168 .
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Information Transfer Systems (AREA)
- Memory System Of A Hierarchy Structure (AREA)
- Debugging And Monitoring (AREA)
Abstract
A method for data storage includes, in a storage device that communicates with a host over a storage interface for executing a storage command in a memory of the storage device, estimating an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface. A data size to be prefetched from the memory, in order to complete uninterrupted execution of the storage command, is calculated in the storage device based on the estimated data under-run. The storage command is executed in the memory while prefetching from the memory data of at least the calculated data size.
Description
- This application claims the benefit of U.S. Provisional Patent Application 61/476,287, filed Apr. 17, 2011, and U.S. Provisional Patent Application 61/528,771, filed Aug. 30, 2011, whose disclosures are incorporated herein by reference. This application is related to a U.S. patent application entitled “Efficient connection management in a SAS target,” Attorney docket no. 1007-1128, filed on even date, whose disclosure is incorporated herein by reference.
- The present invention relates generally to data storage, and particularly to methods and systems for enhanced data storage using serial storage protocols.
- Data storage devices, such as Solid State Drives (SSDs) and enterprise storage systems, use various storage protocols for transferring data to and from storage. Two examples of storage protocols are the Small Computer System Interface (SCSI) and the Serial Attached SCSI (SAS) protocols, both developed by the International Committee for Information Technology Standards (INCITS).
- The SCSI protocol is described, for example, in “Information Technology—SCSI Architecture Model—5 (SAM-5),” INCITS document T10/2104-D, revision 01, Jan. 28, 2009, which is incorporated herein by reference. The SAS protocol is described, for example, in “Information Technology—Serial Attached SCSI—2 (SAS-2),” INCITS document T10/1760-D, revision 15a, Feb. 22, 2009, which is incorporated herein by reference.
- An embodiment of the present invention that is described herein provides a method for data storage. The method includes pre-configuring a hardware-implemented front-end of a storage device with multiple contexts of respective connections conducted between one or more hosts and the storage device. Storage commands, which are received in the storage device and are associated with the connections having the pre-configured contexts, are executed in a memory of the storage device using the hardware-implemented front-end. Upon identifying a storage command associated with a context that is not pre-configured in the hardware-implemented front-end, software of the storage device is triggered to configure the context in the hardware-implemented front-end, and the storage command is then executed using the hardware-implemented front-end in accordance with the context configured by the software.
- In some embodiments, the storage commands are received in accordance with a Serial Attached Storage (SAS) storage protocol. In an embodiment, the storage device includes a Solid State Disk (SSD). In a disclosed embodiment, triggering the software includes issuing an interrupt to a Central Processing Unit (CPU) that runs the software. In another embodiment, triggering the software includes causing the software to replace a previously-configured context in the hardware-implemented front-end with the context associated with the identified storage command. In yet another embodiment, executing the storage commands includes carrying out the storage commands without involvement of the CPU.
- There is additionally provided, in accordance with an embodiment of the present invention, a data storage apparatus including a CPU and a hardware-implemented front-end. The hardware-implemented front-end is pre-configured with multiple contexts of respective connections conducted between one or more hosts and the apparatus, and is arranged to execute in a memory of the apparatus storage commands that are received in the apparatus and are associated with the connections having the pre-configured contexts, and, upon identifying a storage command associated with a context that is not pre-configured in the hardware-implemented front-end, to trigger software running in the CPU to configure the context in the hardware-implemented front-end, and then to execute the storage command in accordance with the context configured by the software.
- There is also provided, in accordance with an embodiment of the present invention, a method for data storage. The method includes, in a hardware-implemented front-end of a storage device, opening at least one connection, executing in a memory of the storage device storage commands associated with at least one connection, closing the at least one connection after executing the storage commands, and caching one or more contexts of respective one or more connections that were most recently closed. A storage command associated with a given connection that is not currently open is received. The given connection is checked against the cached contexts. Upon identifying that the given connection is one of the one or more connections that were most recently closed, the given connection is re-opened using one of the cached contexts and the storage command is executed using the hardware-implemented front-end in accordance with the one of the contexts.
- In some embodiments, the storage commands are received in accordance with a SAS storage protocol. In an embodiment, the storage device includes a SSD. In a disclosed embodiment, closing the at least one connection includes closing each connection following a predefined inactivity period on the connection. In another embodiment, executing the storage commands includes carrying out the storage commands without involvement of a CPU of the storage device.
- There is further provided, in accordance with an embodiment of the present invention, a data storage apparatus including an interface and a hardware-implemented front-end. The interface is arranged to communicate with one or more hosts. The hardware-implemented front-end is arranged to open at least one connection, to execute in a memory of the apparatus storage commands associated with the at least one connection, to close the at least one connection after executing the storage commands, to cache one or more contexts of respective one or more connections that were most recently closed, to receive a storage command associated with a given connection that is not currently open, to check the given connection against the cached contexts, and, upon identifying that the given connection is one of the one or more connections that were most recently closed, to re-open the given connection using one of the cached contexts and to execute the storage command in accordance with the one of the cached contexts.
- There is also provided, in accordance with an embodiment of the present invention, a method for data storage in a storage device that communicates with a host over a storage interface for executing a storage command in a memory of the storage device. The method includes estimating an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface. A data size to be prefetched from the memory, in order to complete uninterrupted execution of the storage command, is calculated in the storage device based on the estimated data under-run. The storage command is executed in the memory while prefetching from the memory data of at least the calculated data size.
- In some embodiments, the storage command is received in accordance with a SAS storage protocol. In some embodiments, the storage device includes a SSD. In an embodiment, executing the storage command includes transferring the data from the storage device to the host, and calculating the data size includes determining the minimal data size that causes the data to be transferred in successive time slots.
- In another embodiment, executing the storage command includes transferring the data from the storage device to the host, and the method includes re-transmitting the data to the host upon a failure to transfer the data successfully using the calculated data size. In an embodiment, calculating the data size includes setting the data size depending on a type of the memory from which the data is fetched.
- There is additionally provided, in accordance with an embodiment of the present invention, a data storage apparatus including an interface and storage circuitry. The interface is arranged to communicate with a host over a storage interface for executing a storage command in a memory of the apparatus. The storage circuitry is arranged to estimate an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface, to calculate, based on the estimated data under-run, a data size to be prefetched from the memory in order to complete uninterrupted execution of the storage command, and to execute the storage command in the memory while prefetching from the memory data of at least the calculated data size.
- There is also provided, in accordance with an embodiment of the present invention, a method for data storage in a storage device that executes storage commands in a memory of the storage device. The method includes maintaining a hash table that stores tags of active connections and is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table includes entries holding one or more of the tags associated with the respective hash values. A storage command, which is associated with a new connection and includes a tag of the new connection, is received in the storage device. The hash function is applied to the tag so as to produce a hash value. A lookup is performed in the hash table using the hash value. Upon detecting that the tag of the new connection matches one of the tags in an entry of the hash table associated with the hash value, an indication is output that the new connection has a duplicate tag with an existing active connection.
- In some embodiments, the storage command and the connection conform to a SAS storage protocol. In some embodiments, the storage device includes a SSD. In an embodiment, each of the entries in the hash table holds no more than a predefined number, N, of the tags, and the method includes declining the new connection upon detecting that all the N tags in the entry associated with the hash value are already occupied. In another embodiment, declining the new connection includes sending a declination message to a host that initiated the storage command. Sending the declination message may include sending a SAS “task set full” message.
- There is further provided, in accordance with an embodiment of the present invention, a data storage apparatus including an interface and storage circuitry. The interface is arranged to receive storage commands for execution in a memory of the apparatus. The storage circuitry is arranged to maintain a hash table that stores tags of active connections and is accessed by hash values produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table includes entries holding one or more of the tags associated with the respective hash values, to receive via the interface a storage command that is associated with a new connection and includes a tag of the new connection, to apply the hash function to the tag so as to produce a hash value, to perform a lookup in the hash table using the hash value, and, upon detecting that the tag of the new connection matches one of the tags in an entry of the hash table associated with the hash value, to output an indication that the new connection has a duplicate tag with an existing active connection.
- The present invention will be more fully understood from the following detailed description of the embodiments thereof, taken together with the drawings in which:
-
FIG. 1 is a block diagram that schematically illustrates a data storage system, in accordance with an embodiment of the present invention; -
FIGS. 2 and 3 are flow charts that schematically illustrate methods for configuring connections, in accordance with embodiments of the present invention; -
FIG. 4 is a flow chart that schematically illustrates a method for data transmission, in accordance with an embodiment of the present invention; -
FIG. 5 is a block diagram that schematically illustrates a hash-based duplicate tag detection mechanism, in accordance with an embodiment of the present invention; and -
FIG. 6 is a flow chart that schematically illustrates a method for hash-based duplicate tag detection, in accordance with an embodiment of the present invention. - Embodiments of the present invention that are described herein provide improved methods and systems for carrying out storage commands using storage protocols such as SAS. In accordance with the SAS protocol, each storage command belongs to a connection that is opened between the storage device and a host.
- In some embodiments, a storage device comprises a hardware-implemented front-end and a Central Processing Unit (CPU), which jointly execute storage commands in a memory. In a Solid State Disk (SSD) application, for example, the hardware front-end and the CPU are embodied in an SSD controller, and the memory comprises multiple Flash memory devices.
- In some disclosed embodiments, the CPU pre-configures the hardware front-end with multiple contexts that define operational parameters of respective connections. The hardware front-end executes storage commands belonging to these connections autonomously, using the pre-configured contexts, without involving the CPU software. If, however, the hardware front-end identifies a storage command whose context is not pre-configured, it triggers the CPU software to configure the context of this connection in the hardware front-end, and then executes the command using the configured context.
- This technique enables the storage device to execute the majority of storage commands purely in hardware, without a need to re-configure the hardware front-end on every command. As a result, processing latency in the storage device can be reduced and storage throughput can be increased considerably. At the same time, the storage device is not limited in the total number of simultaneously-supported connections: Connections that are not pre-configured in the hardware front-end can be configured by the CPU as needed, although they will typically exhibit higher latency.
- In other disclosed embodiments, the hardware front-end caches the contexts of one or more most-recently-used connections, even after the connections are closed. When receiving a subsequent storage command, the hardware front-end checks whether this command belongs to one of the connections that were most recently closed. If so, the hardware front-end re-opens the connection using the cached context, and executes the command, without having to involve the CPU. In some scenarios, this technique reduces the computational and latency overhead associated with opening of connections, and therefore increases storage throughput, while imposing only modest hardware requirements.
- Other embodiments that are described herein compensate for temporary data under-runs that may occur in the storage interface (e.g., SAS interface). Unless accounted for, such temporary data under-run may cause pauses or gaps in the transfer of data frames—which are not permitted in the SAS protocol. In some embodiments, the storage device estimates the expected data under-run, and calculates a data size that is to be prefetched from the memory in order to complete uninterrupted execution of storage commands. The storage device then executes storage commands while prefetching at least the calculated data size.
- In accordance with the SAS protocol, each connection is assigned a tag, and the tags of active (open) connections must differ from one another at any given time. Duplicate tags, i.e., different connections assigned the same tag, are regarded as a failure event. Some disclosed embodiments use a hash table mechanism in the storage device for detecting duplicate tags.
- In these embodiments, the storage device stores tags of currently-active connections in a hash table. The table is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands. Each entry of the hash table holds one or more tags associated with a respective hash value. When a new connection is opened, the storage device adds the tag of the new connection to the appropriate entry of the hash table, i.e., to the entry associated with the hash value produced from the tag assigned to the new connection.
- In some embodiments, the storage device detects duplicate tags by comparing the tag of the new connection to the tags that are already stored in the corresponding entry of the hash table. If a match is found, the storage device reports an error message indicating the duplicate tag.
- In some embodiments, each hash table entry is limited in size to hold no more than a predefined number, N, of tag values. If, when checking the tag of a new connection, the storage device finds that the corresponding hash table entry is already fully-populated with N tag values, the storage device declines the new connection. The storage device may decline the connection, for example, by sending a “task set full” SAS message to the host. This technique enables the storage device to avoid duplicate tag scenarios using a manageable-size hash table.
-
FIG. 1 is a block diagram that schematically illustrates adata storage system 20, in accordance with an embodiment of the present invention.System 20 comprises a storage device, in the present example a Solid state Drive (SSD) 24, which stores data on behalf of one or more hosts 28.System 20 may comprise, for example, an enterprise storage system comprisingmultiple SSDs 24, a computing device such as a notebook or laptop computer, or any other suitable system. - In the
present embodiment SSD 24 communicates withhosts 28 using the Serial Attached SCSI (SAS) protocol, cited above. In SAS terminology, the storage device is referred to as a target and the hosts are referred to as initiators. The embodiment ofFIG. 1 shows a single storage device (target) that communicates with three hosts (initiators) via anexpander 32, - In alternative embodiments,
system 20 may comprise any desired number of storage devices of any suitable kind, which communicate with any desired number of hosts using any suitable storage protocol. Some of the disclosed techniques may be applied, for example, in alternative storage protocols such as Serial Advanced Technology Attachment (SATA) or NVM express. Although the embodiments refer mainly to serial storage protocols such as SAS, some of the disclosed techniques can also be used in parallel storage protocols, as well. -
SSD 24 comprises a physical layer unit (PHY) 36, which functions as an interface between the SSD and the hosts and applies various physical-layer functions such as serial-to-parallel conversion. AnSSD controller 40 manages the operation ofSSD 24. In particular, the SSD controller stores and retrieves data in multiple non-volatile memory devices, such asFlash memory devices 48. In the present example, the data exchanged between the SSD controller and the Flash memory devices is buffered in one or more Random Access Memory (RAM) buffers 44. - Typically,
SSD 24 receives from eachhost 28 memory access commands, e.g., read and write commands, and executes the commands inmemory devices 48. In accordance with the SAS protocol, each command is part of a connection that is opened between the SSD and a host. The SSD may carry out multiple open connections with multiple respective hosts simultaneously. - In some embodiments,
SSD controller 40 comprises a hardware-implemented front-end (H/W FE) 52, and a front-end Central Processing Unit (CPU) 56. Typically, H/W FE receives the memory access commands fromPHY 36 and executes the commands using Direct Memory Access (DMA) inmemory devices 48.CPU 56 configures the H/W FE appropriately, for example configures suitable DMA connection contexts for processing the connections that are currently active between the SSD and the hosts. - Some of the elements of
SSD 24, such asPHY 36 and H/W FE 52, are implemented in hardware. Other elements ofSSD 24, such asCPU 56, are implemented using a microprocessor that runs suitable software. In some embodiments,CPU 56 comprises a general-purpose processor, which is programmed in software to carry out the functions described herein. The software may be downloaded to the processor in electronic form, over a network, for example, or it may, alternatively or additionally, be provided and/or stored on non-transitory tangible media, such as magnetic, optical, or electronic memory. - The configuration of
FIG. 1 is an exemplary system configuration, which is shown purely for the sake of conceptual clarity. Any other suitable data storage system configuration can also be used. Elements that are not necessary for understanding the principles of the present invention have been omitted from the figure for clarity. H/W FE 52 and CPU 56 (or any other suitable SSD controller configurations) are sometimes referred to collectively as storage circuitry that carries out the disclosed techniques. - In the example system configuration shown in
FIG. 1 ,memory devices 48 andSSD controller 40 are implemented as separate Integrated Circuits (ICs). In alternative embodiments, however, the memory devices and the SSD controller may be integrated on separate semiconductor dies in a single Multi-Chip Package (MCP) or System on Chip (SoC), and may be interconnected by an internal bus. Further alternatively, some or all of the SSD circuitry may reside on the same die on which one or more of the memory devices are disposed. Further alternatively, some or all of the functionality ofSSD controller 40 can be implemented in software and carried out byhosts 28. In some embodiments, ahost 28 andSSD controller 40 may be fabricated on the same die, or on separate dies in the same device package. - As noted above, each SAS storage command is part of a connection that is opened between the SSD and a certain host. The SSD may close a connection, for example, when a transaction is completed or when no storage commands associated with the connection are received for a certain time period. The SSD may handle multiple open connections with multiple respective hosts simultaneously.
- For example, after receiving multiple write commands from multiple hosts, the SSD may respond by sending multiple “transfer ready” (XFER_READY) messages to the multiple hosts, indicating that the SSD is ready to receive the data transfer of the multiple write commands. The data of the various write commands may arrive at the SSD in any order, for example in successive order, out-of-order or in an interleaved manner.
- In some embodiments,
SSD controller 40 defines a respective context for each connection. The context defines the state of the connection by specifying operational parameters such as, for example, the type of storage command being executed, the current offset of the data being transferred relative to the beginning of the data, a memory address in which the transferred data is to be stored or buffered, received data and command buffers, tag tables, end-to-end protection state variables, encryption/decryption state variables, compression state variables, and/or any other suitable parameters related to the connection. - Typically, H/
W FE 52 executes storage commands purely in hardware using DMA, without involvingCPU 56. In order for H/W FE 52 to execute storage commands on a given connection,CPU 56 configures the H/W FE with the connection context (also referred to as a DMA context, or simply context for brevity). When the H/W FE prepares to switch to a context that is not currently configured in the hardware,CPU 56 typically stores the state of the previous context, retrieves the state of the new context and configures the new context in the H/W FE. - It is possible in principle for
CPU 56 to re-configure H/W FE 52 with the appropriate connection context on reception of each storage command. This sort of solution, however, incurs considerable latency overhead. The latency overhead of this solution is especially severe when the SSD receives data on multiple connections in an interleaved manner. In such a scenario,CPU 56 would have to repeatedly re-configure H/W FE 52 to alternate from one connection context to another. - Thus, in some
embodiments CPU 56 pre-configures H/W FE 52 with multiple contexts of multiple respective connections. The H/W FE in these embodiments may comprise multiple context caches for storing the parameters of the various pre-configured connections. When receiving a storage command belonging to one of the pre-configured connections, the H/W FE is able to execute the command using the pre-configured context of this connection without involvingCPU 56. H/W FE 52 may be designed to support any desired number of pre-configured connection context, such as two, four or eight contexts. - In some embodiments, if H/
W FE 52 identifies that a certain received storage command belongs to a connection whose context is not pre-configured therein, the H/W FE triggers the software ofCPU 56 to configure this context so as to be able to execute the command. The H/W FE may trigger the CPU software in any suitable way, for example by issuing an interrupt to the CPU. After configuring the new context, H/W FE may execute the storage command using this context. - Typically, the newly-configured context overwrites one of the previously-configured contexts in H/
W FE 52, since the number of configured contexts in the H/W FE is limited.CPU 56 and/or H/W FE 52 may decide which previously-configured context to overwrite using any suitable criterion. - The above-described technique enables SSD controller to handle various multiple-connection scenarios efficiently. For example, when the storage commands belong to a small number of connections (less than the number of connections that can be configured simultaneously in H/W FE 52), the H/W FE executes the commands with high throughput without a need for any configuration on the part of
CPU 56. When the storage commands arrive in order, i.e., one connection after another without interleaving, the H/W FE is able to execute the commands with little or no configuration overhead on the CPU. In these scenarios, the CPU is invoked mainly upon completion of transactions and for handling error events. - On the other hand, when the storage commands of different connections arrive in an interleaved manner, or if a command for a new connection arrives, the connection context is configured in the H/W FE by the CPU software. In this manner, the hardware size in the H/W FE is kept manageable, and at the same time there is no limit on the maximum number of connections that can be supported simultaneously. Different trade-offs of latency (and thus throughput) vs. hardware complexity can be accommodated by increasing or decreasing the number of hardware-implemented context caches in H/
W FE 52. -
FIG. 2 is a flow chart that schematically illustrates a method for configuring connections inSSD controller 40 ofSSD 24, in accordance with an embodiment of the present invention. The method begins with the software ofCPU 56 pre-configuring H/W FE 52 with multiple connection contexts, at apre-configuration step 60. -
SSD controller 40 receives data associated with a storage command from a certain host (initiator) 28, at adata input step 64. The data is provided to H/W FE 52. The H/W FE checks whether the data belongs to one of the connections whose contexts are currently configured in the H/W FE, at aconnection checking step 68. - If the connection context is already configured, H/
W FE 52 processes the data (e.g., stores the data in memory devices 48) in accordance with the context, at aprocessing step 72. If the connection context is not configured, H/W FE 52 generates an interrupt toCPU 56, at aCPU triggering step 76. In response to the interrupt, the software ofCPU 56 configures H/W FE 52 with the appropriate connection context, at aconfiguration step 80. As noted above,CPU 56 typically stores the state of an existing context that is to be overridden by the new context, retrieves the state of the new context and configures the new context in H/W FE 52. The method then proceeds to step 72 for processing the data. - In many practical scenarios, the storage commands received in
SSD 24 are associated with a relatively small number of connections. In other scenarios, a certain connection is closed following an inactivity period on the connection, and then an additional storage command of the same connection arrives. In such scenarios, as well as in others, the storage performance (e.g., latency and throughput) can be improved by caching the most recently used connection contexts in hardware. By using the connection contexts that are cached in hardware, the SSD controller is able to re-open a recently-closed connection immediately and with small overhead, without involving the CPU software. - In some embodiments, H/
W FE 52 opens one or more connections, executes storage commands that are associated with the open connections, and closes the connections after executing the commands. The H/W FE caches the contexts of one or more of the connections that were most recently closed. When a subsequent storage command belonging to a closed connection arrives, the H/W FE checks whether the connection is one of the most-recently-closed connections whose contexts are cached. If so, the H/W FE re-opens the connection using the cached context and executes the command. Depending on hardware complexity, any suitable number of connection contexts can be cached in H/W FE 52. -
FIG. 3 is a flow chart that schematically illustrates a method for configuring connections, in accordance with an embodiment of the present invention. This example refers to caching of a single most-recently used context. Caching of multiple contexts can be implemented in a similar manner. - The method begins with
SSD controller 40 receiving data from one or more hosts (initiators) 28, at adata reception step 90. H/W FE 52 checks whether the data belongs to the most-recently-closed connection, at a recentconnection checking step 94. - If so, the H/W FE re-opens the connection using the hardware-cached context, at a
connection re-opening step 98. The connection re-opening in this case is performed solely in hardware without involving the CPU. Otherwise, H/W FE 52 issues an interrupt toCPU 56, at an interruptgeneration step 106. In response to the interrupt, the software ofCPU 56 configures H/W FE 52 with the connection context, at acontext configuration step 110. As noted above,CPU 56 typically stores the state of the existing context for later use, retrieves the state of the new context and configures the new context in H/W FE 52. The H/W FE then opens the connection atstep 98. - H/
W FE 52 executes the storage command using the applicable context and closes the connection, at anexecution step 102. - In accordance with the SAS specifications, no pauses or gaps are permitted during Information Unit (IU) transfer. Once the SAS transport layer begins transmission of a frame, the data words of the IU should be provided in successive time slots with no gaps or interruptions (with only ALIGNp—a delete-able primitive—possibly inserted).
- In practice, gaps in the data transfer of an IU from the SSD (target) to a host (initiator) may be created for several reasons, for example when a data under-run occurs between fetching the data for from memory and transfer of the data over the storage interface. When a gap is created, the frame will typically contain invalid data and its transfer is likely to fail (e.g., cause Cyclic redundancy Check—CRC—failure).
- In the context of the present patent application and in the claims, the term “data under-run” refers to any scenario in which the storage device circuitry (e.g., SSD controller) is unable to fetch data from memory with sufficient speed or bandwidth, so as to allow the data to be transferred without gaps at the clock speed of the storage interface. Data under-runs are often temporary in nature, and may occur for various reasons, for example due to bus congestion, temporary management or other processing load, or for any other reason.
- In some embodiments, when transferring data from
SSD 24 to a host, H/W FE 52 of the SSD prefetches a certain amount of data from memory in order to avoid potential gaps in the data. The data size to be prefetched from memory (sometimes referred to as prefetch depth) has an impact on performance: An exceedingly high prefetched data size causes an unnecessary increase in latency. Setting the prefetch depth too low, on the other hand, may increase the probability of creating gaps and thus causing transfer errors and retransmission. - Thus, in some
embodiments SSD controller 40 of SSD sets the data size to be prefetched at an optimal value that is based on the expected data under-run. This setting is able to optimize the trade-off between error performance and latency. -
FIG. 4 is a flow chart that schematically illustrates a method for SAS data transmission, in accordance with an embodiment of the present invention. The method begins withSSD controller 40 estimating the temporary data under-run of the SAS interface, at an under-runestimation step 120. The SSD controller may estimate the under-run in various ways. For example, the probability of encountering an under-run may be estimated based on the statistical properties (e.g., histogram) of the latency of fetching data frommemory devices 48. The latency may be estimated, for example, using off-line characterization or on-line measurements. -
SSD controller 40 sets the data size to be prefetched frommemory devices 48 based on the estimated data under-run, at a prefetchdepth setting step 124. The data size is calculated so as to enable uninterrupted completion of storage command execution (e.g., data transfer to the host). - In an example embodiment, the prefetch depth is set based on the histogram of the data fetching latency described above. For example, the SSD controller may set the prefetch depth such that the probability of causing data under-run in an IU does not exceed a specified probability threshold (e.g., 99.9%, 99.99% or any other suitable threshold value). In addition to the estimated data under-run, the prefetched data size may depend, for example, on the total length of the data (e.g., IU size).
- When executing storage commands, e.g., when transferring data from
memory devices 48 to a host,SSD controller 40 prefetches data from the memory devices according to the data size set above, at aprefetching step 128. - In some embodiments, the SSD controller sets the prefetch depth depending on the type of memory from which the data is retrieved. In an example embodiment, data prefetching may be deactivated altogether for one type of memory, and activated for another memory type. For example, data prefetching may be activated when the data is retrieved from internal Read Access Memory (RAM), and deactivated when the data is retrieved from external shared Double Data Rate (DDR) memory.
- In some embodiments, the optimal setting of prefetch depth does not guarantee error-free data transfer. In other words, even with optimal prefetch depth setting, there remains some finite probability that a gap will be created due to data under-run. In such a case, the frame CRC will typically fail and the frame will be retransmitted.
- In accordance with the SSD protocol, each connection for a SAS command or task is assigned an initiator tag. The tag field comprises 16 bits, i.e., it is able to support a total of 65536 64-bit tag values per initiator-target pair. In practice, however, no more than 256 different tags are typically active at any given time. The tags are required to be unique at any given time. In other words, it is not permitted for two connections that are active at the same time to be assigned the same tag. An event of this sort is referred to as a duplicate tag, and is regarded as a severe error.
- In some embodiments,
SSD controller 40 carries out a process for detecting duplicate tags using a hash table data structure. The SSD controller stores in the hash table tags of currently-active connections. The table is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands. Each entry of the hash table holds one or more tags associated with a respective hash value. When a new connection is opened, the SSD controller adds the tag of the new connection to the appropriate entry of the hash table, i.e., to the entry associated with the hash value produced from the tag assigned to the new connection. The SSD controller detects duplicate tags by comparing the tag of the new connection to the tags that are already stored in the corresponding entry of the hash table. If a match is found, the SSD controller reports an error message indicating the duplicate tag. - In the embodiments described herein, each hash table entry is limited in size to hold no more than a predefined number, N, of tag values. If, when checking the tag of a new connection, the SSD controller finds that the corresponding hash table entry is already fully-populated with N tag values, the storage device declines the new connection.
- By limiting the hash table entry size to N tag values, the hash table can be kept at a manageable size. The size N can be set as a design parameter—to trade-off hash table size (and thus memory size) against probability of collision in the hash table (and thus storage performance). N may be set to any suitable entry size. At the same time, connections whose tags cannot be added to the limited-size hash table are declined, and thus duplicate tags are avoided.
- The storage device may decline a connection in various ways, such as by sending a “task set full” SAS message to the host. In response to such a message, the host will typically postpone the connection setup and will retry at a later time.
-
FIG. 5 is a block diagram that schematically illustrates hash-based duplicatetag detection circuitry 130, in accordance with an embodiment of the present invention.Circuitry 130 is typically implemented inSSD controller 40, for example in H/W FE 52. Alternatively, an equivalent mechanism can be implemented in software, e.g., inCPU 56, or using a combination of hardware and software elements. -
Circuitry 130 comprises a hash key calculation module 134, which applies a hash function to tags extracted from incoming storage commands. For a given tag, module 134 outputs a hash key (also referred to as hash value) that was calculated over the tag by the hash function. The hash value is used as a key or index for accessing a hash table 138. - As described above, table 138 comprises multiple entries corresponding to the various hash values, and each entry is able to hold up to N tag values. Table 138 may be stored in any suitable location, such as in
memory devices 48 or in an internal memory ofSSD controller 40. If the tag of the incoming storage command matches one of the tag values in the hash table entry corresponding to the hash value,circuitry 138 outputs a duplicate tag error indication. -
FIG. 6 is a flow chart that schematically illustrates a method for hash-based duplicate tag detection, in accordance with an embodiment of the present invention. The method begins withSSD controller 40 receiving a storage command from a host, at acommand reception step 140. The command belongs to a new connection that is to be set-up, and comprises a tag field having a certain tag value. - Module 134 in the SSD controller calculates a hash value for the tag extracted from the command using the hash function, at a hash calculation step 144. The SSD controller looks-up hash table 138, in order to check whether the tag of the incoming command matches the tag of a currently-active connection, at a
duplicate checking step 148. Typically, the SSD controller compares the tag of the incoming commands against the tag values stored in the hash table entry indexed by the hash value calculated above. - If a match is found,
SSD controller 40 outputs a duplicate tag error indication, at a duplicatetag indication step 152. Otherwise, the SSD controller checks whether all N possible tag values in the hash table entry are already occupied, at an entrystatus checking step 156. If the entry is fully populated, there is no space to add the tag of the incoming command to the hash table. Thus,SSD controller 40 declines the new connection, at adeclination step 160. The SSD controller may decline the command connection, for example by sending a SAS “task set full” message to the host. - Otherwise,
SSD controller 40 adds the tag of the incoming command to the hash table entry, at atag addition step 164, and processes the command, at acommand processing step 168. - It will be appreciated that the embodiments described above are cited by way of example, and that the present invention is not limited to what has been particularly shown and described hereinabove. Rather, the scope of the present invention includes both combinations and sub-combinations of the various features described hereinabove, as well as variations and modifications thereof which would occur to persons skilled in the art upon reading the foregoing description and which are not disclosed in the prior art. Documents incorporated by reference in the present patent application are to be considered an integral part of the application except that to the extent any terms are defined in these incorporated documents in a manner that conflicts with the definitions made explicitly or implicitly in the present specification, only the definitions in the present specification should be considered.
Claims (24)
1. A method for data storage, comprising:
in a storage device that communicates with a host over a storage interface for executing a storage command in a memory of the storage device, estimating an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface;
calculating in the storage device, based on the estimated data under-run, a data size to be prefetched from the memory in order to complete uninterrupted execution of the storage command; and
executing the storage command in the memory while prefetching from the memory data of at least the calculated data size.
2. The method according to claim 1 , wherein the storage command is received in accordance with a Serial Attached Storage (SAS) storage protocol.
3. The method according to claim 1 , wherein the storage device comprises a Solid State Disk (SSD).
4. The method according to claim 1 , wherein executing the storage command comprises transferring the data from the storage device to the host, and wherein calculating the data size comprises determining the minimal data size that causes the data to be transferred in successive time slots.
5. The method according to claim 1 , wherein executing the storage command comprises transferring the data from the storage device to the host, and comprising re-transmitting the data to the host upon a failure to transfer the data successfully using the calculated data size.
6. The method according to claim 1 , wherein calculating the data size comprises setting the data size depending on a type of the memory from which the data is fetched.
7. A data storage apparatus, comprising:
an interface, which is arranged to communicate with a host over a storage interface for executing a storage command in a memory of the apparatus; and
storage circuitry, which is arranged to estimate an expected data under-run between fetching data for the storage command from the memory and sending the data over the storage interface, to calculate, based on the estimated data under-run, a data size to be prefetched from the memory in order to complete uninterrupted execution of the storage command, and to execute the storage command in the memory while prefetching from the memory data of at least the calculated data size.
8. The apparatus according to claim 7 , wherein the storage command conforms to a Serial Attached Storage (SAS) storage protocol.
9. The apparatus according to claim 7 , wherein the interface, the storage circuitry and the memory are comprised in a Solid State Disk (SSD).
10. The apparatus according to claim 7 , wherein the storage circuitry is arranged to execute the storage command by transferring the data to the host, and to calculate the data size by determining the minimal data size that causes the data to be transferred in successive time slots.
11. The apparatus according to claim 7 , wherein the storage circuitry is arranged to execute the storage command by transferring the data to the host, and to re-transmit the data to the host upon a failure to transfer the data successfully using the calculated data size.
12. The apparatus according to claim 7 , wherein the storage circuitry is arranged to set the data size depending on a type of the memory from which the data is fetched.
13. A method for data storage, comprising:
in a storage device that executes storage commands in a memory of the storage device, maintaining a hash table that stores tags of active connections and is accessed by hash values that are produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table comprises entries holding one or more of the tags associated with the respective hash values;
receiving in the storage device a storage command that is associated with a new connection and comprises a tag of the new connection;
applying the hash function to the tag so as to produce a hash value;
performing a lookup in the hash table using the hash value; and
upon detecting that the tag of the new connection matches one of the tags in an entry of the hash table associated with the hash value, outputting an indication that the new connection has a duplicate tag with an existing active connection.
14. The method according to claim 13 , wherein the storage command and the connection conform to a Serial Attached Storage (SAS) storage protocol.
15. The method according to claim 13 , wherein the storage device comprises a Solid State Disk (SSD).
16. The method according to claim 13 , wherein each of the entries in the hash table holds no more than a predefined number, N, of the tags, and comprising declining the new connection upon detecting that all the N tags in the entry associated with the hash value are already occupied.
17. The method according to claim 13 , wherein declining the new connection comprises sending a declination message to a host that initiated the storage command.
18. The method according to claim 17 , wherein sending the declination message comprises sending a Serial Attached Storage (SAS) “task set full” message.
19. A data storage apparatus, comprising:
an interface, which is arranged to receive storage commands for execution in a memory of the apparatus; and
storage circuitry, which is arranged to maintain a hash table that stores tags of active connections and is accessed by hash values produced by applying a hash function to the tags extracted from received storage commands, wherein the hash table comprises entries holding one or more of the tags associated with the respective hash values, to receive via the interface a storage command that is associated with a new connection and comprises a tag of the new connection, to apply the hash function to the tag so as to produce a hash value, to perform a lookup in the hash table using the hash value, and, upon detecting that the tag of the new connection matches one of the tags in an entry of the hash table associated with the hash value, to output an indication that the new connection has a duplicate tag with an existing active connection.
20. The apparatus according to claim 19 , wherein the storage command and the connection conform to a Serial Attached Storage (SAS) storage protocol.
21. The apparatus according to claim 19 , wherein the interface, the storage circuitry and the memory are comprised in a Solid State Disk (SSD).
22. The apparatus according to claim 19 , wherein each of the entries in the hash table holds no more than a predefined number, N, of the tags, and wherein the storage circuitry is arranged to decline the new connection upon detecting that all the N tags in the entry associated with the hash value are already occupied.
23. The apparatus according to claim 19 , wherein the storage circuitry is arranged to decline the new connection by sending a declination message to a host that initiated the storage command.
24. The apparatus according to claim 23 , wherein the declination message comprises a Serial Attached Storage (SAS) “task set full” message.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/439,863 US20120265962A1 (en) | 2011-04-17 | 2012-04-05 | High-performance sas target |
US15/014,223 US10089041B2 (en) | 2011-04-17 | 2016-02-03 | Efficient connection management in a SAS target |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201161476287P | 2011-04-17 | 2011-04-17 | |
US201161528771P | 2011-08-30 | 2011-08-30 | |
US13/439,863 US20120265962A1 (en) | 2011-04-17 | 2012-04-05 | High-performance sas target |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/014,223 Division US10089041B2 (en) | 2011-04-17 | 2016-02-03 | Efficient connection management in a SAS target |
Publications (1)
Publication Number | Publication Date |
---|---|
US20120265962A1 true US20120265962A1 (en) | 2012-10-18 |
Family
ID=47007259
Family Applications (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/439,863 Abandoned US20120265962A1 (en) | 2011-04-17 | 2012-04-05 | High-performance sas target |
US13/439,860 Active US8719457B2 (en) | 2011-04-17 | 2012-04-05 | Efficient connection management in a SAS target |
US14/217,802 Expired - Fee Related US8949475B2 (en) | 2011-04-17 | 2014-03-18 | Efficient connection management in a SAS target |
US14/217,771 Active 2032-09-21 US9411540B2 (en) | 2011-04-17 | 2014-03-18 | Efficient connection management in a SAS target |
US15/014,223 Active 2032-07-17 US10089041B2 (en) | 2011-04-17 | 2016-02-03 | Efficient connection management in a SAS target |
Family Applications After (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/439,860 Active US8719457B2 (en) | 2011-04-17 | 2012-04-05 | Efficient connection management in a SAS target |
US14/217,802 Expired - Fee Related US8949475B2 (en) | 2011-04-17 | 2014-03-18 | Efficient connection management in a SAS target |
US14/217,771 Active 2032-09-21 US9411540B2 (en) | 2011-04-17 | 2014-03-18 | Efficient connection management in a SAS target |
US15/014,223 Active 2032-07-17 US10089041B2 (en) | 2011-04-17 | 2016-02-03 | Efficient connection management in a SAS target |
Country Status (1)
Country | Link |
---|---|
US (5) | US20120265962A1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10042585B2 (en) * | 2016-09-27 | 2018-08-07 | Western Digital Technologies, Inc. | Pervasive drive operating statistics on SAS drives |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120265962A1 (en) * | 2011-04-17 | 2012-10-18 | Anobit Technologies Ltd. | High-performance sas target |
US9891966B2 (en) * | 2015-02-10 | 2018-02-13 | Red Hat, Inc. | Idempotent mode of executing commands triggered by complex event processing |
US10423468B2 (en) | 2015-02-10 | 2019-09-24 | Red Hat, Inc. | Complex event processing using pseudo-clock |
US10536156B1 (en) * | 2018-10-16 | 2020-01-14 | Microchip Technology Incorporated | Analog-to-digital converter controllers including configurable contexts |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5889993A (en) * | 1996-10-15 | 1999-03-30 | The Regents Of The University Of California | Predictive event tracking method |
US20030120871A1 (en) * | 1997-02-10 | 2003-06-26 | Matsushita Electric Industrial Co., Ltd. | Storage apparatus and input/output control method for the storage apparatus |
US20060271766A1 (en) * | 2005-05-27 | 2006-11-30 | Arm Limited | Dynamic fetch rate control of an instruction prefetch unit coupled to a pipelined memory system |
US20070150660A1 (en) * | 2005-12-28 | 2007-06-28 | Marathe Jaydeep P | Inserting prefetch instructions based on hardware monitoring |
US20070174517A1 (en) * | 2006-01-03 | 2007-07-26 | Robillard Michael N | Managing management controller communications |
US20080250183A1 (en) * | 2003-11-25 | 2008-10-09 | Zohar Bogin | Stream under-run/over-run recovery |
US20090119471A1 (en) * | 2007-11-01 | 2009-05-07 | Ibrahim Hur | Priority-Based Memory Prefetcher |
US20090119470A1 (en) * | 2007-11-01 | 2009-05-07 | Ibrahim Hur | Probabilistic Method for Performing Memory Prefetching |
US20110173397A1 (en) * | 2010-01-08 | 2011-07-14 | International Business Machines Corporation | Programmable stream prefetch with resource optimization |
US20120192038A1 (en) * | 2011-01-20 | 2012-07-26 | Byungcheol Cho | Sas-based semiconductor storage device memory disk unit |
Family Cites Families (38)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5032987A (en) * | 1988-08-04 | 1991-07-16 | Digital Equipment Corporation | System with a plurality of hash tables each using different adaptive hashing functions |
DE4410060B4 (en) * | 1993-04-08 | 2006-02-09 | Hewlett-Packard Development Co., L.P., Houston | Translating device for converting a virtual memory address into a physical memory address |
US6665728B1 (en) * | 1998-12-30 | 2003-12-16 | Intel Corporation | Establishing optimal latency in streaming data applications that use data packets |
US6901039B1 (en) | 1999-04-15 | 2005-05-31 | Mitsumi Electric Co., Ltd. | Writable optical drive with dynamically variable linear velocity to prevent buffer under-run |
KR100855927B1 (en) * | 2002-03-13 | 2008-09-02 | 이시하라 산교 가부시끼가이샤 | Process for production of titanium dioxide pigment and resin compositions containing the pigment |
US7627693B2 (en) * | 2002-06-11 | 2009-12-01 | Pandya Ashish A | IP storage processor and engine therefor using RDMA |
US7146467B2 (en) * | 2003-04-14 | 2006-12-05 | Hewlett-Packard Development Company, L.P. | Method of adaptive read cache pre-fetching to increase host read throughput |
US7133324B2 (en) * | 2003-12-24 | 2006-11-07 | Samsung Electronics Co., Ltd. | Synchronous dynamic random access memory devices having dual data rate 1 (DDR1) and DDR2 modes of operation and methods of operating same |
US7171500B2 (en) * | 2004-08-18 | 2007-01-30 | Lsi Logic Corporation | Systems and methods for target mode connection management in SAS connections |
US8612632B2 (en) * | 2004-08-18 | 2013-12-17 | Lsi Corporation | Systems and methods for tag information validation in wide port SAS connections |
US8065401B2 (en) * | 2004-08-18 | 2011-11-22 | Lsi Corporation | Systems and methods for frame ordering in wide port SAS connections |
US7334042B2 (en) * | 2004-08-18 | 2008-02-19 | Lsi Logic Corporation | Systems and methods for initiator mode connection management in SAS connections |
US20060080671A1 (en) * | 2004-10-13 | 2006-04-13 | Day Brian A | Systems and methods for opportunistic frame queue management in SAS connections |
US7472238B1 (en) * | 2004-11-05 | 2008-12-30 | Commvault Systems, Inc. | Systems and methods for recovering electronic information from a storage medium |
US7653070B2 (en) * | 2005-06-07 | 2010-01-26 | Broadcom Corporation | Method and system for supporting efficient and cache-friendly TCP session lookup operations based on canonicalization tags |
US7676604B2 (en) * | 2005-11-22 | 2010-03-09 | Intel Corporation | Task context direct indexing in a protocol engine |
US7536584B2 (en) | 2006-06-08 | 2009-05-19 | Dot Hill Systems Corporation | Fault-isolating SAS expander |
WO2008070688A1 (en) * | 2006-12-04 | 2008-06-12 | Commvault Systems, Inc. | Systems and methods for creating copies of data, such as archive copies |
US7840537B2 (en) * | 2006-12-22 | 2010-11-23 | Commvault Systems, Inc. | System and method for storing redundant information |
US8140696B2 (en) | 2007-03-12 | 2012-03-20 | International Business Machines Corporation | Layering serial attached small computer system interface (SAS) over ethernet |
US8825971B1 (en) * | 2007-12-31 | 2014-09-02 | Emc Corporation | Age-out selection in hash caches |
US20090222569A1 (en) * | 2008-02-29 | 2009-09-03 | Atrato, Inc. | Storage system front end |
US8239662B1 (en) * | 2008-03-20 | 2012-08-07 | Google Inc. | Network based operating system across devices |
US9098495B2 (en) * | 2008-06-24 | 2015-08-04 | Commvault Systems, Inc. | Application-aware and remote single instance data management |
US8219524B2 (en) * | 2008-06-24 | 2012-07-10 | Commvault Systems, Inc. | Application-aware and remote single instance data management |
WO2010047713A1 (en) | 2008-10-24 | 2010-04-29 | Hewlett-Packard Development Company, L.P. | Direct-attached/network-attached storage device |
US8434131B2 (en) | 2009-03-20 | 2013-04-30 | Commvault Systems, Inc. | Managing connections in a data storage system |
US20120110291A1 (en) * | 2009-04-06 | 2012-05-03 | Kaminario Technologies Ltd. | System and method for i/o command management |
US8219776B2 (en) | 2009-09-23 | 2012-07-10 | Lsi Corporation | Logical-to-physical address translation for solid state disks |
KR101662824B1 (en) | 2009-07-08 | 2016-10-06 | 삼성전자주식회사 | Solid state drive device and driving method thereof |
JP2011082911A (en) * | 2009-10-09 | 2011-04-21 | Sony Corp | Peripheral device, and device connection system |
US8255607B2 (en) | 2009-11-05 | 2012-08-28 | Emulex Design & Manufacturing Corporation | SAS expander-based SAS/SATA bridging |
US8291171B2 (en) * | 2009-11-30 | 2012-10-16 | Hewlett-Packard Development Company, L.P. | Altering prefetch depth based on ready data |
US8489803B2 (en) * | 2009-12-14 | 2013-07-16 | Smsc Holdings S.A.R.L. | Efficient use of flash memory in flash drives |
CN102130820A (en) | 2010-01-14 | 2011-07-20 | 深圳市深信服电子科技有限公司 | Network service access method and access gateway equipment |
US8578145B2 (en) * | 2010-10-13 | 2013-11-05 | International Business Machines Corporation | Port throttling across an operating system restart during a hot upgrade |
US20120185749A1 (en) * | 2011-01-14 | 2012-07-19 | Hitachi, Ltd. | Storage apparatus and response time control method |
US20120265962A1 (en) * | 2011-04-17 | 2012-10-18 | Anobit Technologies Ltd. | High-performance sas target |
-
2012
- 2012-04-05 US US13/439,863 patent/US20120265962A1/en not_active Abandoned
- 2012-04-05 US US13/439,860 patent/US8719457B2/en active Active
-
2014
- 2014-03-18 US US14/217,802 patent/US8949475B2/en not_active Expired - Fee Related
- 2014-03-18 US US14/217,771 patent/US9411540B2/en active Active
-
2016
- 2016-02-03 US US15/014,223 patent/US10089041B2/en active Active
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5889993A (en) * | 1996-10-15 | 1999-03-30 | The Regents Of The University Of California | Predictive event tracking method |
US20030120871A1 (en) * | 1997-02-10 | 2003-06-26 | Matsushita Electric Industrial Co., Ltd. | Storage apparatus and input/output control method for the storage apparatus |
US20080250183A1 (en) * | 2003-11-25 | 2008-10-09 | Zohar Bogin | Stream under-run/over-run recovery |
US20060271766A1 (en) * | 2005-05-27 | 2006-11-30 | Arm Limited | Dynamic fetch rate control of an instruction prefetch unit coupled to a pipelined memory system |
US20070150660A1 (en) * | 2005-12-28 | 2007-06-28 | Marathe Jaydeep P | Inserting prefetch instructions based on hardware monitoring |
US20070174517A1 (en) * | 2006-01-03 | 2007-07-26 | Robillard Michael N | Managing management controller communications |
US20090119471A1 (en) * | 2007-11-01 | 2009-05-07 | Ibrahim Hur | Priority-Based Memory Prefetcher |
US20090119470A1 (en) * | 2007-11-01 | 2009-05-07 | Ibrahim Hur | Probabilistic Method for Performing Memory Prefetching |
US20110173397A1 (en) * | 2010-01-08 | 2011-07-14 | International Business Machines Corporation | Programmable stream prefetch with resource optimization |
US20120192038A1 (en) * | 2011-01-20 | 2012-07-26 | Byungcheol Cho | Sas-based semiconductor storage device memory disk unit |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10042585B2 (en) * | 2016-09-27 | 2018-08-07 | Western Digital Technologies, Inc. | Pervasive drive operating statistics on SAS drives |
Also Published As
Publication number | Publication date |
---|---|
US20140201391A1 (en) | 2014-07-17 |
US8949475B2 (en) | 2015-02-03 |
US10089041B2 (en) | 2018-10-02 |
US8719457B2 (en) | 2014-05-06 |
US20120265903A1 (en) | 2012-10-18 |
US20160154598A1 (en) | 2016-06-02 |
US20140201440A1 (en) | 2014-07-17 |
US9411540B2 (en) | 2016-08-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10089041B2 (en) | Efficient connection management in a SAS target | |
US10365832B2 (en) | Two-level system main memory | |
US10423508B2 (en) | Method and system for a high-priority read based on an in-place suspend/resume write | |
US9304938B2 (en) | Storage device and data transferring method thereof | |
US20190188153A1 (en) | Direct host access to storage device memory space | |
US20120246435A1 (en) | Storage system exporting internal storage rules | |
WO2012050935A2 (en) | Apparatus, system, and method for data transformations within a data storage device | |
KR102282879B1 (en) | Method and system for using nand page buffers to improve the transfer buffer utilization of a solid state drive | |
US10310740B2 (en) | Aligning memory access operations to a geometry of a storage device | |
US20210255794A1 (en) | Optimizing Data Write Size Using Storage Device Geometry | |
US8131933B2 (en) | Methods and systems for communication between storage controllers | |
US20200319819A1 (en) | Method and Apparatus for Improving Parity Redundant Array of Independent Drives Write Latency in NVMe Devices | |
CN106990917B (en) | File reading and writing method and system | |
EP4227790B1 (en) | Systems, methods, and apparatus for copy destination atomicity in devices | |
US9996269B2 (en) | Low-latency signature/hash calculation of a stream of data blocks | |
WO2016209957A1 (en) | Aligning memory access operations to a geometry of a storage device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: ANOBIT TECHNOLOGIES LTD, ISRAEL Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PELED, ARIE;REEL/FRAME:027992/0303 Effective date: 20120404 |
|
AS | Assignment |
Owner name: APPLE INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ANOBIT TECHNOLOGIES LTD.;REEL/FRAME:028399/0733 Effective date: 20120601 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |