High speed input/output performance in solid state devices
First Claim
Patent Images
1. A method of storing data in a flash storage device, the method comprising:
- receiving a plurality of data sectors from a host system, wherein each of the data sectors is associated with a host logical address;
storing a plurality of data segments in the random access memory, wherein each data segment comprises one of the plurality of data sectors from the host system;
mapping the host logical address of each of the plurality of data sectors to a flash logical address of a corresponding data segment, wherein the mapping to the flash logical address is based on the respective host logical address;
calculating a channel assignment for each of the plurality of data segments based on the flash logical address of the respective data segment;
allocating the plurality of data segments among a plurality of channels of a flash array based on the channel assignment for each of the plurality of data segments;
generating a plurality of write commands for the plurality of allocated data segments;
providing each of the plurality of write commands to a respective queue associated with a channel to which the write command is allocated; and
for each queue storing write commands, sequentially sending the queued write commands to one or more flash memories via the channel to which the write commands are allocated, and sequentially providing a respective data segment in connection with sending each queued write command from the random access memory via the memory channel corresponding to the queue.
9 Assignments
0 Petitions
Accused Products
Abstract
A method of transferring data in a flash storage device comprising a random access memory and a plurality of channels of a flash array is provided. The method comprises receiving a plurality of data segments from a host system, storing the plurality of data segments in the random access memory, allocating the plurality of data segments among the plurality of channels of the flash array, and writing the allocated data segments from the random access memory to the respective channels of the flash array.
-
Citations
14 Claims
-
1. A method of storing data in a flash storage device, the method comprising:
-
receiving a plurality of data sectors from a host system, wherein each of the data sectors is associated with a host logical address; storing a plurality of data segments in the random access memory, wherein each data segment comprises one of the plurality of data sectors from the host system; mapping the host logical address of each of the plurality of data sectors to a flash logical address of a corresponding data segment, wherein the mapping to the flash logical address is based on the respective host logical address; calculating a channel assignment for each of the plurality of data segments based on the flash logical address of the respective data segment; allocating the plurality of data segments among a plurality of channels of a flash array based on the channel assignment for each of the plurality of data segments; generating a plurality of write commands for the plurality of allocated data segments; providing each of the plurality of write commands to a respective queue associated with a channel to which the write command is allocated; and for each queue storing write commands, sequentially sending the queued write commands to one or more flash memories via the channel to which the write commands are allocated, and sequentially providing a respective data segment in connection with sending each queued write command from the random access memory via the memory channel corresponding to the queue. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A flash storage device comprising:
-
a random access memory; a flash array comprising a plurality of flash memories and a respective plurality of channels; and a controller configured to; receive a plurality of data sectors from a host system, wherein each of the data sectors is associated with a host logical address; store a plurality of data segments in the random access memory, wherein each data segment comprises one of the plurality of data sectors from the host system; map the host logical address of each of the plurality of data sectors to a flash logical address of a corresponding data segment, wherein the mapping to the flash logical address is based on the respective host logical address; calculate a channel assignment for each of the plurality of data segments based on the flash logical address of the respective data segment; allocate the plurality of data segments among the plurality of channels of the flash array based on the channel assignment for each of the plurality of data segments; generate a plurality of write commands for the plurality of allocated data segments; provide each of the plurality of write commands to a respective queue associated with a channel to which the write command is allocated; and for each queue storing write commands, sequentially send the queued write commands to one or more flash memories via respective channels to which the write commands are allocated, and provide a respective data segment in connection with sending each queued write command from the random access memory via the memory channel corresponding to the queue. - View Dependent Claims (9, 10, 11, 12, 13, 14)
-
Specification