The present invention relates to a memory controller that performs drive control with respect to a nonvolatile memory such as a flash memory, particularly a multilevel flash memory including multilevel memory cells configured so as to be capable of storing information of two or more bits. The present invention also relates to a nonvolatile storage device using the foregoing memory controller.
In recent years, a nonvolatile storage device, for example, a memory card has been used as a storage medium for a portable information terminal, etc., typified by a digital camera and a mobile telephone, and a market thereof has been expanding. Regarding such a nonvolatile storage device, the following has been proposed: a plurality of nonvolatile memories such as flash memories are provided to achieve high-speed writing of data, and data are interleaved and written in parallel in the plurality of nonvolatile memories.
Specifically, in a conventional nonvolatile storage device, as described in, for example, JP 6 (1994)-119128 A, physical blocks of a plurality of flash memories are combined, and tracks are configured so that one track is formed with a set of physical pages at the same position (see, for example,
As to the nonvolatile storage device, an increase in the capacity thereof is demanded, too, in addition to the above-described high-speed writing. To respond to this demand, not only the application of the micromachining in the semiconductor manufacturing process, but also the following has been attempted; a nonvolatile memory with use of the multilevel technique of causing one memory cell to store information (data) of two or more bits, for example, a multilevel flash memory in which multilevel memory cells are provided, has come into use.
More specifically, in a conventional nonvolatile storage device, threshold voltages for writing multilevel information into multilevel memory cells are assigned in a manner as described in JP 2004-192789 A (see
Further, as described, for example, in JP 2001-325796A, for a conventional nonvolatile storage device, it is proposed that by using a cache in the nonvolatile memory to which the multilevel technique is applied, high-speed writing can be achieved. Besides, it is also described that in this conventional nonvolatile storage device, the cache is available upon low bit writing, while the cache is unavailable upon high bit writing (see
Here, the data writing operation with respect to the multilevel flash memory shown in JP 2004-192789 A or JP 2001-325796 A described above will be described in detail, with reference to
As shown in
In the conventional nonvolatile storage device, as shown in
In other words, as shown in
Subsequently, in the multilevel flash memory, programming of the data 1 is started at the time T102. This programming is a writing operation for writing data in the second page of the multilevel memory cell. Therefore, in the multilevel flash memory, transfer of data is not allowed during a period while the foregoing programming is executed. For this reason, in the conventional nonvolatile storage device, the memory controller causes only the programming of the data 1 to be executed, while not allowing transfer of subsequent data 2 to be executed, during a period from the time T102 to a time T103.
Thereafter, writing operations for writing data 2 and 3 are carried out in the same manner during a period from the time T103 to a time T106, and writing operations for writing data 4 and 5 are carried out in the same manner during a period from the time T106 to a time T109.
Next, a case where data are interleaved and written in parallel in two multilevel flash memories in the conventional nonvolatile storage device is described in detail, with reference to
As shown in
Further, these page groups are configured so that data are written in an order in accordance with order of the page group, and in the same page group, data are written in an order in accordance with the order of the multilevel flash memories. In other words, data 0, 1, 2, and 3 sequentially are written in a physical page having a page number 0 of the multilevel flash memory 1, in a physical page having a page number 0 of the multilevel flash memory 2, in a physical page having a page number 1 in the multilevel flash memory 1, and in a physical page having a page number 1 in the multilevel flash memory 2, respectively. Thus, 256 sets of data in total, from data 0 to data 255, are allocated to any of the 128 page groups, and written therein.
Then, in the conventional nonvolatile storage device, as illustrated in
In other words, as shown in
Next, at the time T113, the memory controller causes the multilevel flash memory 1 to start programming the data 2, and causes the transfer of data 3 to the multilevel flash memory 2 to be performed during a period from this time T113 to a time T114. Subsequently, at the time T114, the memory controller causes the multilevel flash memory 2 to start programming data 3. For both of the multilevel flash memories 1 and 2, a period from the time T114 to a time T115 is a period for programming with respect to the second page, which is a period in which the data transfer is not allowed. Therefore, in the conventional nonvolatile storage device, the memory controller does not cause the transfer of data with respect to the multilevel flash memories 1 and 2 to be executed during the period from the time T114 to the time T115. Then, at the time T115, the programming of the data 2 ends, and then, the memory controller causes the transfer of data 4 to the multilevel flash memory 1 to be started at this time T115.
The conventional nonvolatile storage device as described above, however, has a problem in that it is not possible to interleave and write data effectively in the nonvolatile memory in which multilevel memory cells are used. The following describes this in more detail. In the conventional nonvolatile storage device, as shown in
More specifically, in the conventional nonvolatile storage device, a period, for example, from the time T114 to the time T115 in
In light of the above-described problem, it is an object of the present invention to provide a memory controller capable of effectively interleaving and writing data with respect to a nonvolatile memory in which multilevel memory cells are used, and to provide a nonvolatile storage device in which the foregoing memory controller is used.
In order to achieve the above-described object, a memory controller according to the present invention is a memory controller for performing drive control with respect to a nonvolatile memory in which multilevel memory cells, each of which is configured to be capable of storing data of two or more bits, are used in physical blocks.
The memory controller includes a main control part configured to be capable of interleaving and writing data in a plurality of the physical blocks, wherein each of the plurality of physical blocks includes the multilevel memory cells, which are p in number, first to p-th multilevel memory cells (p is an integer of not less than 2).
In each of the p multilevel memory cells, n pages that are first to n-th pages are provided as physical pages that are writing units for data (n is an integer of not less than 2), wherein as compared with a time required for a data writing operation with respect to the first page, the time required for a data writing operation with respect to a subsequent page increases sequentially as the page number increases, and in the case where in each of the plurality of physical blocks, page numbers are allocated sequentially to all the physical pages provided in the p multilevel memory cells in a predetermined order, the main control part defines, in the plurality of physical blocks, a plurality of page groups that include the physical pages provided in the physical blocks, and groups the physical pages of the plurality of physical blocks so that boundaries between the page groups are defined behind the physical pages as the n-th pages.
With respect to a plurality of physical blocks into which data are interleaved and written, the main control part in the memory controller configured as described above defines a plurality of page groups including physical pages provided in the physical blocks. The main control part also groups the physical pages of the plurality of physical blocks so that the boundaries between page groups are defined behind the physical pages as the n-th pages. With this configuration, unlike the above-described conventional example, it is possible to prevent the programming characteristics of the multilevel memory cells from adversely affecting the data writing operation. As a result, it is possible to interleave and write data effectively in the nonvolatile memory in which the multilevel memory cells are used.
In the above-described memory controller, the main control part may group the physical pages of the plurality of physical blocks so that each of the plurality of page groups includes the physical pages having the same page numbers in the plurality of physical blocks.
In this case, the grouping of physical pages with respect to the plurality of physical blocks can be carried out easily, and the management of data written in physical pages can be facilitated, whereby the nonvolatile memory driving control can be carried out easily.
Further, in the foregoing memory controller, it is preferable that in the case where data to be written in the nonvolatile memory are fed from outside, when transfer of data to be written is performed with respect to, among the plurality of physical pages included in the page groups, one physical page as the first page, the main control part performs transfer of data to be written with respect to another physical page of the same physical block included in the same page group as the page group including the above-mentioned physical page, and when transfer of data to be written is performed with respect to the physical page as the n-th page, the main control part performs transfer of data to be written with respect to a physical page of a physical block other than the physical block that includes the above-mentioned physical page as the n-th page.
In this case, when a data writing operation with respect to a physical page as the n-th page is performed, transfer of data to be written can be performed with respect to a physical page of a physical block other than the physical block that includes the foregoing physical page as the n-th page. Therefore, data can be interleaved and written more surely and effectively.
Further, a nonvolatile storage device of the present invention includes:
a nonvolatile memory in which multilevel memory cells each of which is configured to be capable of storing data of two or more bits are used in physical blocks; and
any one of the memory controllers described above.
In the nonvolatile storage device configured as described above, the memory controller used is capable of effectively interleaving and writing data in the nonvolatile memory in which multilevel memory cells are used. Thus, the nonvolatile storage device capable of performing high-speed data writing can be configured easily.
With the present invention, it is possible to provide a memory controller capable of effectively interleaving and writing data in a nonvolatile memory in which multilevel memory cells are used, and to provide a nonvolatile storage device in which the foregoing memory controller is used.
The following describes preferred embodiments of a memory controller and a nonvolatile storage device according to the present invention, while referring to the drawings. It should be noted that the following description explains an exemplary case where the present invention is applied to a memory card as the nonvolatile storage device.
Further, a host machine H that provides the memory card 1 with an access instruction with designation of a logical address is provided to be connectable with the memory card 1, so that two-way transfer of data between the memory card 1 and the host machine H can be performed. It should be noted that the memory card 1 and the host machine H are incorporated in, for example, a digital camera, or a personal computer, and therein form a nonvolatile storage system for storing data.
The controller 2 is configured to perform writing and reading of data whose logical address is designated by an external element, with respect to the first to m-th flash memories 3a, 3b, . . . , 3m of the nonvolatile memory group 3. More specifically, the controller 2 writes data into the first to m-th flash memories 3a, 3b, . . . , 3m of the nonvolatile memory group 3, the data being transferred together with a writing request with a logical address being designated, from the host machine 1 provided outside the memory card 1; and in response to a reading request with a logical address being designated, from the host machine H, the controller 2 reads data from some of the first to m-th flash memories 3a, 3b, . . . , 3m of the nonvolatile memory group 3 corresponding to the foregoing logical address, and transfers the data to the host machine H.
The controller 2 includes a main control part 4; a host I/F 5 and a memory I/F 7 that are interfaces provided on the host machine H side and the nonvolatile memory group 3 side, respectively; and a buffer 6 provided between the host I/F 5 and the memory I/F 7.
As the main control part 4, a CPU or a DSP is used, to which the writing request or the reading request from the host machine H is fed. The main control part 4 is configured to perform a driving control with respect to respective parts of the controller 2, according to a writing request or a reading request fed thereto. Additionally, the main control part 4 is configured so that data are interleaved and written in parallel into the first to m-th flash memories 3a, 3b, . . . , 3m of the nonvolatile memory group 3.
Further, as described later, the main control part 4 is configured so that according to page allocation set in the first to m-th flash memories 3a, 3b, . . . , 3m, a plurality of physical pages defined in the physical blocks of the first to m-th flash memories 3a, 3b, . . . , 3m are allocated and grouped into a plurality of page groups through predetermined steps. It should be noted that the main control part 4 is configured to respond appropriately to an access instruction from the host machine H, by interconverting logical addresses from the host machine H and addresses of corresponding ones of the physical pages of the first to m-th flash memories 3a, 3b, . . . , 3m, by referring to an address conversion table (not shown).
The host I/F 5 controls the interface between the memory card 1 and the host machine H pursuant to an instruction from the main control part 4, and performs transfer of data between the memory card 1 and the buffer 6. The buffer 6 is formed with, for example, a volatile memory, so as to store temporarily data that are supplied to and from the memory card 1. The memory I/F 7 controls the first to m-th flash memories 3a, 3b, . . . , 3m of the nonvolatile memory group 3, which are connected in parallel, pursuant to an instruction from the main control part 4, while performing data transfer between the buffer 6 and the nonvolatile memory group 3.
Next, the first to m-th flash memories 3a, 3b, . . . , 3m and physical blocks are described in detail, with reference to
As shown in
In each physical block 8, as shown in
The following specifically describes a configuration of page groups of physical pages of physical blocks according to the present embodiment, while referring to
First, the following specifically describes page allocation with respect to the multilevel memory cells provided in the physical blocks 8 of each of the first and second flash memories 3a and 3b, while referring to
Further, in the physical block 8, the page numbers of the physical pages 9 in a predetermined order are allocated to the first page P1 and the second page P2 of each of the multilevel memory cells C1, C2, . . . , C64. More specifically, as shown in
Further, in the memory card 1, page allocation information as described above regarding the allocation of page numbers of the physical pages 9 to the first page P1 and the second page P2 of each of the multilevel memory cells C1, C2, . . . , C64 in the physical block 8 is held by the main control part 4 in advance. Then, based on the page allocation information thus held, with respect to the physical blocks 8 of the first and second flash memories 3a and 3b, the main control part 4 provides a plurality of page groups that include the physical pages 9 defined in the foregoing physical blocks 8. Further, the main control part 4 groups the physical pages 9 of a plurality of the physical blocks 8 in such a manner that boundaries between the page groups are defined behind the second pages P2.
More specifically, as shown in
Besides, a boundary between page groups, for example, a boundary between the page groups 0 and 1, is defined between the multilevel memory cell C1 and the multilevel memory cell C2 of each physical block 8, and the first page P1 of the multilevel memory cell C1 (the physical page 9 having the page number 0) and the next physical page 9 having the page number 1, i.e., the second page P2 of the multilevel memory cell C1, belong to the same page group 0. Behind the second page P2 of the multilevel memory cell C1 (the physical page 9 having the page number 1), the boundary between the page groups 0 and 1 is defined.
Then, when data to be written in the first and second flash memories 3a and 3b are fed from outside, the main control part 4 performs the following: when transfer of data to be written is performed with respect to, among the plurality of physical pages 9 included in any one of the page groups, one physical page 9 other than that as the second page P2, transfer of data to be written is performed with respect to another physical page 9 of the same physical block 8 (i.e., one of the first and second flash memories 3a and 3b) included in the same page group as the page group including the above-mentioned physical page 9; and when transfer of data to be written is performed with respect to the physical page 9 as the second page 2, transfer of data to be written is performed with respect to a physical page 9 of a physical block 8 (i.e, the other of the first and second flash memories 3a and 3b) other than the physical block 8 that includes the above-mentioned physical page 9 as the second page P2. With such transfer of data to be written being performed, the data 0 to 255, which are 256 sets of data in total, are written, in units of physical pages 9, in the first and second flash memories 3a and 3b, as shown in
The following specifically describes a data processing operation in the present embodiment configured as described above, while referring to
[Data Writing Operation]
As shown in
Then, at the time T3 when the main control part 4 causes the programming of the data 1 to be started and a low-level busy signal is supplied from the first flash memory 3a, the main control part 4 switches the destination of transfer of data to the second flash memory 3b, and transfers data 2 to the second flash memory 3b during a period from the time T3 to a time T4. Next, at the time T4, the main control part 4 causes the programming of the data 2 to be started. Since a period from this time T4 to a time T5 for programming the data 2 is a period for writing data in the first page P1 of the multilevel memory cell C1, the main control part 4 is supplied with a high-level busy signal from the second flash memory 3b. Therefore, during the period from the time T4 to the time T5, the main control part 4 continuously transfers data 3 to the second flash memory 3b using a cache program, without switching to the first flash memory 3a.
Subsequently, at the time T5, the main control part 4 causes the programming of the data 3 to be started, a low-level busy signal is supplied from the second flash memory 3b, the programming of the data 1 ends, and a high-level busy signal is supplied from the first flash memory 3a. Then, the main control part 4 switches the destination of transfer of data to the first flash memory 3a, and transfers data 4 to the first flash memory 3a during a period from the time T5 to a time T6. Next, at the time T6, the main control part 4 causes the programming of the data 4 to be started. Since a period from this time T6 to a time T7 for programming the data 4 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the first flash memory 3a. Therefore, during the period from the time T6 to the time T7, the main control part 4 continuously transfers data 5 to the first flash memory 3a using a cache program, without switching to the second flash memory 3b. Thereafter, the main control part 4 performs the same data transfer with respect to the first and second flash memories 3a and 3b, so that data are written therein.
As described above, in the controller (memory controller) 2 of the present embodiment, with respect to the two physical blocks 8 of the first and second flash memories (nonvolatile memories) 3a and 3b in which data are interleaved and written, the main control part 4 defines 64 page groups 0 to 63 including the physical pages 9 defined in the respective physical blocks 8. Besides, the main control part 4 groups the physical pages 9 of the foregoing two physical blocks 8 in such a manner that boundaries between the page groups come behind the physical pages 9 as the second pages P2. With this configuration, unlike the above-described conventional example, it is possible to prevent the programming characteristics of the multilevel memory cells from adversely affecting the data writing operation. As a result, the controller 2 of the present embodiment is capable of effectively interleaving and writing data in the first and second flash memories 3a and 3b in which the multilevel memory cells C1 to C64 are used. Further, in the present embodiment, since the controller 2 capable of effectively interleaving and writing data is used, it is possible to configure easily the memory card (nonvolatile storage device) 1 capable of performing high-speed data writing.
Further, in the present embodiment, as shown in
In physical blocks 8 of first and second flash memories 3a and 3b of the present embodiment, as shown in
Thereafter, page numbers 4 and 6 of the physical pages 9 are allocated to a first page P1 and a second page P2 of a multilevel memory cell C3, respectively, and page numbers 5 and 7 of the physical pages 9 are allocated to a first page P1 and a second page P2 of a multilevel memory cell C4, respectively. Page numbers 124 and 126 of the physical pages 9 are allocated to a first page P1 and a second page P2 of a multilevel memory cell C63, respectively, and page numbers 125 and 127 of the physical pages 9 are allocated to a first page P1 and a second page P2 of a multilevel memory cell C64, respectively. Information of this page allocation in the physical block 8 is held by the main control part 4 in advance. Based on the page allocation information thus held, the main control part 4 groups the physical pages 9 of the physical blocks 8 of the first and second flash memories 3a and 3b.
More specifically, in the present embodiment, as shown in
Further, in the present embodiment, the main control part 4 defines boundaries between the page groups behind the second pages P2 of the multilevel memory cells. In other words, for example, a boundary between the page group 0 and the page group 1 is defined behind the second page P2 of the multilevel memory cell C1 in each physical block 8. Likewise, a boundary between the page group 1 and the page group 2 is defined behind the second page P2 of the multilevel memory cell C2 in each physical block 8.
Then, when data to be written in the first and second flash memories 3a and 3b are fed from outside, the main control part 4 performs the following: when transfer of data to be written is performed with respect to, among the plurality of physical pages 9 included in any one of the page groups, one physical page 9 other than that as the second page P2, transfer of data to be written is performed with respect to another physical page 9 of the same physical block 8 (i.e., one of the first and second flash memories 3a and 3b) included in the same page group as the page group including the above-mentioned physical page 9; and when transfer of data to be written is performed with respect to the physical page 9 as the second page 2, transfer of data to be written is performed with respect to a physical page 9 of a physical block 8 (i.e, the other of the first and second flash memories 3a and 3b) other than the physical block 8 that includes the above-mentioned physical page 9 as the second page P2. With such transfer of data to be written being performed, the data 0 to 255, which are 256 sets of data in total, are written, in units of physical pages 9, in the first and second flash memories 3a and 3b, as shown in
[Data Writing Operation]
The following describes a data writing operation in the present embodiment, while referring to
As shown in
Next, the main control part 4 causes the programming of data 1 to be started at the time T34. Since a period from this time T34 to a time T35 for programming the data 1 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the first flash memory 3a. Therefore, during the period from the time T34 to the time T35, the main control part 4 continuously transfers data 2 to the first flash memory 3a using a cache program, without switching to the second flash memory 3b.
Then, at the time T35 when the main control part 4 causes the programming of the data 2 to be started and a low-level busy signal is supplied from the first flash memory 3a, the main control part 4 switches the destination of transfer of data to the second flash memory 3b, and transfers data 3 to the second flash memory 3b during a period from the time T35 to a time T36. Next, at the time T36, the main control part 4 causes the programming of the data 3 to be started. Since a period from this time T36 to a time T37 for programming the data 3 is a period for writing data in the first page P1 of the multilevel memory cell C1, the main control part 4 is supplied with a high-level busy signal from the second flash memory 3b. Therefore, during the period from the time T36 to the time T37, the main control part 4 continuously transfers data 4 to the second flash memory 3b using a cache program, without switching to the first flash memory 3a.
Next, at the time T37, the main control part 4 causes the programming of the data 4 to be started. Since a period from this time T37 to a time T38 for programming the data 4 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the second flash memory 3b. Therefore, during the period from the time T37 to the time T38, the main control part 4 continuously transfers data 5 to the second flash memory 3b using a cache program, without switching to the first flash memory 3a.
Then, at the time T38 when the main control part 4 causes the programming of the data 5 to be started and a low-level busy signal is supplied from the second flash memory 3b, the main control part 4 switches the destination of transfer of data to the first flash memory 3a, and transfers data 6 to the first flash memory 3a during a period from the time T38 to a time T39. Next, at the time T39, the main control part 4 causes the programming of the data 6 to be started. Since a period from this time T39 to a time T41 for programming the data 6 is a period for writing data in the second page P2 of the multilevel memory cell C2, the main control part 4 is supplied with a low-level busy signal from the first flash memory 3a. Therefore, during the period from the time T39 to the time T41, the main control part 4 is not allowed to transfer data to the first flash memory 3a.
On the other hand, at the time T40 when the programming of the data 5 ends and a high-level busy signal is supplied from the second flash memory 3b, the main control part 4 determines that the second flash memory 3b is ready for receiving data transferred thereto, switches the destination of transfer of data to the second flash memory 3b, and transfers data 7 to the second flash memory 3b during a period from the time T40 to a time T41. Then, the main control part 4 causes the programming of the data 7 to be started at the time T41. Since a period from this time T41 to a time T43 for programming the data 7 is a period for writing data in the second page P2 of the multilevel memory cell C2, the main control part 4 is supplied with a low-level busy signal from the second flash memory 3b. Therefore, during the period from the time T41 to the time T43, the main control part 4 is not allowed to transfer data to the second flash memory 3b.
On the other hand, at the time T41 when the programming of the data 6 ends and a high-level busy signal is supplied from the first flash memory 3a, the main control part 4 determines that the first flash memory 3a is ready for receiving data transferred thereto, switches the destination of transfer of data to the first flash memory 3a, and transfers data 8 to the first flash memory 3a during a period from this time T41 to a time T42. Thereafter, the main control part 4 performs the same data transfer operation with respect to the first and second flash memories 3a and 3b, so that data are written therein.
With the above-described configuration, the present embodiment achieves the same effects as those of Embodiment 1 described above.
More specifically, as shown in
Further, in the case where data to be written in the first to third flash memories 3a to 3c are fed from outside, the main control part 4 in the present embodiment performs the following, like in Embodiments described above: when transfer of data to be written is performed with respect to, among the plurality of physical pages 9 included in any one of the page groups, one physical page 9 other than that as the second page P2, transfer of data to be written is performed with respect to another physical page 9 of the same physical block 8 (i.e., one of the first to third flash memories 3a to 3c) included in the same page group as the page group including the above-mentioned physical page 9; and when transfer of data to be written is performed with respect to the physical page 9 as the second page 2, transfer of data to be written is performed with respect to a physical page 9 of a physical block 8 (i.e, one of the first to third flash memories 3a to 3c that is other than the foregoing one of the first to third flash memories 3a to 3c) other than the physical block 8 that includes the above-mentioned physical page 9 as the second page P2. With such transfer of data to be written being performed, the data 0 to 383, which are 384 sets of data in total, are written, in units of physical pages 9, in the first to third flash memories 3a to 3c, as shown in
[Data Writing Operation]
The following describes a data writing operation in the present embodiment, while referring to
As shown in
Next, the main control part 4 causes the programming of data 1 to be started at the time T62. Since a period from this time T62 to a time T63 for programming the data 1 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the first flash memory 3a. Therefore, during the period from the time T62 to the time T63, the main control part 4 continuously transfers data 2 to the first flash memory 3a using a cache program, without switching to the second or third flash memory 3b or 3c.
Then, at the time T63 when the main control part 4 causes the programming of the data 2 to be started and a low-level busy signal is supplied from the first flash memory 3a, the main control part 4 switches the destination of transfer of data to, for example, the second flash memory 3b, and transfers data 3 to the second flash memory 3b during a period from the time T63 to a time T64. Next, at the time T64, the main control part 4 causes the programming of the data 3 to be started. Since a period from this time T64 to a time T65 for programming the data 3 is a period for writing data in the first page P1 of the multilevel memory cell C1, the main control part 4 is supplied with a high-level busy signal from the second flash memory 3b. Therefore, during the period from the time T64 to the time T65, the main control part 4 continuously transfers data 4 to the second flash memory 3b using a cache program, without switching to the first or third flash memory 3a or 3c.
Next, at the time T65, the main control part 4 causes the programming of the data 4 to be started. Since a period from this time T65 to a time T66 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the second flash memory 3b. Therefore, during the period from the time T65 to the time T66, the main control part 4 continuously transfers data 5 to the second flash memory 3b using a cache program, without switching to the first or third flash memory 3a or 3c.
Next, at the time T66, the main control part 4 causes the programming of the data 5 to be started. Since a period from this time T66 to a time T70 for programming the data 5 is a period for writing data in the second page P2 of the multilevel memory cell C1, the main control part 4 is supplied with a low-level busy signal from the second flash memory 3b. Therefore, during the period from the time T66 to the time T70, the main control part 4 is not allowed to transfer data to the second flash memory 3b.
On the other hand, at the time T67 when the programming of the data 2 ends and a high-level busy signal is supplied from the first flash memory 3a, the main control part 4 determines that the first flash memory 3a is ready for receiving data transferred thereto, switches the destination of transfer of data to the first flash memory 3a, and transfers data 6 to the first flash memory 3a during a period from the time T67 to a time T68. Then, the main control part 4 causes the programming of the data 6 to be started at the time T68. Since a period from this time T68 to a time T72 for programming the data 6 is a period for writing data in the second page P2 of the multilevel memory cell C2, the main control part 4 is supplied with a low-level busy signal from the first flash memory 3a. Therefore, during the period from the time T68 to the time T71, the main control part 4 is not allowed to transfer data to the first flash memory 3a.
Therefore, the main control part 4 switches the destination of transfer of data to the third flash memory 3c, and transfers data 7 to the third flash memory 3c during a period from the time T68 to a time T69. Next, at the time T69, the main control part 4 causes the programming of the data 7 to be started. Since a period from this time T69 to a time T70 for programming the data 7 is a period for writing data in the first page P1 of the multilevel memory cell C1, the main control part 4 is supplied with a high-level busy signal from the third flash memory 3c. Therefore, during the period from the time T69 to the time T70, the main control part 4 continuously transfers data 8 to the third flash memory 3c using a cache program, without switching to the first or second flash memory 3a or 3b.
Next, at the time T70, the main control part 4 causes the programming of the data 8 to be started. Since a period from this time T70 to a time T71 for programming the data 8 is a period for writing data in the first page P1 of the multilevel memory cell C2, the main control part 4 is supplied with a high-level busy signal from the third flash memory 3c. Therefore, during the period from the time T70 to the time T71, the main control part 4 continuously transfers data 9 to the third flash memory 3c using a cache program, without switching to the first or second flash memory 3a or 3b.
Next, the main control part 4 causes the programming of the data 9 to be started at the time T71. Since a period from this time T71 to a time T75 for programming the data 9 is a period for writing data in the second page P2 of the multilevel memory cell C1, the main control part 4 is supplied with a low-level busy signal from the third flash memory 3c. Therefore, during the period from the time T71 to the time T75, the main control part 4 is not allowed to transfer data to the third flash memory 3c.
On the other hand, at the time T70 when the programming of the data 5 ends and a high-level busy signal is supplied from the second flash memory 3b, the main control part 4 determines that the second flash memory 3b is ready for receiving data transferred thereto, switches the destination of transfer of data to the second flash memory 3b, and transfers data 10 to the second flash memory 3b during a period from the time T71 to a time T72. Then, the main control part 4 causes the programming of the data 10 to be started at the time T72. Since a period from this time T72 to a time T76 for programming the data 10 is a period for writing data in the second page P2 of the multilevel memory cell C2, the main control part 4 is supplied with a low-level busy signal from the second flash memory 3b. Therefore, during the period from the time T72 to the time T76, the main control part 4 is not allowed to transfer data to the second flash memory 3b.
On the other hand, at the time T72 when the programming of the data 6 ends and a high-level busy signal is supplied from the first flash memory 3a, the main control part 4 determines that the first flash memory 3a is ready for receiving data transferred thereto. Therefore, the main control part 4 switches the destination of transfer of data to the first flash memory 3a, and transfers data 11 to the first flash memory 3a during a period from the time T72 to a time T73. Thereafter, the main control part 4 performs the same data transfer operation with respect to the first to third flash memories 3a to 3c, so that data are written therein.
With the above-described configuration, the present embodiment achieves the same effects as those of Embodiment 2 described above.
The above-described embodiments are merely illustrative and not limiting. The technical scope of the present invention is specified by the scope of the claims, and any modification falling in the scope of the configuration described therein and equivalent thereto also fall in the technical scope of the present invention.
For example, the foregoing description describes a case where the present invention is applied to a memory card (nonvolatile storage device), but the memory controller of the present invention is not limited to this; it may be applied to another nonvolatile storage device, such as a flash disk.
Further, the foregoing description describes a case where the present invention is applied to a nonvolatile storage device having two or three flash memories (nonvolatile memories) in which 64 multilevel memory cells, each of which has a first page and a second page so as to be capable of storing two-bit data (information), are used for forming physical blocks. The memory controller of the present invention, however, is not limited to those described above, regarding the page configuration of multilevel memory cells, the number of the same, etc., as long as the memory controller has the following configuration: each of the plurality of physical blocks includes the multilevel memory cells, which are p in number, first to p-th multilevel memory cells (p is an integer of not less than 2); in each of the p multilevel memory cells, n pages that are first to n-th pages are provided as physical pages that are writing units for data (n is an integer of not less than 2) wherein as compared with a time required for a data writing operation with respect to the first page, the time required for a data writing operation with respect to a subsequent page increases sequentially as the page number increases; and in the case where in each of the plurality of physical blocks, page numbers are allocated sequentially to all the physical pages provided in the p multilevel memory cells in a predetermined order, the main control part defines, in the plurality of physical blocks, a plurality of page groups that include the physical pages provided in the physical blocks, and groups the physical pages of the plurality of physical blocks so that boundaries between the page groups are defined behind the physical pages as the n-th pages.
Further, in a case other than that described above, such as a case where the first to n-th pages are provided in the multilevel memory cell, it is preferable that when transfer of data to be written is performed with respect to, among the plurality of physical pages included in the page groups, one physical page as the first page, the main control part performs transfer of data to be written with respect to another physical page of the same physical block included in the same page group as the page group including the above-mentioned physical page, and when transfer of data to be written is performed with respect to the physical page as the n-th page, the main control part performs transfer of data to be written with respect to a physical page of a physical block other than the physical block that includes the above-mentioned physical page as the n-th page. This makes it possible that, like in the above-described embodiments, while transfer of data to be written is being performed with respect to the physical page of the n-th page, transfer of data to be written can be performed with respect to a physical page of a physical block other than a physical block that includes the foregoing physical page of the n-th page. Therefore, data can be interleaved and written more surely and efficiently.
Though the above description explains the case in which the main control part groups the physical pages of the plurality of physical blocks so that each of the plurality of page groups includes the physical pages having the same page numbers in the plurality of physical blocks, the main control part of the present invention is not limited to this. The grouping may be performed in such a manner that physical pages having different page numbers in a plurality of physical blocks may be grouped into one page group.
It is preferable, however, that as in the above-described embodiments, physical pages having the same page numbers are grouped into one page group. The reason is as follows: in this case, the grouping of physical pages with respect to a plurality of physical blocks can be carried out easily, and the management of data written in physical pages can be facilitated, whereby the nonvolatile memory driving control can be carried out easily.
Further, though the above description explains a configuration in which the main control part groups physical pages so that physical pages of a plurality of physical blocks included in each of a plurality of flash memories are included in each of a plurality page groups, the present invention is not limited to this configuration.
Physical pages of a plurality of physical blocks included in a single nonvolatile memory may be grouped, and data may be written therein in parallel. More specifically, in a nonvolatile memory having a multiplane structure that is configured so that data writing operations with respect to a plurality of different physical blocks are performed concurrently, physical pages of a plurality of physical blocks in the single nonvolatile memory may be grouped.
Still further, though the above description explains a case where a flash memory of the NAND type is used as the nonvolatile memory, the present invention is not limited to this. The present invention may be applied to a flash memory of another type, such as the MONOS type or the AND type.
The present invention is useful for a memory controller capable of efficiently interleaving and writing data in a nonvolatile memory in which multilevel memory cells are used, and a nonvolatile storage device configured to perform high-speed memory access.
Number | Date | Country | Kind |
---|---|---|---|
2007-190004 | Jul 2007 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2008/001904 | 7/16/2008 | WO | 00 | 8/6/2009 |