This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2009-022044, filed on Feb. 2, 2009; the entire contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to a memory system and an interleaving control method of a memory system.
2. Description of the Related Art
As a memory system used for a computer system, a solid state drive (SSD) having a nonvolatile semiconductor memory such as a NAND flash memory (hereinafter, “NAND memory”) incorporated therein has attracted attention. Memory systems such as an SSD have advantages such as higher operation speed and lightweight as compared to magnetic disk drives.
Recently, to improve transfer efficiency, a function of performing bank interleaving has been adopted. Specifically, a NAND memory incorporated in an SSD is divided into a plurality of memory areas (banks) capable of performing memory operations including data write at the same time, and a bank to be written with data is sequentially switched at the time of performing data write to the NAND memory continuously (see, for example, U.S. Patent Application Publication No. 2006/0152981).
A memory system according to an embodiment of the present invention comprises:
a plurality of nonvolatile memory areas capable of operating individually; and
a memory controller connected to each of the memory areas individually via a ready/busy signal for interleaving an operation in the memory areas by changing a memory area as a target of an operation command, every time the operation command is transmitted, wherein
the memory controller includes a priority-level managing unit that manages a level of selection priority for each memory area, so that after transmission of an operation command, the memory controller selects a memory area with a highest level of selection priority from memory areas in a ready state, to change the selected memory area to a target of a next operation command, and shifts the level of selection priority of the selected memory area at a time of next selection to a lowest level by the priority-level managing unit.
A memory system according to an embodiment of the present invention comprises:
a plurality of nonvolatile memory areas capable of operating individually; and
a memory controller connected to each of the memory areas individually via a ready/busy signal for interleaving an operation in the memory areas by changing a memory area as a target of an operation command, every time the operation command for performing a plurality of operations is transmitted, wherein
the memory controller includes a priority-level managing unit that manages a level of selection priority for each memory area, and an operation-state recognizing unit that recognizes whether the operation command is being performed based on the ready/busy signal, so that after transmission of the operation command, a memory area with a highest level of selection priority is selected from the memory areas, in which the operation command is not being performed, to change the selected memory area to a next memory area as a target of a next operation command, and shifts the level of selection priority of the selected memory area at a time of next selection to a lowest level by the priority-level managing unit.
An interleaving control method of a memory system according to an embodiment of the present invention comprises:
selecting a memory area with a highest level of selection priority from the memory areas in a ready state based on a level of selection priority of each memory area set beforehand, to designate the selected memory area as a memory area as a target of the operation command;
transmitting the operation command to the memory area as the target of the operation command; and
shifting the level of selection priority of the selected memory area at a time of next selection to a lowest level.
The time required for a memory operation including data write to a NAND memory is different between chips due to a production tolerance or the like. Therefore, the time required for a data write operation can be different between banks. Even if bank interleaving is performed, as each bank is focused on, a blank time occurs during which any of a reception operation or a write operation of data is not performed due to a difference in time required for the write operation. It has been found by the present inventor that if the blank time occurs disproportionately in a specific bank, transfer speed of data with respect to the entire NAND memory decreases, and the transfer efficiency is degraded. In U.S. Patent Application Publication No. 2006/0152981, there is no description or suggestion of any technique for solving this problem.
Exemplary embodiments of a memory system and an interleaving control method of a memory system according to the present invention will be explained below in detail with reference to the accompanying drawings. The present invention is not limited to the following embodiments.
The SSD is connected to a host device such as a personal computer via an advanced technology attachment (ATA)-standard communication interface, and functions as an external storage unit of the host device. The SSD includes a NAND memory 2, which is a nonvolatile memory that stores data to be read or written by the host device, a data transfer apparatus 1 that performs data transfer control of the SSD, and a random access memory (RAM) 3, which is a nonvolatile memory that temporarily stores transfer data for data transfer by the data transfer apparatus 1. The data transmitted from the host device is stored once in the RAM 3 under control of the data transfer apparatus 1, and then read from the RAM 3 and written into the NAND memory 2.
The data transfer apparatus 1 includes an ATA interface controller (ATA controller) 10 that performs control of the ATA interface (I/F) and control of the data transfer between the host device and the RAM 3, a RAM controller 30 that controls read and write of data with respect to the RAM 3, a NAND controller 20 that performs control of the data transfer between the NAND memory 2 and the RAM 3, and a micro processing unit (MPU) 40 that performs control of the entire data transfer apparatus 1 based on firmware.
The NAND memory 2 has four parallel operation elements 2a to 2d that operate in parallel, and the parallel operation elements 2a to 2d are respectively connected to the NAND controller 20 via a signal line group (channels ch0 to ch3) independently. The parallel operation elements 2a to 2d are divided into bank 0 to bank 3, which are four memory areas capable of operating individually. Each bank includes one or more memory chips (NAND flash memory). For example, a configuration of including one chip, two chips, or four chips for each bank can be considered. Each memory chip includes a plurality of blocks (physical blocks), which is a minimum unit capable of erasing data independently. Each block includes a plurality of pages (physical pages), which is a unit capable of writing and reading collectively.
Each memory cell transistor MT includes a metal oxide semiconductor field effect transistor (MOSFET) having a laminate gate structure formed on a semiconductor substrate. The laminate gate structure includes a charge accumulation layer (floating gate electrode) formed on the semiconductor substrate via a gate insulating film and a control gate electrode formed on the charge accumulation layer via an inter-gate insulating film. In the memory cell transistor MT, a threshold voltage changes according to the number of electrons accumulated in the floating gate electrode, and the memory cell transistor MT stores data according to a difference in the threshold voltage.
The memory cell transistor MT can be configured to store one bit or multiple values (data of two or more bits).
In each NAND string, (n+l) memory cell transistors MT are arranged between the source of the selection transistor ST1 and the drain of the selection transistor ST2 so that respective current pathways are serially connected. That is, a plurality of memory cell transistors MT is serially connected in a Y direction in such a form that adjacent memory cell transistors share a diffusion region (source region or drain region). A control gate electrode is respectively connected to word lines WL0 to WLn sequentially from the memory cell transistor MT positioned closest to the drain side. Therefore, the drain of the memory cell transistor MT connected to the word line WL0 is connected to the source of the selection transistor ST1, and the source of the memory cell transistor MT connected to the word line WLn is connected to the drain of the selection transistor ST2.
The word lines WL0 to WLn commonly connect the control gate electrodes of the memory cell transistors MT between the NAND strings in the block. That is, the control gate electrodes of the memory cell transistors MT in the same row in the block are connected to the same word line WL. The (m+l) memory cell transistors MT connected to the same word line WL are handled as a page, and read/write is performed for each page.
Bit lines BL0 to BLm commonly connect the drains of the selection transistors ST1 between blocks. That is, the NAND strings in the same line in a plurality of blocks are connected to the same bit line BL.
Further, the memory cell transistor MT can have not only a configuration having the floating gate electrode but also a configuration capable of adjusting a threshold by trapping an electron on a nitride film interface as the charge accumulation layer, such as a metal-oxide-nitride-oxide-silicon (MONOS) transistor. The memory cell transistor MT having an MONOS structure can be configured to store one bit or multiple values (data of two or more bits) in the same manner.
In the quaternary data storage system, either one of quaternary data “xy” defined by high-order page data “x” and low-order page data “y” can be held in the memory cell transistor MT.
In the quaternary data “xy”, for example, data “11”, “01”, “00”, and “10” are allocated in order of threshold voltage of the memory cell transistor MT. In data “11”, the threshold voltage of the memory cell transistor MT is in a negative erased state.
In a write operation of a low-order page, data “10” is selectively written into the memory cell transistor MT for data “11” (in the erased state) by write of low-order bit data “y”.
Threshold distribution of data “10” before write of the high-order page is positioned in the middle of threshold distribution of data “01” and data “00” after write of the high-order page, and can be broader than threshold distribution after write of the high-order page.
In the write operation of the high-order page, write of high-order bit data “x” is performed selectively to a memory cell for data “11” and a memory cell for data “10”, and data “01” and data “00” are written therein.
Referring back to
A size of data that can be written into a bank at a time is predetermined, and hereinafter, this size is referred to as a unit write size. The unit write size has a value equal to a page (physical page) size in the first embodiment. Connection between the respective parallel operation elements 2a to 2d and the NAND controller 20 will be explained later in detail. An example of a nonvolatile semiconductor memory device having a plurality of independent buses to the NAND memory and enabling independent event processing with respect to each flash memory chip is disclosed in Japanese Patent Application Laid-Open No. H10-187359 filed by the same applicant.
When the data stored in the RAM 3 is read and written into the NAND memory 2, the MPU 40 issues a write request for transferring data from the RAM 3 to the NAND memory 2 to the NAND controller 20. The NAND controller 20 reads transfer data in each unit write size from the RAM 3 based on the write request, and sequentially transfers the read transfer data in each unit write size to the NAND memory 2. Each bank of the parallel operation elements as a write destination (transfer destination) in the NAND memory 2 writes the transfer data therein.
Each bank cannot receive the next transfer data while data write is being executed. Further, the NAND controller 20 cannot transfer a plurality of transfer data simultaneously via one channel. Therefore, the SSD according to the first embodiment has a function of performing the bank interleaving with respect to the data write operation. The bank interleaving with respect to the data write operation is specifically explained below.
First, when a plurality of pieces of transfer data are to be written into a certain parallel operation element, the MPU 40 allocates a write destination bank for each transfer data so that the write destinations of the transfer data are uniformly distributed to a plurality of banks included in the parallel operation element. For example, when 12 pieces of transfer data are written into the parallel operation element 2a, the banks 0 to 3 of the parallel operation element 2a become the write destination of 3 pieces of transfer data, respectively. When a logical address (logical block addressing: LBA) specified by the host device is associated with a bank, the MPU 40 selects pieces of transfer data that can be bank interleaved, to improve transfer efficiency.
The NAND controller 20 reads 12 pieces of transfer data from the RAM 3 and transfers 3 pieces of transfer data, respectively, to the banks 0 to 3 one by one sequentially. At this time, the NAND controller 20 selects a bank which is not performing the data write operation, after a piece of transfer data has been transferred, and performs the transfer operation of another piece of transfer data, for which the selected bank is designated as a write destination. In other words, the NAND controller 20 switches (changes) the bank as the write destination (transfer destination) every time a piece of data has been transferred. When there is no bank which is not performing the data write operation, the NAND controller 20 waits until any one bank finishes the data write operation.
By performing the bank interleaving with respect to the write operation, the time since the transfer operation of the transfer data was performed by the NAND controller 20 until the next transfer operation is performed can be reduced, and as a result, the transfer efficiency is improved as compared to a case that the bank interleaving is not performed. The NAND controller 20 is configured such that the bank interleaving is performed with respect to the data write operation independently, for the banks 0 to 3 included in the respective parallel operation elements 2b to 2d, which operate at the same time with the parallel operation element 2a. When the physical blocks belonging to the same bank are selected one each from the respective channels (ch0 to ch3) to form the logical block, parallel access is performed with respect to the banks of the same number included in the respective parallel operation elements 2a to 2d.
A method of selecting a transfer destination bank at the time of performing a bank interleaving operation is explained next. In the following explanations, a state in which the data write operation is being performed is expressed as a busy state, and a state in which the data write operation is not being performed is expressed as a ready state.
As a method compared with the first embodiment, there is a method of setting a priority level to the banks 0 to 3, and fixing the priority level from a level with high priority, for example, bank 0→bank 1→bank 2→bank 3. This method is referred to as a method of a comparative example. That is, according to the method of the comparative example, after a piece of transfer data has been transferred to a certain bank, the NAND controller 20 selects a bank from the banks in a ready state based on the fixed priority level to switch the transfer destination bank to the selected bank.
The time required for data write is different for each bank. Due to this difference, a blank time can occur after completion of the data write operation until the next transfer data is transferred. If the blank time occurs disproportionately in a specific bank, transfer efficiency as a whole can be degraded. According to the method of the comparative example, a deviation of the blank time cannot be prevented. On the other hand, the first embodiment has a main characteristic in that it is prevented that the blank time occurs disproportionately in a specific bank by sequentially updating the priority level so that priority becomes higher in an old bank with the longer elapsed time since execution of the last data transfer. A difference in the operation between the method of the comparative example and the method of the first embodiment is schematically explained below by way of examples.
As shown in the upper part of
As the operation history of the bank 3 is focused on, a longer blank time has occurred since completion of write of transfer data by data transfer 4 until the next data transfer 11 is started. Due to the blank time, the time required for transfer and write of 3 pieces of data in the bank 3 becomes prominently long as compared to other banks. As a result, it is understood that the time required since start of transfer of 12 pieces of data in total until write of all pieces of data finishes becomes long.
According to the method of the first embodiment shown in the lower part of
According to the operation history by the method of the first embodiment, the blank time occurred in the bank 3 in the example of the operation history in the method of the comparative example is distributed to the banks 1 to 3. As a result, it is understood that the total transfer time required until write of all 12 pieces of data finishes is reduced as compared to the method of the comparative example, and transfer speed is improved. That is, when the method of the first embodiment is adopted, the transfer efficiency is improved as compared to a case of adopting the method of the comparative example.
Generally, write into a low-order page is performed at a higher speed than the write into a high-order page. The write of the transfer data transferred by data transfers 5, 6, 7, and 11 in the method of the comparative example shown in the upper part of
The banks 0 to 3 of the parallel operation element 2a is individually connected to the ch0 controller 210, respectively, via ready/busy (Ry/By) signal lines (Ry/By0 to Ry/By3). The banks 0 to 3 individually notify the ch0 controller 210 via the Ry/By signal lines, respectively, of whether the bank itself is in a busy state or ready state. As an example, it is assumed that Ry/By=L indicates a busy state and Ry/By=H indicates a ready state. The banks 0 to 3 are individually connected to the ch0 controller 210, respectively, via chip enable (CE) signal lines (CE0 to CE3) for selecting a chip. When the respective banks have a plurality of memory chips, the Ry/By signal lines and the CE signal lines of the respective memory chips are commonly connected.
One end of a Cont. I/O signal line for transferring a command, address, and data is connected to the ch0 controller 210. The other end of the Cont. I/O signal line is branched to four, and the branched four Cont. I/O signal lines are respectively connected to the banks 0 to 3. The ch0 controller 210 transmits a write command including a data write command, an address of write destination, and transfer data in the unit write size read from the RAM 3 one each to the four banks 0 to 3 via the Cont. I/O signal line. Because the NAND memory 2 side of the Cont. I/O signal line is branched to four and connected to the banks 0 to 3, the banks 0 to 3 receive the same write command simultaneously. However, the respective banks 0 to 3 determine whether to execute the write command based on the level of the CE signal line.
More specifically, the respective memory chips constituting the bank i include a primary buffer (data cache) that temporarily stores the transmitted transfer data and a secondary buffer (page buffer) intervening between the data cache and a memory cell array.
The ch0 controller 210 transfers the transfer data in the unit write size (page size) included in the write command to the data cache. Upon reception of the data write command following the transfer data, the respective memory chips constituting the bank i set Ry/By=L and transfer the transfer data stored in the data cache to the page buffer.
The respective memory chips constituting the bank i program the transfer data transferred to the page buffer into the write address in the memory cell array, which is a storage area. Further, the respective memory chips constituting the bank i read the programmed data from the memory cell array and compare the read data with the transfer data held in the page buffer, to verify whether the transfer data is correctly programmed in the memory cell array (Program and Verify).
As a result of comparison and verification, when the both data match each other, the respective memory chips constituting the bank i recognize that the transfer data has been correctly programmed in the memory array cell, set Ry/By=H, and finish the write operation involved with the received write command. As a result of comparison and verification, when the both data do not match each other, the respective memory chips constituting the bank i attempt to program the transfer data held in the page buffer in the memory cell array until the both data match each other as the result of comparison and verification. The number of attempts is set to a desired value beforehand.
Thus, because the write operation of the transfer data in the respective memory chips constituting the bank i includes transfer of the transfer data from the data cache to the page buffer, programming of the transfer data in the memory cell array, and read and verification of the programmed data, a longer time is required as compared to the data transfer operation from the ch0 controller 210 to the bank i.
In this example, the write command includes the data input command, write address, transfer data, and data write command. However, the write command can transmit different information in addition to these pieces of information.
Referring back to
The command processor 212 reads the transfer data from the RAM 3 based on the write request received from the MPU 40, to generate a write command. For example, the command processor 212 can include a storage area therein such as a register or small memory so that the generated write command is held therein, or held in other storage areas. The command processor 212 selects a data transfer destination bank (a bank as a target of the write command) based on the states of the banks 0 to 3 notified via the Ry/By signal lines and the priority level managed by the priority-level managing unit 211, and transmits the write command in which the selected bank is set as a write destination to the banks 0 to 3 via the Cont. I/O signal line.
While it is explained that the Ry/By signal line for each bank of the parallel operation element 2a is connected to the ch0 controller 210, the Ry/By signal line for each bank can be commonly connected between the parallel operation elements 2a to 2d and input to the NAND controller 20. A specific configuration example of the NAND controller 20, taking into consideration parallel operations between channels when the Ry/By signal lines for respective banks are commonly connected is explained with reference to
The NAND controller 20 includes a DMA controller (DMAC) 60, an error correction circuit (ECC) 61, and a NAND I/F 62 so that each parallel operation element is independently operated. Each NAND I/F 62 is connected with CE signal lines for four banks (CE0 to CE3), to control the CE signal lines (CE0 to CE3) according to the bank to be accessed.
The NAND controller 20 further includes an arbiter 63 that arbitrates a right of use of the channel, and four bank controllers (BANK-C) 64 that monitor the Ry/By signal lines commonly connected between the parallel operation elements 2a to 2d for each bank and manage the state of the bank. In the first embodiment, because four banks share one channel, when a plurality of access requests is overlapped, the arbiter 63 arbitrates the right of use of the channel to use the channel in a time-sharing manner.
A correspondence relation between the ch0 controller 210 and the configuration example shown in
The write command generated by the command processor 212 placed in the arbiter 63 is queued to one of the four BANK-Cs 64 corresponding to the write destination bank. The command processor 212 receives Ry/By=H from the four BANK-Cs 64 based on the array managed by the priority-level managing unit 211, reads the write command from the BANK-C that manages the bank with the highest priority, and transmits the read write command to the parallel operation element 2a via the NAND I/F 62.
The priority-level managing unit and the command processor respectively included in the ch1 controller 220 to ch3 controller 240 are placed in the arbiter 63 in the same manner, and integrated with the priority-level managing unit 211 and the command processor 212. The priority-level managing unit 211 and the command processor 212, one of the DMACs 60, ECCs 61, and NAND I/Fs 62 of the corresponding ch, and the BANK-C 64 cooperate and function as the ch1 controller 220 to ch3 controller 240, respectively.
An operation of transferring data from the NAND controller 20 to the NAND memory 2 in the SSD according to the first embodiment configured as described above is explained next with reference to
When there is a bank with Ry/By=H (YES at Step S22), the command processor 212 refers to the array managed by the priority-level managing unit 211 from the top, to select a bank with the highest priority among the banks with Ry/By=H (Step S23). When there is only a bank with Ry/By=H, the command processor 212 selects this bank. Following Step S23, the command processor 212 selects a write command designating the selected bank as a write destination from the generated write commands, and transmits the write command to the banks C to 3 of the parallel operation element 2a (Step S24).
When transmission of the write command is started at Step S24, the priority-level managing unit 211 shifts the number of the bank, which executes the transmitted write command, that is, the number of the bank selected at Step S24 to the last of the array of priority level, so that a position of a bank number in the back of the array than the bank number before the shift is brought forward toward the top of the array one by one (Step S25). It is assumed that the array of priority level is updated when transmission of the write command is started. However, update can be performed immediately after the write command is transmitted, or during the write command is being transmitted. Accordingly, when the command processor 212 proceeds to Step S23 next time, the priority of the bank selected this time at Step S23 is the lowest.
The command processor 212 determines whether all the generated write commands have been transmitted (Step S26), and when there is an untransmitted write command (NO at Step S26), the command processor 212 proceeds to Step S22. When all the write commands have been transmitted (YES at Step S26), the operation finishes.
In this manner, a bank with the longest elapsed time since the last execution of the data transfer is preferentially selected as the transfer destination bank.
As described above, according to the first embodiment, the ch0 controller 210 selects a bank with the highest selection priority from the banks in a ready state included in the parallel operation element 2a, after transmission of the write command, changes the selected bank as a target of the next write command, and shifts the level of selection priority of the selected bank at the time of next selection of the bank to the lowest level. Therefore, the blank time occurring in the individual operation history in each bank is distributed to a plurality of banks, thereby enabling to perform an efficient bank interleaving operation. Further, because the selection priority of the banks is managed in an array of the bank number, a bank with the longest elapsed time since last transmission of an operation command is preferentially selected, without mounting a complicated mechanism that records a transmission time of the operation command and compares the transmission time with each other.
A case that the bank interleaving is performed with respect to the data write operation has been explained above. However, the method of the first embodiment can be applied to cases other than the case of performing data write, so long as the operation enables bank interleaving. For example, when the bank interleaving is performed with respect to a data read operation, after a read command including a read command and a read source address is transmitted, a bank as a data read source is changed based on the Ry/By signal line and the level of selection priority, and the level of selection priority at the time of next selection of the bank to be changed can be shifted to the lowest level. When the bank interleaving is performed with respect to a data erasure operation, after a data erasure command including a data erasure command and an address of data to be erased is transmitted, a bank as a target of the data erasure command is changed based on the Ry/By signal line and the level of selection priority, and the level of selection priority at the time of next selection of the bank to be changed can be shifted to the lowest level. At this time, each bank is set to output Ry/By=L (busy state) when not only the data write operation but also the data read operation and the data erasure operation are being performed, and output Ry/By=H (ready state) when the data write operation, the data read operation, and the data erasure operation are not being performed. Further, each bank can output Ry/By=L when the bank is in a ready state, and Ry/By=H when the bank is in a busy state.
A case that the bank interleaving is performed in the same kind of operation (here, data write) between the banks has been explained above. However, the method of the first embodiment can be applied to a case that the bank interleaving is performed with respect to different kinds of operation (data write, data read, and data erasure) between the banks. That is, a bank as a target of the operation command (write command, read command, and data erasure command) (a transfer destination bank, a read source bank, and a bank as a target of the data erasure command) is changed based on the Ry/By signal line and the level of selection priority, and the level of selection priority at the time of next selection of the bank as a target of the command can be shifted to the lowest level.
Further, while it has been explained that the four parallel operation elements are included and each parallel operation element is divided into four banks, the number of parallel operation elements and the number of banks in each parallel operation element are not limited to these numbers.
Recently, a technique in which an inside of each memory chip constituting each bank is divided into a plurality of planes having a peripheral circuit (row decoder, column decoder, or the like) individually, and the planes are caused to perform different memory operations, respectively, by a memory operation command, thereby realizing high-speed memory access has been developed. An example of a nonvolatile semiconductor memory device having a plurality of planes is disclosed in U.S. Patent Application Publication No. 2007/0206419. According to this technique, each plane individually includes a data cache and a page buffer.
As shown in
When the data input command, first write address, first transfer data, and dummy write command are transmitted to the Cont. I/O signal line, the bank i changes the state of the Ry/By signal line from H to L, and thereafter, changes the state of the Ry/By signal line from L to H. The bank i accumulates the transmitted first transfer data in the data cache 0. Upon detection of a change in the state of the Ry/By signal line from H to L, the ch0 controller starts an operation of transmitting the data input command, second write address as the address of the plane 1 of the bank i, second transfer data, and data write command to the Cont. I/O signal line. The bank i accumulates the transmitted second transfer data in the data cache 1. When the data write command is transmitted, the bank i simultaneously starts the write operation of the first transfer data accumulated in the data cache 0 and the write operation of the second transfer data accumulated in the data cache 1, and changes the state of the Ry/By signal line from H to L. Upon completion of the write operation in the plane 0 and plane 1, the bank i changes the state of the Ry/By signal line from L to H. Thus, because the data cache in a plurality of planes respectively accumulates the transfer data, and concurrently starts the write operation of the transfer data in the planes by a data write command, high-speed write can be realized as compared to the case that a write command (hereinafter, “single write command”) is transmitted continuously in a plurality of numbers explained in the first embodiment. Because the transfer data for two pages is written in the respective banks by a multiple write command, the size of two pages becomes the unit write size.
As focusing on the Ry/By signal line, it is understood that the state of the Ry/By signal line is changed from L to H, at times other than at the time of completion of a multiple write operation. Therefore, if the transfer destination is simply selected from the banks with the state of the Ry/By signal line being H as in the first embodiment, bank switching timing becomes between completion of the write operation of the first transfer data and start of reception of the second transfer data. If the transfer destination bank is selected at this timing, the second transfer data, which is to be transferred to the bank, cannot be transferred. To solve this problem, in a second embodiment of the present invention, it is configured such that the transfer destination bank is selected from the banks in which write of all pieces of transfer data has been complete based on the multiple write command.
The NAND controller 50 includes four controllers (a ch0 controller 510, a ch1 controller 520, a ch2 controller 530, and a ch3 controller 540) as memory controllers that respectively control data transfer to the parallel operation elements 2a to 2d. Because the ch0 controller 510, the ch1 controller 520, the ch2 controller 530, and the ch3 controller 540 have the same function, only the ch0 controller 510 is explained below as a representative. In
A relation of connection between the parallel operation element 2a and the ch0 controller 510 is the same as the relation of connection between the parallel operation element 2a and the ch0 controller 210 according to the first embodiment. Therefore, detailed explanations thereof will be omitted.
The ch0 controller (memory controller) 510 further includes the priority-level managing unit 211, a command processor 512 that transmits the multiple write command to the banks 0 to 3 of the parallel operation element 2a, and an operation-state recognizing unit 513 that recognizes an operation state of the banks 0 to 3 of the parallel operation element 2a.
The priority-level managing unit 211 sequentially updates and manages the priority level of the banks 0 to 3, as in the first embodiment. The operation-state recognizing unit 513 recognizes the operation state of each bank, that is, whether the multiple write command transmitted from the command processor 512 is complete for each bank, based on the state of the Ry/By signal line. The command processor 512 selects a transfer destination bank of the transfer data based on the operation state of each bank recognized by the operation-state recognizing unit 513, and the priority level managed by the priority-level managing unit 211, and transmits a multiple write command to the selected bank.
An operation for transferring data from the NAND controller 50 to the NAND memory 2 in the SSD according to the second embodiment is explained with reference to
As shown in
The operation-state recognizing unit 513 monitors the state of the Ry/By signal line for the respective banks 0 to 3, to recognize whether the operation state is in a state of “executing the multiple write command” for each bank based on a change in the Ry/By signal line according to the dummy write command and a change in the Ry/By signal line at the time of completion of write in each plane. That is, upon detection of a fall from H to L at Step S34, the operation-state recognizing unit 513 recognizes the state of the bank, in which the fall from H to L has been detected, as the state of “executing the multiple write command”. Upon detection of a rise from L to H at Step S34, the operation-state recognizing unit 513 recognizes the state of the bank, in which the rise from L to H has been detected, as a state of “having executed the multiple write command”. The state of the bank in which the multiple write command designating the memory chip itself as the transfer destination has not been received, and the multiple write command has not been executed is not in the state of “executing the multiple write command” but substantially in the same state as the state of “having executed the multiple write command”. Therefore, it is explained here that the bank is in the state of “having executed the multiple write command” for descriptive purposes.
The command processor 512 then refers to the operation-state recognizing unit 513, to search for a bank with the state being “having executed the multiple write command” (Step S43). When there is no bank with the state being “having executed the multiple write command” (NO at Step S43), the command processor 512 continues search until a bank with the state being “having executed the multiple write command” is found.
When there is a bank with the state being “having executed the multiple write command” (YES at Step S43), the command processor 512 refers to the array managed by the priority-level managing unit 211 from the top, to select a bank with the highest priority from the banks with the state being “having executed the multiple write command”. When there is only one bank with the state being “having executed the multiple write command”, the command processor 512 selects this bank. Following Step S44, the command processor 512 selects a multiple write command designating the selected bank as a write destination from the generated multiple write commands, and transmits the multiple write command to the banks 0 to 3 of the parallel operation element 2a (Step S45).
The priority-level managing unit 211 shifts the number of the bank designated as the transfer destination at Step S45 to the last of the array of priority level, so that a position of a bank number in the back of the array than the bank number before the shift is brought forward toward the top of the array one by one (Step S46).
The command processor 512 determines whether all the generated multiple write commands have been transmitted (Step S47). When there is an untransmitted write command (NO at Step S47), the command processor 512 proceeds to Step S43. When all of the generated multiple write commands have been transmitted (YES at Step S47), the command processor 512 finishes the operation.
As described above, according to the second embodiment, when the bank interleaving is performed with respect to the multiple write operation for performing write operation of a plurality of pieces of transfer data by one bank, it is recognized whether the multiple write command for performing the multiple write operation is being performed based on a change in the Ry/By signal line for each bank, and a bank with the highest selection priority is selected from the banks in which the multiple write operation is not being performed. The selected bank is changed to a target of the next multiple write command, and the level of selection priority of the selected bank at the time of next selection of the bank is shifted to the lowest level. Therefore, the bank interleaving can be performed efficiently even in the SSD capable of performing the bank interleaving with respect to the multiple write operation.
In the above explanations, while it has been assumed that one bank is divided into two planes and data is transferred to each of the planes by a multiple write command, the number of division of one bank is not limited to two. That is, it is also possible that each bank is divided into three planes and pieces of data of the same number as that of the plane dividing number are transferred by a multiple write command.
When the write request explained in the first embodiment (hereinafter, “single write request”) is received, the command processor of the second embodiment can be configured to perform the same operation as in the first embodiment. Specifically, the command processor of the second embodiment can be provided with a functional unit that determines whether a write request received from the MPU is the single write request or multiple write request, so that when the single write request is received, the operation explained in the first embodiment is performed, and when the multiple write request is received, the operation explained in the second embodiment is performed.
A case that bank interleaving is performed with respect to a data write operation has been explained in the second embodiment. However, the second embodiment can be also applied to a case that bank interleaving is performed with respect to a data read operation and a data erasure operation like in the first embodiment.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details and representative embodiments shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2009-022044 | Feb 2009 | JP | national |