This application is based upon and claims the benefit of priority from prior Japanese Patent Application No. 2010-288829, filed Dec. 24, 2010, the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to a data storage apparatus using nonvolatile memories as storage media, and also to apparatus and method for controlling nonvolatile memories.
In recent years, solid state drives (SSDs) have been developed as data storage apparatuses, each using NAND flash memories (hereinafter referred to as “flash memories” in some cases) that are rewritable nonvolatile memories.
Most SSDs are of a multichannel type, in which flash memories are managed in units of channels, and data is written to channels in parallel. In any SSD of the multichannel type, the data (user data) to be written in each channel is used, generating error correction codes (i.e., Reed-Solomon codes, hereinafter called “parity data” in some cases), which can perform interchannel parity (ICP) correction process. These error correction codes are stored in the flash memories of some channels selected from the plurality of channels.
In the SSD of the multichannel type, parity data capable of correcting data between the channels is generated and stored in the selected channels. Data to be stored in the flash memories may be managed in the SSD, in the form of logical blocks. The interchannel parity data is therefore allocated to given locations (storage locations) existing in the logical blocks. The method of allocating the interchannel parity data to storage locations may influence the SDD-mounting design, particularly the amounting design of the controller that accomplishes the interchannel parity (ICP) correction function.
A general architecture that implements the various features of the embodiments will now be described with reference to the drawings. The drawings and the associated descriptions are provided to illustrate the embodiments and not to limit the scope of the invention.
Various embodiments will be described hereinafter with reference to the accompanying drawings.
In general, according to one embodiment, a data storage apparatus comprises a channel controller, an encoding module, and a data controller. The channel controller configured to control data input and output to and from nonvolatile memories for channels. The encoding module configured to generate encoded data for an interchannel error correction process, using data stored in each of the nonvolatile memories. The data controller configure to manage the encoded data in units of logical blocks when the channel controller writes the encoded data in parallel to the channels, and to allocate parity data contained in the encoded data to planes of the same channel in each logical block.
[Configuration of the Data Storage Apparatus]
As shown in
The flash memories 20 are the data storage media used in the SSD, and are flash memory chips. The SSD according to this embodiment is a multichannel type having flash memories 200 to 20n, which are associated with channels CH-0 to CH-n, respectively. This embodiment, however, has five flash memories 200 to 204 associated with five channels CH-0 to CH-4, for the same of convenience.
The SSD controller 10 has a flash memory controller 11, a buffer manager module 12, a host interface controller 13, and a subsystem module 14.
The flash memory controller 11 performs a read/write control and a data transfer control on the flash memories 200 to 204 (see
The host interface controller 13 controls the transfer of data and commands between the SSD and a host device 30. The host device 30 is, for example, the interface controller of the Serial ATA (SATA) standard incorporated in a personal computer.
The subsystem module 14 has a first microprocessor (CPU) 140 and a second microprocessor (CPU) 141, and controls the other components of the SSD controller 10. The first CPU 140 controls the buffer manager module 12 and host interface controller 13. The second CPU 141 controls the flash memory controller 11 and buffer manager module 12, causing them to execute commands coming from the host device 30, thereby writing and reading data to or from the flash memories 200 to 204.
(Configuration of the Flash Memory Controller)
As shown in
The accelerator 110 is a main controller for controlling the channel controllers 100 to 104, dataflow controller 120 and interchannel parity module 130 and also for controlling the data transfer to and from them. The accelerator 110 further controls a command process, in cooperation with the firmware (i.e., CPU 141).
The channel controllers 100 to 104 control the interface (i.e., data transfer) with the flash memories 200 to 204 associated with channels CH-0 to CH-4, respectively. That is, the flash memory controller 11 is configured to control the flash memories 200 to 2004 that the channel controllers 100 to 104 control in parallel for channels CH-0 to CH-4, respectively.
The dataflow controller 120 controls the data transfer between the channel controllers 100 to 104 and the interchannel parity module 130. Further, the dataflow controller 120 controls the data transfer between the channel controllers 100 to 104 and the buffer manager module 12. The interchannel parity module 130 is a data protection module configured to perform an interchannel parity (ICP) error correction process if errors are made, as will be described later. Hereinafter, the interchannel parity module 130 may be referred to as “ICP module 130” in some cases.
As shown in
The data stored in each of the flash memories 200 to 204 associated with channels CH-0 to CH-4, respectively, contains ECC data. The channel controllers 100 to 104 perform an ECC process, thereby protecting the data items stored in the flash memories 200 to 204. The ICP module 130 according to this embodiment combines the data items for different channels and generates encoded data, thereby accomplishing the interchannel data protection. The RS operator 40 is constituted by a plurality of operators in order to process data at high speed and configured to perform a pipeline parallel process. Alternatively, the RS operator 40 may be constituted by an operator that processes data in units of several bytes.
(InterChannel Parity (ICP) Process)
The ICP process (i.e., interchannel data protection process) will be explained with reference to
As shown in
Each logical block is constituted by a plurality of logical pages. In the present embodiment, the matrix elements of each plane are, for example, one-byte data items. The ICP module 130 generates encoded data 402 is a data unit in the interchannel ECC process (i.e., data unit to be protected). As shown in
In the present embodiment, one logical page (page sizes 500 and 501) is regarded as constituting one logical block, for the same of convenience, as shown in
The ICP process (i.e., data protection process), more precisely the encoding process and decoding process, will be explained with reference to the flowcharts of
First, the flash memory controller 11 processes the planes 0 and 1 of each of channels CH-0 to CH-4, in order to make accesses to the flash memories 200 to 204. To process a write command, the controller 11 combines the planes 0 and 1, as one request unit (i.e., one write command). This write process, which is known as “multiplane write,” can increase the write process (or shortens the programming time).
As shown in the flowchart of
Then, the ICP module 130 performs an encoding process, generating encoded data 502 as shown in
As shown in
The present embodiment is based on the assumption that the storage location of a logical page that contains the parity data generated in the encoding process is designated in units of planes. That is, this embodiment proposes a method of managing data, in which the parity data used in the interchannel parity process (data protection) is managed in a logical block in a specific manner.
The encoding process according to the embodiment will be explained in detail, with reference to
Assume that the encoded data has a code length of 10 bytes in the present embodiment. Then, two bytes of the encoded data is parity data 702. In order to encode data, the source data 700 of the plane 0 and the source data 702 of the plane 1 are input to the RS operator 40 as shown in
Next, the channel controllers 100 to 104 store the source data items 700 and 701 and the parity data 702 thus generated, in mutual association as shown in
To be more specific, as shown in
More precisely,
In such a data management method, wherein the parity data is stored in different channels and then managed, however, the dataflow process performed in units of planes 0 and 1 cannot preserve its uniformity when the source data items 700 and 701 to be encoded are input to the RS operator 40. Further, in the process of writing data in units of channels, too, the order of processing data in units of planes 0 and 1 must be changed for every channel.
By contrast, in the data management method according to this embodiment, the channel controllers 100 to 104 write, in phase 0, the source data 700 in the plane 0 of each channel other than channel CH-3 designated as one for the parity data, as shown in
In the data management method according to this embodiment, the logical blocks are thus managed to store the parity data, in the same number of bytes, in the planes 0 and 1 of the same channel CH-3. Data can therefore be uniformly processed in units of channels and in units of planes. More specifically, the process of inputting data to the RS operator 40 and the process of writing encoding data (i.e., source data and parity data) can be uniformly performed during the encoding process and the decoding process (described later).
This renders it easy to arrange the accelerator 110 and channel controllers 100 to 104, in particular, in the flash memory controller 11. In addition, this can simplify the multiplane write process.
(Decoding Process)
As shown in the flowchart of
If the channel controllers 100 to 104 detects errors while the data is being accessed (NO in Block 1702) and if the ECC can no longer corrects errors (YES in Block 1705) and the data should therefore be restored, the flash memory controller 11 causes the ICP module 130 to perform the interchannel parity (ICP) process.
The ICP module 130 uses the parity data read from the flash memory (Block 1706) and then performs a decoding process (i.e., data restoring process) (Block 1707).
How the decoding process is performed in the method of managing the encoded data (i.e., source data and parity data) generated in the encoding process according to this embodiment will be explained with reference mainly to
First, as shown in
Hence, as shown in
More precisely, as shown in
As described above, the flash memory controller 11 according to this embodiment manages data in units of logical blocks defined by channels CH-0 to CH-4 and planes 0 and 1, and processes the planes 0 and 1 as smallest units of data. During the decoding process, the ICP module 130 performs the ICP error correction process, in units of encoded data items, over channels CH-0 to CH-4. Therefore, the ICP module 130 must associate the location data items (i.e., channel numbers CH-0 to CH-4 and plane numbers 0 and 1) with the degrees of encoded data items (i.e., order).
In this embodiment, the dataflow controller 120 performs a control during the encoding process as described above, thereby associating the order of inputting data items to the RS operator 40 with the channel numbers to which the encoded data items are allocated and in which they are stored. The channel controllers 100 to 104 allocate the encoded data items to, and store them in the respective channels of the logical block.
In order to associate the location data contained in the logical block with the degree of the encoded data during the decoding process, the ICP module 130 has the address calculation module 41 and address conversion module 42 as shown in
As shown in
As shown in
The address calculation module 41 performs such address calculation as shown in
As described above, the RS operator 40 associates the order of the encoded data items with the degrees thereof, on the basis of the location data (301, 603) received from the address calculation module 41, thereby detecting and correcting the errors contained in the encoded data. The RS operator 40 outputs the error correction data (303 and 605), which is the result of the decoding process, to the dataflow controller 120.
In accordance with the error correction data (605) output from the RS operator 40, the dataflow controller 120 outputs correction data 606. An interchannel data correction can thereby be achieved in the decoding process during the interchannel parity process, by reading all data from the logical block and transferring the data to the RS operator 40.
In order to output the corrected data 606, the dataflow controller 120 needs corrected location data (Fn^−1) that associates the error location data obtained by the RS operator 40 with the corrected location data contained in the logical block. The corrected location data can be generated by the address conversion module 42 as shown in
The address conversion module 42 performs such address conversion as shown in
As indicated above, the ECC process may be performed for each channel. Then, an erasure correction can be accomplished to generate error location data (307) in the interchannel parity process according to this embodiment. In this case, the address calculation module 41 can convert the plane location represented by the error location (307) to the degree data contained in the code. The address conversion module 42 can therefore be dispensed with.
As has been described, in the SSD according to this embodiment, the ICP module 130 performs an encoding process, generating encoded data wherein the source data and the parity data are associated in the logical block. The parity data is managed, storing bytes in the same number in the planes 0 and 1 of the same channel (i.e., CH-3 in this instance). As a result, the data processing in units of channels and the data processing in units of planes can be uniformly performed. More specifically, the data input and the encoded data write, both to the RS operator 40, can be uniformly accomplished during the encoding process and decoding process.
This can simplify not only the mounting design in the flash memory controller 11, particularly that of the accelerator 110 and channel controllers 100 to 104, but also the multiplane write process. In other words, it is possible to simplify the dataflow control achieved by the dataflow controller 120 and the pipeline process management achieved by a plurality of RS operators to accomplish a high-speed operation in the ECC process. The parallel operation of RS operators can thereby be easily performed, ultimately reducing the cost of mounting components. In brief, the present embodiment can simplify the mounting design of a controller that implements the ICP function.
The various modules of the systems described herein can be implemented as software applications, hardware and/or software modules, or components on one or more computers, such as servers. While the various modules are illustrated separately, they may share some or all of the same underlying logic or code. While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2010-288829 | Dec 2010 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5737344 | Belser et al. | Apr 1998 | A |
5809516 | Ukai et al. | Sep 1998 | A |
6742159 | Sakurai | May 2004 | B2 |
7117421 | Danilak | Oct 2006 | B1 |
7793197 | Ito et al. | Sep 2010 | B2 |
20010056567 | Sakurai | Dec 2001 | A1 |
20060143553 | Takahashi et al. | Jun 2006 | A1 |
20090044078 | Vogan et al. | Feb 2009 | A1 |
20090150748 | Egner et al. | Jun 2009 | A1 |
20090307418 | Chen et al. | Dec 2009 | A1 |
20090327803 | Fukutomi et al. | Dec 2009 | A1 |
20100115183 | Araki et al. | May 2010 | A1 |
20100262755 | Becker et al. | Oct 2010 | A1 |
20110066883 | Dachiku | Mar 2011 | A1 |
20120166711 | Matsuyama et al. | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
H08-321138 | Dec 1996 | JP |
2002-007225 | Jan 2002 | JP |
3371044 | Nov 2004 | JP |
2005-528712 | Sep 2005 | JP |
2006-190346 | Jul 2006 | JP |
2007-274239 | Oct 2007 | JP |
2008-508632 | Mar 2008 | JP |
2010-015195 | Jan 2010 | JP |
2010-108246 | May 2010 | JP |
2010-250816 | Nov 2010 | JP |
2011-060217 | Mar 2011 | JP |
WO 03102965 | Dec 2003 | WO |
WO 2009042554 | Apr 2009 | WO |
Entry |
---|
Japanese Office Action dated Jun. 11, 2013 for Japanese Application No. 2010-288830. |
Office Action mailed Jun. 11, 2013 in JP Pat App No 2010-288829. |
Number | Date | Country | |
---|---|---|---|
20120166911 A1 | Jun 2012 | US |