This U.S. non-provisional patent application claims priority under 35 U.S.C. § 119 of Korean Patent Application No. 10-2016-0138578, filed on Oct. 24, 2016, the entire contents of which are hereby incorporated by reference.
The disclosure relates to semiconductor memory devices, and more particularly, to a method of operating a memory controller and a method of operating a storage device including the memory controller.
A semiconductor may be classified into a volatile memory device that loses its stored data when a power supply is interrupted, such as a static random access memory (SRAM), a dynamic random access memory (DRAM), a synchronous DRAM (SDRAM), etc., and a nonvolatile memory device that retains its stored data even when a power supply is interrupted, such as a read only memory (ROM), a programmable ROM (PROM), an electrically programmable ROM (EPROM), an electrically erasable and programmable ROM (EEPROM), a flash memory device, a phase-change RAM (PRAM), a magnetic RAM (MRAM), a ferroelectric RAM (FRAM), and resistive RAM (RRAM), etc.
A flash memory is being widely used as a high-capacity storage medium of a user device. As computing technology develops, more improved performance is required for a flash memory-based high-capacity storage medium. Various techniques or devices are being developed to improve performance of the flash memory-based high-capacity storage medium.
Example embodiments of the disclosure provide a method, executed by a memory controller, of controlling a nonvolatile memory device having first and second planes. The method may include transmitting a first command included in a command queue to the nonvolatile memory device. A block address of a second command is compared with a block address of a third command when the third command is ahead of the second command in the command queue. The second command is selectively transmitted to the nonvolatile memory device prior to the third command based on the comparison result. The first command is a command with respect to the first plane, the second command is a command with respect to the second plane, and the third command is a multi-plane command with respect to the first and second planes.
Example embodiments of the disclosure provide a method executed by a storage device having a memory controller and a nonvolatile memory device, which includes first and second planes. The method may include processing a first command included in a command queue of the memory controller. A block address of a second command is compared with a block address of a third command when the third command is ahead of the second command. The second command is processed prior to the third command according to the comparison result. The first command is a command with respect to the first plane, the second command is a command with respect to the second plane, and the third command is a command with respect to the first and second planes.
Example embodiments of the disclosure provide a method, executed by a memory controller, of controlling a nonvolatile memory device having first and second planes. The method may include transmitting a first command, addressing the first plane, to the nonvolatile memory device and transmitting a second command, addressing the second plane, to the nonvolatile memory device before receiving a response to the first command from the nonvolatile memory device.
Example embodiments of the disclosure provide a method executed by a storage device having a memory controller and a nonvolatile memory. The method includes communicating a first command from the memory controller to the nonvolatile memory, the first command having a highest execution priority within a command queue of the memory controller. When a second command having the next-highest priority, to that of the first command, within the command queue is addressed to the same plane of the nonvolatile memory as is the first command, the method includes communicating a third command, within the command queue, from the memory controller to the nonvolatile memory that is not addressed to the same plane of the nonvolatile memory as is the first command Otherwise, the second command is communicated from the memory controller to the nonvolatile memory.
Embodiments of the disclosure will be described below in more detail with reference to the accompanying drawings. The embodiments of the disclosure may, however, be embodied in different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the disclosure to those skilled in the art. Like numbers refer to like elements throughout.
Below, embodiments of the disclosure may be described in detail and clearly to such an extent that an ordinary one in the art easily implements the disclosure.
The memory controller 110 may read data stored in the nonvolatile memory device 120 or may store data in the nonvolatile memory device 120 according to a request from an external device (e.g., host, CPU, AP, etc.). For example, the memory controller 110 may provide an address ADDR, a command CMD, and a control signal CTRL to the nonvolatile memory device 120 and may exchange data, DATA, with the nonvolatile memory device 120.
The nonvolatile memory device 120 may output stored data or may store received data in response to a signal received from the memory controller 110. It is assumed that the nonvolatile memory device 120 is a NAND-type flash memory device. However, the scope of the disclosure is not limited thereto and the nonvolatile memory device 120 may include a volatile memory, such as a static random access memory (SRAM), a dynamic random access memory (DRAM), a synchronous DRAM (SDRAM), etc., and a nonvolatile memory, such as a read only memory (ROM), a programmable ROM (PROM), an electrically programmable ROM (EPROM), an electrically erasable and programmable ROM (EEPROM), a phase-change RAM (PRAM), a magnetic RAM (MRAM), a ferroelectric RAM (FRAM), a resistive RAM (RRAM), a TRAM (thyristor RAM), etc.
The nonvolatile memory device 120 may include first and second planes (PL1, PL2). Each of the first and second planes (PL1, PL2) may include a plurality of memory blocks. The plurality of memory blocks included in the first plane PL1 may share the same bit lines and the plurality of memory blocks included in the second plane PL2 may share the same bit lines.
In example embodiments, the nonvolatile memory device 120 may perform an independent operation on each of the first and second planes (PL1, PL2) under the control of the memory controller 110. For example, the nonvolatile memory device 120 may perform a first operation on at least some of the plurality of memory blocks included in the first plane PL1 under the control of the memory controller 110. While the first operation is performed, the nonvolatile memory device 120 may perform a second operation on at least some of the plurality of memory blocks included in the second plane PL2 under the control of the memory controller 110. That is, the nonvolatile memory device 120 may perform an independent operation by planes.
In example embodiments, the memory controller 110 may provide commands for an operation of the nonvolatile memory device 120. The memory controller 110 may provide a first plane command, a second plane command, or a multi plane command. The first plane command may indicate a command with respect to a memory block included in the first plane PL1, the second plane command may indicate a command with respect to a memory block included in the second plane PL2, and the multi plane command may indicate a command with respect to both a memory block included in the first plane PL1 and a memory block included in the second plane PL2.
The nonvolatile memory device 120 may perform an operation on a memory block included in the first plane PL1 in response to the first plane command, may perform an operation on a memory block included in the second plane PL2 in response to the second plane command, and may perform an operation on both a memory block included in the first plane PL1 and a memory block included in the second plane PL2 in response to the multi plane command. As described above, performance of the storage device (e.g., performance with respect to random I/O) may be improved by performing, by the nonvolatile memory device 120, an independent operation on each plane.
In example embodiments, the memory controller 110 may include a command scheduler 111. The command scheduler 111 may manage a command from an external device (e.g., host) to improve performance of the storage device 100.
The commands may be queued in a command queue (CQ). The commands may include the first plane command, the second plane command, or the multi-plane command. The command scheduler 111 may provide the first plane command, the second plane command, or the multi-plane command to the nonvolatile memory device 120 in an in-order manner or an out-of-order manner according to a scheduling method of the disclosure. According to a scheduling method of the command scheduler 111, the first plane command and the second plane command may be provided to the nonvolatile memory device 120 differently from the order queued in the command queue (CQ). In this case, since the nonvolatile memory device 120 can perform operations on the first and second planes (PL1, PL2) at the same time or to be overlapped with each other, performance of the storage device 100 may be improved. The scheduling method according to the disclosure will be described in further detail with reference to
The command scheduler 111 may be configured to schedule commands queued in the command queue (CQ). The processor 112 may control an overall operation of the memory controller 110. The SRAM 113 may be used as a buffer memory, a cache memory, or a main memory of the memory controller 110. The RAM 114 may store various information required when the memory controller 110 operates in the form of firmware. In example embodiments, information about commands included in the command queue (CQ) may be stored in the SRAM 113.
In example embodiments, the command scheduler 111 may be provided in the form of software or hardware. The command scheduler 111 provided in the form of software may be stored in the SRAM 113 and may be driven by the processor 112.
The memory controller 110 may communicate with an external device (e.g., host) through the host interface 115. As an example, the host interface 115 may include at least one of a DDR (double data rate) interface, a USB (universal serial bus) interface, an MMC (multimedia card) interface, an eMMC (embedded MMC) interface, a PCI (peripheral component interconnection) interface, a PCI-E (PCI-express) interface, an ATA (advanced technology attachment) interface, a serial-ATA interface, a parallel-ATA interface, an SCSI (small computer small interface) interface, an ESDI (enhanced small disk interface) interface, an IDE (integrated drive electronics) interface, a Firewire interface, a UFS (universal flash storage) interface, an NVMe (nonvolatile memory-express) interface, etc. The memory controller 110 may communicate with the nonvolatile memory device 120 through the flash interface 116.
The memory cell array 121 may include the first and second planes (PL1, PL2). Each of the first and second planes (PL1, PL2) may include a plurality of memory blocks BLK. Each of the memory blocks BLK included in each of the first and second planes (PL1, PL2) may be connected to the peripheral circuit PERI through string selection lines SSL, word lines WL, and ground selection lines GSL.
The memory blocks BLK included in the first plane PL1 may be connected to the peripheral circuit PERI through first bit lines BL1. That is, the memory blocks BLK included in the first plane PL1 may share the first bit lines BL1. The memory blocks BLK included in the second plane PL2 may be connected to the peripheral circuit PERI through second bit lines BL2. That is, the memory blocks BLK included in the second plane PL2 may share the second bit lines BL2.
The peripheral circuit PERI may receive an address ADDR, a command CMD, and a control signal CTRL from the memory controller 110 and may exchange data with the memory controller 110 in response to the received signal. For example, the peripheral circuit PERI may include an address decoder 122, a control logic & voltage generation circuit 123, a page buffer 124, and an input/output circuit 125.
The address decoder 122 is connected to the memory cell array 121 through string selection lines SSL, word lines WL, and ground selection lines GSL. The address decoder 122 may receive the address ADDR from the memory controller 110 and may decode the received address ADDR. The address decoder 122 can control at least one word-line voltage based on the decoded address.
The control logic & voltage generation circuit 123 may receive the command CMD and the control signal CTRL from the memory controller 110 and may control the address decoder 122, the page buffer 124, and the input/output circuit 125 in response to the received signals. The control logic & voltage generation circuit 123 may generate various voltages required when the nonvolatile memory device 120 operates.
The page buffer 124 is connected to the memory blocks BLK included in the first plane PL1 through the first bit lines BL1 and is connected to the memory blocks BLK included in the second plane PL2 through the second bit lines BL2. The page buffer 124 may temporarily store data to be stored in the memory cell array 121 or data read from the memory cell array 121.
The input/output circuit 125 may be connected to the page buffer 124 through data lines DL and may exchange data with the page buffer 124 through the data lines DL. The input/output circuit 125 may transmit data to the memory controller 110 or may receive data from the memory controller 110 under the control of the control logic & voltage generation circuit 123.
The configuration elements included in the peripheral circuit PERI may be configured to independently perform an operation on the first plane PL1, an operation on the second plane PL2, or an operation on the first and second planes (PL1, PL2) (i.e., a multi-plane operation) in response to signals received from the memory controller 110.
Referring to
Each of the cell strings (CS11, CS12, CS21, CS22) includes a plurality of cell transistors. For example, each of the cell strings (CS11, CS12, CS21, CS22) may include string selection transistors (SSTa, SSTb), a plurality of memory cells (MC1 to MC8), ground selection transistors (GSTa, GSTb), and dummy memory cells (DMC1, DMC2). Each of the plurality of cell transistors included in the cell strings (CS11, CS12, CS21, CS22) may be a charge trap flash (CTF) memory cell.
The plurality of memory cells (MC1 to MC8) are serially connected to one other and are laminated in a height direction perpendicular to a plane formed by a row direction and a column direction. The string selection transistors (SSTa, SSTb) are serially connected to each other and are provided between the memory cells (MC1 to MC8) and the bit lines BL1 and BL2. The ground selection transistors (GSTa, GSTb) are serially connected to each other and are provided between the memory cells (MC1 to MC8) and a common source line CLS.
In example embodiments, the first dummy memory cell DMC1 may be provided between the memory cells (MC1 to MC8) and the ground selection transistors (GSTa, GSTb) and the second dummy memory cell DMC2 may be provided between the memory cells (MC1 to MC8) and the string selection transistors (SSTa, SSTb).
In example embodiments, the ground selection transistors (GSTa, GSTb) of the cell strings (CS11, CS12, CS21, CS22) may be connected to the ground select line GSL in common. In example embodiments, although not illustrated in the drawing, ground selection transistors of the same row may be connected to the same ground selection line and ground selection transistors of different rows may be connected to different ground selection lines respectively. For example, the first ground selection transistors GSTa of the cell strings (CS11, CS12) of a first row may be connected to a first ground selection line and the first ground selection transistors GSTa of the cell strings (CS21, CS22) of a second row may be connected to a second ground selection line.
In example embodiments, although not illustrated in the drawing, ground selection transistors provided at the same height from a substrate (not shown) may be connected to the same ground selection line and ground select transistors provided at different heights from the substrate may be connected to different ground select lines respectively.
Memory cells positioned at the same height from the substrate or the ground selection transistors (GSTa, GSTb) may be connected to the same word line in common and memory cells positioned at different heights from the substrate or the ground selection transistors (GSTa, GSTb) may be connected to different word lines respectively. For example, the first through eighths memory cells (MC1 to MC8) of the cell strings (CS11, CS12, CS21, CS22) are connected to the first through eighth word lines (WL1 to WL8) respectively in common.
String selection transistors of the same row among the first string transistors SSTa of the same height are connected to the same string selection line and string selection transistors of different rows among the first string transistors SSTa of the same height are connected to different string selection lines respectively. For example, the first string selection transistors SSTa of the cell strings (CS11, CS12) of the first row are connected to a string selection line SSL1a in common and the first string selection transistors SSTa of the cell strings (CS21, CS22) of the second row are connected to a string select line SSL2a in common.
Similarly, string selection transistors of the same row among the second string selection transistors SSTb of the same height are connected to the same string selection line and string selection transistors of different rows among the second string selection transistors SSTb of the same height are connected to different string selection lines respectively. For example, the second string selection transistors SSTb of the cell strings (CS11, CS12) of the first row are connected to a string selection line SSL1b in common and the second string selection transistors SSTb of the cell strings (CS21, CS22) of the second row are connected to a string selection line SSL2b in common.
Dummy memory cells of the same height are connected to the same dummy word line and dummy memory cells of different heights are connected to different dummy word lines respectively. For example, the first dummy memory cells DMC1 are connected to a first dummy word line DWL1 and the second dummy memory cells DMC2 are connected to a second dummy word line DWL2.
The memory block BLK illustrated in
That is, the nonvolatile memory device 120 may perform an operation (e.g., a read operation, a write operation, or an erase operation) with respect to memory blocks included in the first plane PL1 in response to the P1 command. The nonvolatile memory device 120 may perform an operation on memory blocks included in the second plane PL2 in response to the P2 command. The nonvolatile memory device 120 may perform an operation on memory blocks included in the first and second planes (PL1, PL2) at the same time in response to the MP command.
For convenience of description, in the embodiments of the disclosure, a read, program, or erase operation on a specific memory block is performed in response to a specific command. However, this is only for convenience of description and this may mean that a program operation, a read operation or an erase operation on at least one memory block, at least one page of the at least one memory block, or at least one word-line connected to the at least one memory block is performed in response to the specific command.
It is assumed that the commands mentioned in the specification or the commands illustrated in the drawing are queued in the command queue (CQ) of
Referring to
The nonvolatile memory device 120 may perform an operation on a memory block included in the first plane PL1 in response to the received P1 command. The memory block described above may be a memory block corresponding to a physical address of the P1 command.
In an operation S120, the command scheduler 111 may determine whether there exists the P2 command in the command queue (CQ). For example, the command queue (CQ) may include various commands such as the P1 command, the P2 command, or the MP command. The command scheduler 111 may determine whether there exists the P2 command in commands included in the command queue (CQ).
In the case where there exists the P2 command in the command queue (CQ), in an operation S130, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120. For example, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120 while the nonvolatile memory device 120 performs an operation on the P1 command (i.e., before an operation corresponding to the P1 command is completed). The nonvolatile memory device 120 may perform an operation on a memory block included in the second plane PL2 in response to the received P2 command In this case, the operation on a memory block included in the first plane PL1 and an operation and the operation on a memory block included in the second plane PL2 may be performed at the same time or to be overlapped with each other.
In the case where there does not exist the P2 command in the command queue (CQ), the command scheduler 111 may not perform a separate operation.
In example embodiments, although not illustrated in the drawing, after the nonvolatile memory device 120 completes an operation on the P1 command, the command scheduler 111 may transmit other P1 commands included in the command queue (CQ) to the nonvolatile memory device 120.
As described above, in the case where commands (e.g., the P1 command and the P2 command) with respect to different planes exist in the command queue (CQ), the command scheduler 111 may transmit the P1 command and the P2 command to the nonvolatile memory device 120 regardless of the queueing order. Performance of the storage device 100 is improved by performing operations with respect to the P1 command and the P2 command at the same time or to be overlapped with each other.
A read command with respect to the first memory block BLK1 of the first plane PL1 is called “P1B1[RD] command” In response to the P1B1[RD] command, the nonvolatile memory device 120 may perform a read operation on at least one page of a plurality of pages included in the first memory block BLK1 of the first plane PL1. At least one page may be a page corresponding to an address of the P1B1 [RD] command.
A program command with respect to the second memory block BLK2 of the first plane PL1 is called “P1B2[PG] command” An erase command with respect to the third memory block BLK3 of the first plane PL1 is called “P1B3[ER] command” Similarly, commands with respect to fourth through sixth memory blocks (BLK4, BLK5, BLK6) are called “P2B4[XX]” command”, “P2B5[XX] command”, and “P2B6[XX] command” respectively. The “XX” symbol indicates “RD”, “PG”, or “ER” and may be variously replaced according to the type of command.
The commands described above are exemplary, so as to clearly describe the embodiments of the disclosure. However, the commands are not a command set that is in common use and, the scope of the disclosure is not limited thereto. Reference symbols of the commands may be variously changed depending on a target memory block, the type of command, etc. For example, an erase command with respect to the fifth memory block BLK5 of the second plane PL2 may be referred to as “P2B5[ER] command”.
Although not illustrated in the specification or drawings, the aforementioned commands may be generated by a flash translation layer (FTL) of the memory controller 110 based on a request of an external device or an internal management operation.
To briefly and clearly describe embodiments of the disclosure, the embodiments of the disclosure are described based on the reference symbols of the command described with reference to
Referring to
The queueing order described above takes into account only the lapse of time (e.g., time taken for a command to be queued). However, the scope of the disclosure is not limited thereto and the queueing order of commands may be queued in various ways (e.g., priority way, quality of service, etc.). As an example, after the P2B4[PG] command is queued in the command queue (CQ) first, the P1B1[RD] command and the P1B2[PG] command that have higher priority than the P2B4[PG] command may be issued. In this case, since the P1B1[RD] command and the P1B2[PG] command have high priority, the command queue (CQ) may be arranged such that the P1B1[RD] command and the P1B2[PG] command are performed first. The priority queueing way is merely an example and the scope of the disclosure is not limited thereto. It will be well understood by one of ordinary skill in the art that the queueing order in the command queue (CQ) may be arranged in various ways. For convenience of description and clarity of embodiments, it is assumed that commands in the command queue (CQ) are arranged based on the time when they are queued.
A command arrangement illustrated in
It is also assumed that a queueing order of commands has an order of a dotted line direction illustrated in the drawing. That is, the dotted line illustrated in the drawing means that after the P1B1[RD] command is queued in the command queue (CQ), the P1B2[PG] command is queued, and the dotted line indicating a queueing order may have a similar meaning in similar drawings below.
A conventional command scheduler may sequentially transmit commands in the command queue (CQ) to the nonvolatile memory device 120 in the order of being queued. However, the command scheduler 111 according to the disclosure may provide commands to the nonvolatile memory device 120 according to the operation method described with reference to
For example, the command scheduler 111 may provide the P1B1[RD] command first queued to the nonvolatile memory device 120 through a command I/O. The nonvolatile memory device 120 may perform a corresponding operation (i.e., a read operation corresponding to a time tRD) on the first plane PL1 in response to the P1B1 [RD] command.
A conventional memory controller may provide the P1B2[RD] command to the nonvolatile memory device 120 after an operation on the P1B1[RD] command is completed and may provide the P2B4[PG] command to the nonvolatile memory device 120 after an operation on the P1B2[RD] command is completed according to a queueing order.
However, the command scheduler 111 may transmit the P2B4[PG] command which is a command with respect to the second plane PL2 to the nonvolatile memory device 120 after transmitting the P1B1[RD] command to the nonvolatile memory device 120. That is, while the nonvolatile memory device 120 performs an operation (i.e., corresponding to time tRD) on the P1B1[RD] command, the command scheduler 111 may provide the P2B4[PG] command to the nonvolatile memory device 120. The command scheduler 111 may provide the P2B4[PG] command to the nonvolatile memory device 120 before receiving a response or read data to the P1B1[RD] command from the nonvolatile memory device 120. The nonvolatile memory device 120 may perform a program operation (i.e., corresponding to a time tPROG) on the fourth memory block BLK4 of the second plane PL2 in response to the P2B4[PG] command.
After the nonvolatile memory device 120 completes an operation on the P1B1[RD] command, the command scheduler 111 may provide the P1B2[PG] command to the nonvolatile memory device 120. The nonvolatile memory device 120 may perform a program operation (i.e., corresponding to a time tPROG) on the second memory block BLK2 of the first plane PL1 in response to the P1B2[PG] command.
As described above, the command scheduler 111 may provide commands in the command queue (CQ) to the nonvolatile memory device 120 differently from the order of being queued (i.e., an out-of-order manner) and thereby the nonvolatile memory device 120 may perform an operation on each of the first and second planes (PL1, PL2) at the same time or to be overlapped with each other. Thus, overall operation performance of the storage device 100 may be improved.
Referring to
In the case where there does not exist the P2 command in the command queue (CQ), the command scheduler 111 can sequentially schedule commands according to a queueing order in the command queue (CQ).
In the case where there exists the P2 command in the command queue (CQ), in an operation S230, the command scheduler 111 may determine whether there is an MP command ahead of the P2 command in the command queue (CQ). For example, various commands such as the P1 command, the P2 command, and the MP command may be sequentially queued in the command queue (CQ).
In a specific embodiment, referring to
In the case where there is not the MP command ahead of the P2 command, the command scheduler 111 may perform an operation S250. Since the operation of S250 is similar to the operation of S130 of
In the case where there is the MP command ahead of the P2 command, in an operation S240, the command scheduler 111 may compare a block address of the P2 command with a block address of the MP command. For example, the P2 command may include a block address of at least one of the fourth through sixth memory blocks (BLK4 to BLK6) of the second plane PL2. The MP command may include a block address of at least one of the first through third memory blocks (BLK1 to BLK3) of the first plane PL1 and a block address of at least one of the fourth through sixth memory blocks (BLK4 to BLK6) of the second plane PL2. The command scheduler 111 may compare a block address included in the P2 command with a block address of at least one of the fourth through sixth memory blocks (BLK4 to BLK6) of the second plane PL2 included in the MP command.
In the case where the block addresses described above are not identical to one another (or in the case where a block address of the MP command does not include a block address of the P2 command), in the operation S250, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120.
In the case where the block addresses described above are identical to one another (or in the case where a block address of the MP command includes a block address of the P2 command), the P2 command and the MP command may be commands corresponding to an operation on the same memory block. In this case, the command scheduler 111 may not transmit the P2 command to the nonvolatile memory device 120 and sequentially schedule commands according to a queueing order in the command queue (CQ).
For example, it is assumed that the P2 command indicates a read operation on the fourth memory block BLK4 and the MP command indicates a program operation on the first memory block BLK1 and the fourth memory block BLK4. In this case, when each command is executed according to a queueing order, a program operation on the fourth memory block BLK4 may be performed by the MP command and then data programmed in the fourth memory block BLK4 may be read by the P2 command. However, in the case where the command scheduler 111 transmits the P2 command to the nonvolatile memory device 120 prior to the MP command, after unintended data is read in the fourth memory block BLK4 by the P2 command, the fourth memory block BLK4 may be programmed by the MP command.
More specifically, as illustrated in
The command scheduler 111 compares the block address of the P2 command with the block address of the MP command queued prior to the P2 command In the case where the block address of the P2 command is different from the block address of the MP command, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120 prior to the MP command In the case where the block address of the P2 command is the same as the block address of the MP command, the command scheduler 111 may transmit commands to the nonvolatile memory device 120 according to the queueing order (i.e., transmit the P2 command after transmitting the MP command) Accordingly, command processing time of the storage device 100 may be improved and an unintended operation (e.g., an operation of reading data different from the intended data) may be prevented.
In the embodiments described above, even though a configuration that compares the block address of the P2 command with the block address of the MP command was described, the scope of the disclosure is not limited thereto. For example, the command scheduler 111 may compare other physical addresses such as a row address, a page address, etc. instead of the block address and may perform the scheduling operation described above according to a comparison result.
Referring to
In the case where a determination result of the operation S340 indicates that the block address of the P2 command is the same as the block address of the MP command, in an operation S350, the command scheduler 111 may determine whether the MP command and the P2 command are a read command.
In the case where the MP command and the P2 command are a read command, in an operation S360, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120 prior to the MP command. In the case where at least one of the MP command and the P2 command is not a read command (i.e., at least one of the MP command and the P2 command is a program command or an erase command), the command scheduler 111 may not transmit the P2 command to the nonvolatile memory device 120 prior to the MP command.
For example, as illustrated in
However, if the P2 command is transmitted to the nonvolatile memory device 120 prior to the MP command under the situation that at least one of the MP command and the P2 command is not a read command, operations of the P2 command and the MP command may not be normally performed. In this case, the command scheduler 111 may transmit the MP command and the P2 command to the nonvolatile memory device 120 according to the queueing order.
As described above, in the case where the block address of the P2 command and the block address of the MP command that are included in the command queue (CQ) are different from each other, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120 prior to the MP command In the case where the block address of the P2 command is the same as the block address of the MP command, the command scheduler 111 may determine whether both of the P2 command and the MP command are a read command In the case where both of the P2 command and the MP command are a read command, the command scheduler 111 may transmit the P2 command to the nonvolatile memory device 120 prior to the MP command.
Although not illustrated in the drawings, each operation of
Accordingly, as described above, the command scheduler 111 may not only reduce command processing time but also guarantee a normal operation of each command by reordering a queueing order of the P1 command, the P2 command, and the MP command.
As illustrated in
As described above, the nonvolatile memory device 120 may support an independent operation by planes. Accordingly, the command scheduler 111 may process each of the P1B1[RD] command, the P1B2[PG] command, the P2B4[PG] command, the P2B4[RD] command, and the P2B5[RD] command based on the operation method described with reference to
More specifically, the command scheduler 111 may transmit the P1B1[RD] to the nonvolatile memory device 120 according to the queueing order. After that, according to the operation method described with reference to
A conventional memory controller may process each of the commands of the command queue (CQ) illustrated in
In the case where a determination result of the operation S430 indicates that there is a MP command prior to the P2 command, in an operation S440, the command scheduler 111 may determine whether a postponement count of the MP command is smaller than a reference value. For example, in the case where commands in the command queue (CQ) are processed according to the operation methods of the command scheduler 111 described above, under specific conditions, the P2 command or the P1 command having a later queueing order than the MP command may be processed prior to the MP command. In this case, the postponement count of the MP command may increase. In example embodiments, the postponement count may be managed by the command scheduler 111 or specific components.
In the case where the postponement count of the MP command is smaller than the reference value, the command scheduler 111 may perform operations of S450 and S460. In the case where the postponement count of the MP command is not smaller than the reference value, the command scheduler 111 may not transmit the P2 command to the nonvolatile memory device 120. In this case, the command scheduler 111 may process commands in the command queue (CQ) according to the queueing order.
The postponement count indicates the number of times a command later than the MP command is processed prior to the MP command or is transmitted to the nonvolatile memory device 120. For example, commands may be queued in the command queue (CQ) in the order of a first P1 command, a first MP command, a first P2 command, a second P1 command, and a second P2 command. The command scheduler 111 may transmit the first P1 command to the nonvolatile memory device 120 and may transmit the first P2 command to the nonvolatile memory device 120 prior to the first MP command. After an operation on the first P1 command is completed, the command scheduler 111 may transmit the second P1 command to the nonvolatile memory device 120 prior to the first MP command. In the case where commands are processed according to a general queueing order, the commands have to be processed in the order of the first P1 command, the first MP command, the first P2 command, the second P1 command, and the second P2 command. However, according to the scheduling method of the disclosure, the first MP command may be processed later than the second P1 command and the second P2 command In this case, the postponement count of the first MP command may be 2.
As described above, as the postponement count of the MP command increases, a process for the MP command may be delayed and thereby an error (e.g., an error caused by a command time out) may occur in an operation on the storage device 100. Thus, in the case where the postponement count of the MP command is greater than the reference value, the command scheduler 111 can prevent an incorrect operation caused by a postponement or delay of the MP command by not transmitting the P2 command to the nonvolatile memory device 120 and processing commands in the command queue (CQ) according to the queueing order.
The memory cell array 221 may include a plurality of planes (PL1 to PLn). Each of the planes (PL1 to PLn) may include a plurality of memory blocks. Each of the planes (PL1 to PLn) may be connected to the peripheral circuit PERI through string select line SSL, word lines WL, and ground select lines GSL.
The first plane PL1 may be connected to the peripheral circuit PERI through first bit lines BL1. Similarly, the second through nth planes (PL2 to PLn) may be connected to the peripheral circuit PERI through second through nth bit lines (BL2 to BLn) respectively. A plurality of memory blocks of the first plane PL1 may share the first bit lines BL1. Similarly, a plurality of memory blocks of the second through nth planes (PL2 to PLn) may share the respective second through nth bit lines (BL2 to BLn).
As described above, the nonvolatile memory device 220 may independently perform an operation on each of the planes (PL1 to PLn) under the control of the memory controller 110 (refer to
The memory controller 110 described with reference to
For brevity of drawing and convenience of description, it may be understood that reference numerals of commands illustrated in
Referring to
The command scheduler 111 may transmit the P1B1[PG] command to the nonvolatile memory device 120 similar to those described above. The nonvolatile memory device 120 may perform a program operation on the first plane PL1 (a first memory block of the first plane PL1) in response to the P1B1[PG] command A conventional memory controller may transmit the P1B2/P2B4[RD] command to the nonvolatile memory device 120 after the nonvolatile memory device 120 completes an operation on the P1B1[PG] command.
However, since the nonvolatile memory device 120 may independently operate on each plane, the command scheduler 111 of the memory controller 110 may transmit the P3B7 [RD] command to the nonvolatile memory device 120 prior to the P1B2/P2B4[RD] command before an operation on the P1B1[PG] command is completed. As described with reference to
As described above, unlike the conventional memory controller, the command scheduler 111 may process commands in an out-of-order manner. The command scheduler 111 may compare block addresses of commands included in the command queue (CQ) and may transmit the commands to the nonvolatile memory device 120 according to the aforementioned method based on a comparison result. Thus, since time taken to process commands is reduced, a storage device having improved performance is provided.
The plurality of nonvolatile memory devices (320a to 320m) may be connected to the memory controller 310 through a plurality of channels (CHa to CHm) respectively. For example, the nonvolatile memory device 320a may be connected to the memory controller 310 through the first channel CHa. Similarly, the nonvolatile memory devices (320b to 320m) may be connected to the memory controller 310 through the respective second through mth channels (CHb to CHm).
The memory controller 310 can independently control nonvolatile memory devices by channels. Although not illustrated in the drawing, the command queue (CQ) and the command scheduler 311 with respect to each of the channels (CHa to CHm) may independently exist.
The memory controller 310 can independently control nonvolatile memory devices connected through one channel. For example, the memory controller 310 may transmit a command to or exchange data with a first nonvolatile memory device 321a through the first channel CHa and may transmit a command to or exchange data with a second nonvolatile memory device 322a through the first channel CHa.
The memory controller 310 may process commands included in the command queue (CQ) with respect to one nonvolatile memory device based on the scheduling method described with reference to
For brevity of drawing and convenience of description, commands illustrated in
The assumptions described above do not limit the scope of the disclosure and each of the first and second nonvolatile memory devices (321a, 322a) may include a plurality of planes. A command scheduling method that will be described below may be changed or extended with respect to a plurality of nonvolatile memory devices,
Referring to
As illustrated in
The command scheduler 311 may transmit the P3 [RD] command to the second nonvolatile memory device 322a. As before described, since the first and second nonvolatile memory devices (321a, 322a) operate independently of each other, the command scheduler 311 may transmit the P3[RD] command to the second nonvolatile memory device 322a while the first nonvolatile memory device 321a performs a read operation (i.e., a read operation according to the P1[RD] command) The second nonvolatile memory device 322a may perform a read operation on the third plane PL3 in response to the P3 [RD] command.
The command scheduler 311 may transmit the P2[RD] command to the first nonvolatile memory device 321a. As before described, the first and second planes (PL1, PL2) of the first nonvolatile memory device 321a may operate independently of each other. The command scheduler 311 may transmit the P2[RD] command to the first nonvolatile memory device 321a while the first nonvolatile memory device 321a performs a read operation on the first plane PL1. The first nonvolatile memory device 321a may perform a read operation on the second plane PL2 in response to the P2[RD] command. As before described, the P1/P2[RD] command may not include a block address of the P2[RD] command.
The command scheduler 311 may transmit the P4[RD] command to the second nonvolatile memory device 322a and the second nonvolatile memory device 322a may perform a read operation on the fourth plane PL4 in response to the P4[RD] command.
After read operations on the first and second planes (PL1, PL2) of the first nonvolatile memory device 321a are all completed, the command scheduler 311 may transmit the P1/P2[RD] command to the first nonvolatile memory device 321a. The first nonvolatile memory device 321a may perform a read operation on the first and second planes (PL1, PL2) in response to the P1/P2[RD] command.
A conventional memory controller, with respect to the command queue (CQ) illustrated in
The embodiment illustrated in
The SSD 1200 may exchange a signal SIG with the host 1100 through a signal connector 1201 and receive power PWR through a power connector 1202. The SSD 1200 may include an SSD controller 1210, a plurality of flash memories 1221-122n, an auxiliary power supply 1230, and a buffer memory 1240.
The SSD controller 1210 may control the flash memories 1221-122n in response to the signal SIG received from the host 1100. The flash memories 1221-122n may operate under the control of the SSD controller 1210. The SSD controller 1210 may include the command queue (CQ) and the command scheduler (111, 311) described with reference to
The auxiliary power supply 1230 is connected to the host 1100 through the power connector 1202. The auxiliary power supply 1230 may receive power PWR from the host 1100 to charge the auxiliary power supply 1230. The auxiliary power supply 1230 may provide power of the SSD 1200 when a power supply from the host 1100 is not smooth.
The buffer memory 1240 operates as a buffer memory of the SSD 1200. The buffer memory 1240 may temporarily store data received from the host 1100, data received from the flash memories 1221-122n, or meta data (e.g., mapping table) of the flash memories 1221-122n. The buffer memory 1240 may temporarily store various information required when the SSD controller 1210 operates.
According to the embodiments of the disclosure, by comparing block addresses of a single plane command and a multi plane command to reorder an order of the commands, a method of operating a memory controller having improved performance and a method of operating a storage device including the memory controller are provided.
As is traditional in the field, embodiments may be described and illustrated in terms of blocks which carry out a described function or functions. These blocks, which may be referred to herein as units or modules or the like, are physically implemented by analog and/or digital circuits such as logic gates, integrated circuits, microprocessors, microcontrollers, memory circuits, passive electronic components, active electronic components, optical components, hardwired circuits and the like, and may optionally be driven by firmware and/or software. The circuits may, for example, be embodied in one or more semiconductor chips, or on substrate supports such as printed circuit boards and the like. The circuits constituting a block may be implemented by dedicated hardware, or by a processor (e.g., one or more programmed microprocessors and associated circuitry), or by a combination of dedicated hardware to perform some functions of the block and a processor to perform other functions of the block. Each block of the embodiments may be physically separated into two or more interacting and discrete blocks without departing from the scope of the disclosure. Likewise, the blocks of the embodiments may be physically combined into more complex blocks without departing from the scope of the disclosure.
The contents described above are specific embodiments for implementing the disclosure. The disclosure may include not only the embodiments described above but also embodiments in which a design is simply or easily capable of being changed. The disclosure may also include technologies easily changed to be implemented using embodiments. Thus, the scope of the disclosure is to be determined by the following claims and their equivalents, and shall not be restricted or limited by the foregoing embodiments.
Number | Date | Country | Kind |
---|---|---|---|
10-2016-0138578 | Oct 2016 | KR | national |