This application claims the benefit of Korean Patent Application No. 10-2007-0052920, filed on May 30, 2007 in the Korean Intellectual Property Office, the disclosure of which is incorporated herein in its entirety by reference.
1. Field of the Invention
Apparatuses and methods consistent with the present invention relate to controlling commands used for a flash memory, and more particularly, to controlling commands by using a direct memory access (DMA) controller that serves to write commands onto a system memory or read commands from the system memory independently of a central processing unit (CPU).
2. Description of the Related Art
As related art multimedia techniques have developed, various multimedia files are being increasingly used, such as multimedia files for a mobile device. Since related art high definition multimedia services have started to be provided, the sizes of the multimedia files have increased. Accordingly, there is a related art need for the reading and writing speeds of portable storage devices to increase more than related art speeds.
The host interface 110 controls an input and an output of data or commands between the related art NAND flash memory control device 160 and an external host (not shown).
The bus interface 120 controls communication of data or commands between the related art NAND flash memory control device 160 and a central processing unit (CPU) (not shown) or a flash translation layer (FTL) (not shown) through a system bus. The FTL serves to transform a logical address in a file system into a physical address in a flash memory. If a file system, such as a file allocation table (FAT), for a general magnetic disk is used, it is possible to control the flash memory by using the FTL.
The control unit 130 controls the operations of components included in the related art NAND flash memory control device 160.
The register unit 140 stores commands for controlling a NAND flash memory 170, and a status (Full or Not full) representing whether there is a space for storing the commands for controlling the NAND flash memory 170. A full status represents that there is no space in the register unit 140 for storing the commands. A not full status represents that there is a space in the register unit 140 for storing the commands.
The command register 142 serves to store commands for requesting data to be recorded onto the NAND flash memory 170 or to be read from the NAND flash memory 170, and the stored commands may be stored in the command register 142 in a queue such as a first-in-first-out queue. Also, the command register 142 may be constructed with a plurality of registers.
The command register status register 144 represents a status indicating whether there is a space for storing the commands in the command register 142. When the command register 142 includes the plurality of registers, the command register status register 144 may indicate whether there is a space for storing the commands in each of the registers of the command register 142 corresponding to a channel or NAND flash memory device. Accordingly, the number of registers of the command register status register 144 may be the same as the number of NAND flash memory devices 0 to N of the NAND flash memory 170 or the number of channels of the NAND flash memory 170. The NAND flash memory devices 0 to N indicate flash memory chips that form the NAND flash memory 170. A channel indicates a group constructed with a number of NAND flash memory devices from among the NAND flash memory devices 0 to N. For example, when there are sixteen NAND flash memory devices, four NAND flash memory devices are grouped into one channel so that there are a total of four channels.
There are (N+1) R/B status registers in the R/B status register 146 in correspondence with the NAND flash memory devices 0 to N in the NAND flash memory 170, and the R/B status registers indicate a ready/busy status of the NAND flash memory devices 0 to N. When a status of one of the NAND flash memory devices 0 to N is busy, the NAND flash memory device that is busy is read or written by the related art NAND flash memory control device 160. When a status of one of the NAND flash memory devices 0 to N is ready, the NAND flash memory device that is ready is not read and not written by the related art NAND flash memory control device 160.
The NAND flash memory interface 150 controls an input and an output of data of the NAND flash memory 170.
When an external host or internal FTL requests data to be read from or written onto the channel or NAND flash memory device of the NAND flash memory 170, the related art NAND flash memory control device 160 receives a command corresponding to the request from the CPU or FTL and records the received command into the command register 142 such that the recorded command is stored in the command register 142 in the queue manner, in operation 210.
In operation 220, the related art NAND flash memory control device 160 determines the R/B status of the NAND flash memory device, in which the command is to be executed, through the R/B status register 146. When it is determined that the status of the NAND flash memory device is ready, the next command is received. When it is determined that the status of the NAND flash memory device is busy, the current operation proceeds to operation 230.
In operation 230, the related art NAND flash memory control device 160 determines if a space exists for storing commands in the command register 142 based on information stored in the command register status register 144. When there is no space for storing the commands in the command register 142, a full flag is stored in the command register status register 144. When there is a space for storing the commands in the command register 142, a not full flag is stored in the command register status register 144. In case of the not full flag, the next command is received. When it is determined that the full flag is there, the current operation proceeds to operation 240.
In operation 240, it is determined whether the related art NAND flash memory control device 160 is in an interrupt mode or polling mode. In the interrupt mode, when an event in which there is no space for storing the commands in a register of the related art NAND flash memory control device 160 occurs, an interrupt is generated and reported to the CPU. In a polling mode, when there is no space for storing commands in a register of the related art NAND memory control device 160, software directly reads the command register status register 144 and controls the related art NAND flash memory control device 160. When it is determined that the related art NAND flash memory control device 160 is not in the interrupt mode, that is, when the related art NAND flash memory control device 160 is in the polling mode, the current operation proceeds to operation 260. When the related art NAND flash memory control device 160 is in the interrupt mode, the current operation proceeds to operation 250.
In operation 250, the related art NAND flash memory control device 160 generates an interrupt CMD REG FULL so as to report to the CPU that there is no space for storing commands in the command register 142, when it is determined that the related art NAND flash memory control device 160 is in the interrupt mode in operation 240. When the interrupt CMD REG FULL occurs, the CPU processes a predetermined interrupt routine. When it is determined that the related art NAND flash memory control device 160 is in the polling mode in operation 240, since the current operation proceeds to operation 260 by skipping operation 250, it is unnecessary to generate an interrupt.
In operation 260, when it is determined that the NAND flash memory control device 160 is in the polling mode in operation 240 or when the interrupt CMD REG FULL is generated in operation 250, the R/B status of the NAND flash memory device in which the command received in operation 210 is to be executed is determined based on the information from the R/B status register 146. When it is determined that the R/B status is ready, the current operation proceeds to operation 270. When it is determined that the R/B status is busy, the current operation is put on standby until the R/B status is ready.
In operation 270, when it is determined that the R/B status of the related art NAND flash memory control device 160 is ready in operation 260, it is determined whether the related art NAND flash memory control device 160 is in the interrupt mode. When it is determined that the related art NAND flash memory control device 160 is not in the interrupt mode, that is, when the related art NAND flash memory control device 160 is in the polling mode, software directly reads the R/B status of the NAND flash memory device from the R/B status register 146. When it is determined that the related art NAND flash memory control device 160 is in the interrupt mode, the current operation proceeds to operation 280.
In operation 280, the related art NAND flash memory control device 160 generates an interrupt CMD REG NOT FULL to report the CPU that there is a space for storing commands in the command register 142. Thus, the CPU skips the predetermined interrupt routine performed in operation 250 due to the interrupt CMD REG NOT FULL.
Referring to
When the related art method of controlling the NAND flash memory 170 is defined as a task and when each received command is processed by using the method shown in
A program time indicates a time for which data is electrically charged from a data buffer (not shown) of the NAND flash memory 170 to a NAND flash memory device. The time denotes a time for which data is recorded on the NAND flash memory device. Referring to
However, when an interrupt occurs at an interval of about 15.7 μs an excessive load for processing the interrupt is generated in the entire system, and accordingly, the performance of the system is decreased. Specifically, according to the aforementioned related art technique, when processing massive data, the interrupt CMD REG FULL and the interrupt CMD REG NOT FULL are generated for each command after transmitting a predetermined amount of data. Even in the polling mode, since the CPU uses a bus through polling for the most time for which data is transmitted, deterioration in the performance of the system due to the usage of the bus and an unnecessary power loss may occur in the polling mode.
As the transmission speed of the data increases, more interrupts for communicating information on the command register 142 are generated between the CPU and the related art NAND flash memory control device 160, and accordingly, the performance of the system may further deteriorate. Although a queuing capacity of the command register 142 increases, there might be a related art problem in that costs are increased, in order to obtain a sufficient capacity for transmitting massive multimedia files and reduce occurrences of interrupts.
The present invention provides a method and device for controlling commands used for a flash memory by using a direct memory access (DMA) controller to process commands for reading and writing data from and onto the flash memory. The present invention also provides a computer-readable recording medium having embodied thereon a computer program for executing the aforementioned method.
According to an aspect of the present invention, there is provided a method of controlling commands used for a flash memory, the method comprising: receiving information on at least one command currently stored in a system memory; receiving a command represented by the received information from the system memory; and generating an interrupt representing that all the commands are received, when receiving of all the commands represented by the received information is completed.
According to another aspect of the present invention, there is provided a computer-readable recording medium having embodied thereon a computer program for executing the aforementioned method of controlling the commands used for the flash memory.
According to another aspect of the present invention, there is provided a device for controlling commands for a flash memory, the device comprising: a first register storing information on at least one command currently stored in a system memory; and a DMA controller receiving commands represented by the information stored in the first register from the system memory and generating an interrupt representing that all the commands are received when all the commands represented by the stored information are received.
The above and other aspects of the present invention will become more apparent by describing in detail exemplary embodiments thereof with reference to the attached drawings in which:
Hereinafter, exemplary embodiments will be described in detail with reference to the attached drawings.
Hereinafter, a full description on the structure of the command control device 510 shown in
Referring to
The command control device 510 receives commands stored in a system memory (not shown) through a system bus without intervening of the CPU based on command storage information stored by the CPU and outputs the received commands to a device for executing the commands. The command storage information may be the number of commands stored in the system memory or an address in the system memory in which the commands are stored. The command control device 510 is included in a flash memory control device for controlling the flash memory.
The first register 530 is a register in which the command storage information for accessing the commands stored in the system memory is stored by the CPU.
The DMA controller 520 receives the commands stored in the system memory (not shown) through the system bus based on the command storage information stored in the first register 530 without intervening of the CPU, and the received commands are stored in the second register 540 in a queue manner. When all the commands that are stored in the system memory are received in the second register 540, the DMA controller 520 reports to the CPU that the receiving of the data of the DMA controller 520 is completed by generating an interrupt.
The second register 540 indicates a register in which the commands received from the DMA controller 520 are stored, and the received commands may be stored in the queue manner, and the received commands are output to a device in order to firstly execute the firstly stored command.
Referring to
In operation 610, the command control device 510 receives the command storage information on the commands currently stored in the system memory from the CPU and stores the received command storage information in the first register 520.
In operation 620, the command control device 520 receives the commands represented by the command storage information stored in the first register 520 from the system memory.
In operation 630, the command control device 510 records the commands received in operation 620 in the second register 540.
In operation 640, the command control device 510 determines whether all the commands stored in the system memory are received. When it is determined that some commands remain in the system memory, the current operation proceeds to operation 620. When it is determined that there is not any commands that remain in the system memory, the current operation proceeds to operation 650.
In operation 650, the command control device 510 reports to the CPU that all the commands have been received by generating an interrupt. As described above, in the method of controlling commands used for the flash memory according to the present exemplary embodiment, since the interrupt is generated after all the commands stored in the system memory have been received, the interrupt occurs substantially less frequently as compared with the related art technique in which an interrupt occurs whenever a command is received, that is, when an overflow occurs.
Referring to
Hereinafter, a description on the structure of the flash memory control device 760 will be omitted since its structure is substantially the same as the structure of the devices shown in
An embedded system or memory card may include the flash memory control device 760 and the flash memory 770.
The register unit 740 further includes the command storage information register 748 in addition to the structure of the register unit 140 shown in
The command storage information register 748 indicates a register for storing the number of the commands to be read from the system memory and an address in the system memory in which the commands are stored, and the command storage information register 748 corresponds to the first register 520 of
The DMA controller 530 serves to read a plurality of commands stored in the system memory based on the command storage information stored in the command storage information register 748 without intervening of the CPU and record the read commands in the command register 142 that corresponds to the second register 540 of
When an external host (not shown) or internal FTL requests data to be read from or written onto a channel or a flash memory device 0 to N of the flash memory 770, the host or FTL generates a command corresponding to the request and stores the generated command in the system memory. The stored commands may be stored in the system memory in a queue.
In operation 810, the flash memory control device 760 receives command storage information for reading the commands stored in the system memory from the CPU or FTL and stores the received command storage information in the command storage information register 748. The command storage information includes the number of the commands stored in the system memory and the address in the system memory in which the commands are stored.
In operation 820, the flash memory control device 760 determines whether the status of the DMA controller 530 is ready. A case where the status of the DMA controller 530 is ready indicates that the DMA controller 530 does not operate. A case where the status of the DMA controller 530 is busy indicates that the DMA controller 530 performs an operation such as reading of commands from the system memory. When it is determined that the status of the DMA controller 530 is ready, the current operation proceeds to operation 830. When it is determined that the status of the DMA controller 530 is busy, the current operation is on standby until the status of the DMA controller 530 is ready.
In operation 830, when it is determined that the DMA controller 530 is ready in operation 820, the DMA controller 530 reads the commands stored in the system memory based on the command storage information stored in operation 810.
In operation 840, the flash memory control device 760 determines whether there is a space for storing a command in the command register based on information stored in the command register status register 144. When it is determined that there is no space for storing a command (full flag), the current operation is on standby. When it is determined that there is a space for storing a command (not full flag), the current operation proceeds to operation 850.
In operation 850, the DMA controller 530 records the commands, which are read in operation 830, onto the command register 142 in a queue.
In operation 860, it is determined whether the flash memory control device 760 reads commands to the extent of the number of commands represented by the command storage information received in operation 810. When it is determined that the flash memory control device 760 does not read the commands to the extent of the number of commands represented by the command storage information received in operation 810, the current operation proceeds to operation 830, and the commands remaining in the system memory are read. When it is determined that the flash memory control device 760 reads the commands to the extent of the number of commands represented by the command storage information received in operation 810, the current operation proceeds to operation 870.
In operation 870, the flash memory control device 760 generates an interrupt representing that an operation of reading a command stored in the system memory is completed, and the interrupt is generated by the DMA controller 530. The CPU receives a report on the operation of the flash memory control device 760 by receiving the generated interrupt. As described above, it is possible for the flash memory control device 760 according to an embodiment of the present invention to receive a plurality of commands for writing or reading data onto or from the flash memory 770 from the system memory through only a single interrupt. In a case where the method shown in
According to an exemplary embodiment, it is possible to reduce the number of interrupts that occur whenever commands overflow in a register and to control the interrupt interval sufficiently wide even when transmitting massive data by storing commands in a partial area of the system memory and allowing a flash memory control device to include a DMA controller that accesses the stored commands. Accordingly, it is possible to substantially minimize operations except for the operation of inputting and outputting data into and from a flash memory. That is, it is possible to minimize operations, such as an operation of generating an interrupt for exchanging status information of a register for storing a command between a CPU and the flash memory control device. Accordingly, it is possible to embody a high speed input and output storage apparatus capable of reducing an amount of usage of the CPU and a bus as compared with the related art technique, and it is also possible to minimize an interaction with hardware when embodying an FTL and reduce complexity of the exemplary embodiment.
The exemplary embodiments of the present invention can be written as computer programs and can be implemented in general-use digital computers that execute the programs using a computer readable recording medium. In addition, data structures used for the embodiments of the present invention can be recorded in the computer readable recording medium through various means. Examples of the computer readable recording medium include magnetic storage media (e.g., ROM, floppy disks, hard disks, etc.), and optical recording media (e.g., CD-ROMs, or DVDs), other storage media. However, the present invention is not limited thereto.
While the present invention has been particularly shown and described with reference to exemplary embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as defined by the appended claims. The exemplary embodiments should be considered in descriptive sense only and not for purposes of limitation. Therefore, the scope of the invention is defined not by the detailed description of the invention but by the appended claims, and all differences within the scope will be construed as being included in the present invention.
Number | Date | Country | Kind |
---|---|---|---|
10-2007-0052920 | May 2007 | KR | national |