WO2011070526A1 - Contrôleur de mémoire flash - Google Patents

Contrôleur de mémoire flash Download PDF

Info

Publication number
WO2011070526A1
WO2011070526A1 PCT/IB2010/055684 IB2010055684W WO2011070526A1 WO 2011070526 A1 WO2011070526 A1 WO 2011070526A1 IB 2010055684 W IB2010055684 W IB 2010055684W WO 2011070526 A1 WO2011070526 A1 WO 2011070526A1
Authority
WO
WIPO (PCT)
Prior art keywords
flash memory
memory controller
sub
instruction
steps
Prior art date
Application number
PCT/IB2010/055684
Other languages
English (en)
Inventor
Evangelos S. Eleftheriou
Robert Haas
Xiao-yu HU
Original Assignee
International Business Machines Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corporation filed Critical International Business Machines Corporation
Priority to GB1207123.9A priority Critical patent/GB2488259A/en
Priority to US13/515,118 priority patent/US8996794B2/en
Priority to DE112010003762T priority patent/DE112010003762B4/de
Priority to CN201080056012.6A priority patent/CN102652313B/zh
Publication of WO2011070526A1 publication Critical patent/WO2011070526A1/fr

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C7/00Arrangements for writing information into, or reading information out from, a digital store
    • G11C7/10Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
    • G11C7/1015Read-write modes for single port memories, i.e. having either a random port or a serial port
    • G11C7/1042Read-write modes for single port memories, i.e. having either a random port or a serial port using interleaving techniques, i.e. read-write of one part of the memory while preparing another part
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/3004Arrangements for executing specific machine instructions to perform operations on memory

Definitions

  • the present invention relates to a Flash memory controller and to a method for operating a Flash memory controller.
  • Solid-state based storage devices are becoming increasingly popular due to their low power consumption, ruggedness and high input-output (10) performance compared to conventional hard disc drives. Most current solid-state storage devices are based on NAND-flash memory chips.
  • a typical configuration of a Flash-based storage system comprises at least one Flash memory controller and one or more Flash memory packages connected to the Flash memory controller through a serial, multiplexed Flash memory interface.
  • Each Flash memory pack- age is typically composed of one or more dies, each of which typically offers a capacity of 2 GB or more. Flash memory packages are accessed by sending multi-step commands over the multiplexed Flash memory interface.
  • the Flash memory interface is commonly also referred to as a channel.
  • each die within a package contains 8192 blocks. Each block in turn consists of 64 pages of 4 KB each.
  • each page includes a 128 Byte region to store metadata or error detection and correction information.
  • Data reads and writes are typically done at page granularity.
  • a typical read operation takes 25 to read a page from the cells into a 4 KB data buffer attached to each die.
  • the data is transmitted from the data buffer to the Flash memory controller through the Flash memory interface.
  • the Flash memory interface transfers data at typically 25 ns per Byte (according to ONFI-1 standard), or roughly 100 per page.
  • the Flash memory interface is occupied and not available for competing data transfers.
  • a write operation takes the same time to transfer data from the Flash memory controller through the Flash memory interface to the data buffer inside the die. Afterwards it takes an additional 200 for the data to be written out to the individual memory cells of the die.
  • a Flash memory controller may be coupled to a first Flash memory package through a first Flash memory interface.
  • a second Flash memory package may also be coupled to the Flash memory controller through the first Flash memory interface.
  • the Flash memory controller is designed to receive a first instruction relating to the first Flash memory package and to perform a first process depending on the first instruction.
  • the Flash memory controller is further designed to receive a second instruction relating to the second Flash memory package and to perform a second process depending on a second instruction.
  • the Flash memory controller is further designed for splitting the first process into at least two first sub-steps and for splitting the second process into at least two second sub-steps.
  • the Flash memory controller is further designed for executing the first and second sub-steps and for interleaving execution of first and second sub-steps. This Flash memory controller may improve IO throughput on the Flash memory interface and may eliminates a skew between the times required for executing read and write instruction.
  • the Flash memory controller may comprise a process list and be adapted for storing an unfinished process and a current sub-step of the unfinished process in the process list.
  • the Flash memory controller may further maintain a timer for an unfinished process, wherein the timer is adapted for triggering an event upon completion of a sub-step of the unfinished process. This may allow to efficiently pipeline sub-steps of multiple processes.
  • the Flash memory controller may further comprise an instruction queue and be adapted for pushing the first and/or the second instruction onto the instruction queue. This may allow for postponing instructions until processes relating to previous instructions have completed.
  • the first instruction may be a read instruction.
  • the first process may then be a read process and be split into three sub-steps.
  • the first instruction may also be a write instruction.
  • the first process then is a write process and is split into three sub-steps.
  • the first instruction may also be an erase instruction.
  • the first process then is an erase process and is split into three sub-steps.
  • the first Flash memory package may comprise a first chip die.
  • the first instruction may then relate to the first chip die of the first Flash memory package.
  • the Flash memory controller may then be designed to receive a third instruction relating to the first chip die of the first Flash memory package and to perform a third process depending on the third instruction.
  • the Flash memory controller is then designed for splitting the third process into at least two third sub-steps and for finishing execution of all first sub-steps before starting execution of a third sub-step. This may assure that two processes involving the same die are not executed in parallel. This may avoid an eventual corruption of data.
  • the Flash memory controller may be coupled to a third Flash memory package through a second Flash memory interface.
  • the Flash memory controller can then simultaneously exchange data with a Flash memory package coupled to the first Flash memory interface and with a Flash memory package coupled to the second Flash memory interface.
  • the Flash memory controller may comprise a host interface and be adapted for receiving the first instruction and the second instruction through the host interface. This may allow for coupling the Flash memory controller to an external system, for example a personal computer.
  • the Flash memory controller may comprise a flag that marks the first Flash memory interface as busy or as free. This may allow for keeping track whether the first Flash memory interface is currently available or occupied.
  • the Flash memory controller is connected to multiple Flash memory interfaces, each of which is connected to multiple Flash memory packages or chip dies.
  • the Flash memory controller retrieves and stores data from the Flash memory packages or chip dies by issuing a stream of processes consisting of read, write and erase processes. Every read, write or erase process is split into multiple sub-steps.
  • the Flash memory controller is designed such that sub-steps in a later process can proceed before sub-steps of an earlier process have completed. Furthermore, multiple processes can proceed in parallel inside multiple Flash memory packages or chip dies connected to the same Flash memory interface.
  • a method for operating a Flash memory controller comprises steps in which the Flash memory controller receives a first instruction relating to a first Flash memory package coupled to the Flash memory controller through a first Flash memory interface, in which the Flash memory controller receives a second instruction relating to a second Flash memory package coupled to the Flash memory controller through the first Flash memory interface, in which the Flash memory con- trailer splits a first process depending on the first instruction into at least two first sub- steps, in which the Flash memory controller splits a second process depending on the second instruction into at least two second sub-steps, and in which the Flash memory controller executes the first and second sub-steps, wherein the Flash memory controller interleaves execution of first and second sub-steps.
  • This method may improve 10 throughput on the Flash memory interface and may eliminate a skew between the times required for executing read and write instructions.
  • the method may include a step in which, after receiving the first instruction, the Flash memory controller pushes the first instruction onto a queue. The method then also com- prises further steps, which are only executed if the first Flash memory interface is marked as free and no unfinished earlier process relating to the first Flash memory package exists, in which the Flash memory controller pulls an earlier instruction relating to the first Flash memory package from the queue, in which the Flash memory controller marks the first Flash memory interface as busy if a first sub-step of a third process depending on the ear- lier instruction requires using the first Flash memory interface, and in which the Flash memory controller starts executing the first sub-step of the third process.
  • This method may ensure that completing processes that require usage of the same Flash memory interface are executed one after another.
  • the method may also comprise steps in which the Flash memory controller receives a completion event for a previous sub-step of the third process, the Flash memory controller releases the first Flash memory interface if the first Flash memory interface has been used for executing the previous sub-step.
  • the method then also comprises further steps, which are only executed if the previous sub-step is not the last sub-step of the third process, in which the Flash memory controller marks the first Flash memory interface as busy if the first Flash memory interface is needed for the next sub-step of the third process, and in which the Flash memory controller starts executing the next sub-step of the third process. This may allow for pipelining sub-steps of several completing processes, thereby reducing the overall execution time of all processes.
  • the method may also includes steps in which after finishing execution of the third process the Flash memory controller pulls a fourth instruction relating to the first Flash memory package from the queue, the Flash memory controller marks the first Flash memory interface as busy if a first sub-step of a fourth process depending on the fourth instruction requires using the first Flash memory interface, and the Flash memory controller starts executing the first sub-step of the fourth process. This may ensure that processes that have been queued for later execution are executed once the Flash memory interface becomes available again.
  • Fig. 1 depicts a schematic representation of a Flash memory system with a Flash memory controller
  • Fig. 2 shows a timing diagram of a read process
  • Fig. 3 shows a timing diagram of a write process
  • Fig. 4 shows a timing diagram of an erase process
  • Fig. 5 shows a schematic flow diagram of a method for operating a Flash memory controller
  • Fig. 6 shows a schematic flow diagram of further steps of a method for operating a Flash memory controller.
  • Fig. 1 shows a simplified schematic representation of a Flash memory system 400.
  • the Flash memory system 400 may for example be a Flash storage device and may for example serve as a replacement for a hard disc drive.
  • the Flash memory system 400 may also be a portable storage device.
  • the Flash memory system 400 comprises a Flash memory controller 500.
  • the Flash memory controller 500 comprises a host interface 570 through which the Flash memory controller 500 may communicate with an external system, for example with a personal computer.
  • the Flash memory controller 500 may receive instructions via the host interface 570, may receive data to store in the Flash memory system 400 via the host interface 570 and may send out data retrieved from the Flash memory system 400 to the host system via the host interface 570.
  • the Flash memory controller 500 is coupled to a first Flash memory interface 510 and to a second Flash memory interface 520.
  • the Flash memory controller 500 may be coupled only to the first Flash memory interface 510 or may be coupled to more than two Flash memory interfaces 510, 520.
  • the Flash memory interface 510, 520 may also be referred to as channels.
  • a first Flash memory package 530 and a second Flash memory package 540 are coupled to the first Flash memory interface 510.
  • only the Flash memory package 530 may be provided or the first Flash memory interface 510 may be coupled to more than two Flash memory packages 530, 540.
  • a third Flash memory package 550 and a fourth Flash memory package 560 are coupled to the second Flash memory interface 520.
  • the second Flash memory interface may be coupled to only one Flash memory package 550 or to more than two Flash memory packages 550, 560.
  • each Flash memory interface 510, 520 may currently be in use, which throughout this description will also be referred to as busy or occupied, or it may currently be not in use, which will be referred to as free or available.
  • Each Flash memory package 530, 540, 550, 560 comprises one or more chip dies.
  • the first Flash memory package 530 comprises a first chip die 531 and second chip die 532.
  • Each chip die 531, 532 may for example com- prise 2 GB of memory cells.
  • the memory cells of each die may for example be grouped into 8192 blocks.
  • Each block of each chip die 531, 532 may in turn be grouped into 64 pages, each page comprising 4 KB of memory cells.
  • the memory cells of each page may store data, metadata or error detection or correction information.
  • the Flash memory controller 500 further comprises an instruction queue 501, a process list 502, a timer device 503, a first flag 504 and a second flag 505.
  • the instruction queue 501, the process list 502 and the flags 504, 505 may for example be designed as RAM memory cells.
  • the instruction queue 501 is adapted as a FIFO (first in, first out) queue.
  • the instruction queue 501 may, however, also be adapted in another way.
  • the timer device 503 is capable of triggering events at programmable points in time. An event triggered by the timer device 503 triggers execution of a predefined routine by the Flash memory controller 500.
  • the Flash memory controller 500 may comprise further components necessary for operating the Flash memory packages 530, 540, 550, 560.
  • the Flash memory controller 500 may for example maintain a list that maps logical block addresses of the Flash memory pack- ages 530, 540, 550, 560 to physical block addresses of the Flash memory packages 530, 540, 550, 560.
  • the Flash memory controller 500 may also comprise a wear-leveling garbage collection and a bad block management. These components are well known to those of skill in the art in the field of Flash memory systems.
  • the Flash memory controller 500 is designed for receiving instructions through the host interface 570. Instructions may be either read instructions, write instructions or erase instructions. A read instruction instructs the Flash memory controller 500 to execute a process that reads out data stored in one of the Flash memory packages 530, 540, 550, 560 and to send the retrieved data via the host interface 570.
  • a write instruction instructs the Flash memory controller 500 to retrieve data via the host interface 570 and to store the retrieved data in one of the Flash memory packages 530, 540, 550, 560.
  • An erase instruction instructs the Flash memory controller 500 to execute a process that erases the data stored in one or more blocks of one of the Flash memory packages 530, 540, 550, 560.
  • Fig. 2 shows a schematic diagram of a read process 100 executed by the Flash memory controller 500 upon receiving a read instruction.
  • the read process comprises a first read sub-step 110, a second read sub-step 120 and a third read sub-step 130.
  • FIG. 2 assumes that the read process 100 reads data stored in one of the chip dies 531, 532 of the first Flash memory package 530 coupled to the first Flash memory inter- face 510.
  • the horizontal axis of Fig. 2 depicts increasing time.
  • a first graph 140 depicts data traffic on the first Flash memory interface 510.
  • a second graph 150 depicts whether the Flash memory interface 510 is busy or free.
  • An upper level of the graph 150 indicates that the first Flash memory interface 510 is required during execution of the read process 100 and is thus busy, while a lower level of the graph 150 indicates that the first Flash memory interface 510 is not used during this period of execution of the read process 100 and is thus free.
  • the Flash memory controller 500 consecutively sends a first command code 141, a page address 142 and a second command code 143 to the first Flash memory package 530 via the first Flash memory interface 510.
  • the first read sub- step 110 lasts for a first read sub-step duration 115 that is seven clock cycles long. One clock cycle may for example require 25 ns.
  • the first Flash memory interface 510 is required for transferring the first command code 141, the page address 142 and the second command code 143, and therefore not available for other processes.
  • the first Flash memory package 530 retrieves the requested data from one of the chip dies 531, 532 and stores the data in an internal buffer associated with the respective chip die of the first Flash memory package 530.
  • the second read sub-step 120 lasts for a second read sub-step duration 125 that may for example be 25 long.
  • the first Flash memory interface 510 is not required for the read process 100 dur- ing the second read sub-step 120, as is indicated by the second graph 150.
  • the flash memory controller 500 retrieves the requested data 144 from the internal buffer associated with the respective chip die of the first Flash memory package 530 via the first Flash memory interface 510.
  • the third read sub-step 130 lasts for a third read sub-step duration 135 that may for example be 100 long.
  • the first Flash memory interface 510 is occupied by the read process 100, as is indicated by the graph 150 in Fig. 2.
  • Fig. 3 displays a schematic timing diagram of a write process 200 executed by the Flash memory controller 500.
  • the write process 200 writes data to one of the chip dies 531, 532 of the first Flash memory package 530.
  • the horizontal axis of Fig. 3 depicts increasing time.
  • a first graph 240 depicts data transferred between the Flash memory controller 500 and the first Flash memory package 530 via the first Flash memory interface 510.
  • a second graph 250 depicts whether the first Flash memory interface 510 is required at a respective point in time during execution of the write process 200.
  • An upper level indicates that the first Flash memory interface 510 is required, while a lower level indicates that the first Flash memory interface 510 is not required.
  • the write process 200 comprises a first write sub-step 210, a second write sub-step 220 and a third write sub-step 230.
  • the Flash memory controller 500 consecutively sends a first command code 241, a page address 242, data 243 to be stored in the memory cells of one of the chip dies 531, 532 of the first Flash memory package 530 and a second command code 244 to the first Flash memory package 530 via the first Flash memory interface 510.
  • the first Flash memory interface 510 is occupied during the first write sub-step 210.
  • the first write sub-step 210 lasts for a first write sub-step duration 215 that may be approximately 100 long.
  • the first Flash memory package 530 first stores the retrieved data 243 in the internal buffer that is associated with the respective chip die 531, 532 of the first Flash memory package 530.
  • the first Flash memory package 530 writes the data 243 stored in the internal buffer of the first Flash memory package 530 to the individual memory cells of the chip dies 531, 532.
  • the first Flash memory interface 510 is not required for the write process 200.
  • the second write sub-step 200 lasts for a second write sub-step duration 225 that may for example be 200 long.
  • the Flash memory controller 500 retrieves a third command code 245 and a fourth command code 246 from the first Flash memory package 530 via the Flash memory interface 510 to determine if the data write has been executed successfully. Hence, the first Flash memory interface 510 is busy during the third write sub-step 230.
  • the third write sub-step 230 lasts for a third write sub-step duration 235 that may for example be two clock cycles long.
  • Fig. 4 depicts a schematic timing diagram of an erase process 300 executed by the Flash memory controller 500.
  • the erase process 300 erases data from memory cells of one of the chip dies 531 , 532 of the first Flash memory package 530.
  • the horizontal axis again depicts increasing time.
  • a first graph 340 depicts data transferred between the Flash memory controller 500 and the first Flash memory package 530 via the first Flash memory interface 510.
  • a second graph 350 depicts if the first Flash memory interface 510 is required for executing the erase process 300 at a re- spective point in time.
  • the erase process 300 comprises a first erase sub-step 310, a second erase sub-step 320 and a third erase sub-step 330.
  • the Flash memory controller 500 sends a first command code 341, a block address 342 and a second command code 343 to the first Flash memory package 530 via the first Flash memory interface 510.
  • the first Flash memory interface 510 is busy during the first erase sub-step 310.
  • the first erase sub-step 310 lasts for a first erase sub-step duration 315 that may for example be seven clock cycles long.
  • the first Flash memory package 530 erases the data from the memory cells of the block with block address 342.
  • the second erase sub-step 320 lasts for a second erase sub-step duration 325 that may for example be 1.5 ms long.
  • the first Flash memory interface 510 is not occupied for the erase process 300.
  • the Flash memory controller 500 retrieves a third command code 344 and a fourth command code 345 from the first Flash memory package 530 via the first Flash memory interface 510 to determine if erasing the data from the requested block has been successful.
  • the first Flash memory interface 510 is occupied by the erase process 300 during the third erase sub-step 330.
  • the third erase sub-step 330 lasts for a third erase sub-step duration 335 that may for example be two clock cycles long.
  • FIG. 1 shows that the first Flash memory package 530 and the second Flash memory package 540 are both coupled to the Flash memory controller 500 through the first Flash memory interface 510.
  • the first Flash memory interface 510 is completely blocked while the Flash memory controller 500 executes a process related to the first chip die 531 of the first Flash memory package 530. Consequently, the Flash memory controller 500 cannot execute a process related to the second chip die 532 of the first Flash memory package 530 before the competing process related to the first chip die 531 of the first Flash memory package 530 has finished.
  • FIG. 2, 3 and 4 have shown that the read process 100, the write process 200 and the erase process 300 each comprise sub-steps during which the first Flash memory interface 510 is not required.
  • One idea of the present invention is to make use of these intervals for executing sub-steps of competing processes in parallel. This allows for achieving an improved overall performance. This method especially allows for making the read process 100 and the write process 200 equally fast.
  • the proposed method for example allows to partially execute the first read process related to the first chip die 531 of the first Flash memory package 530 in parallel to a second read process related to the second chip die 532 of the first Flash memory package 530.
  • Two processes related to the same chip die of the Flash memory package must, however, still execute sequentially to avoid a corruption of data.
  • the principle is to pipeline sub-steps of processes related to Flash memory packages coupled to the same Flash memory interface while letting read processes, write processes and erase processes complete according to their sub-steps in sequence without corruption.
  • the Flash memory controller 500 keeps track of all incomplete read processes, write processes and erase processes for each Flash memory interface coupled to the Flash memory controller 500, as well as it keeps track of the current sub-step of each incomplete read process, write process and erase process. This information is stored in the process list 502 of the Flash memory controller 500.
  • the Flash memory controller 500 further maintains a timer for each incomplete read process, write process and erase proc- ess, to know once a sub-step of one of these processes completes. To do so, the Flash memory controller 500 makes use of the timer device 503.
  • the Flash memory controller 500 checks if it is possible to advance an incomplete process to its respective next sub-step, and if not, checks if it is possible to start a new read process, write process or erase process.
  • the Flash memory controller 500 maintains the flags 504, 505 to determine if the Flash memory interfaces 510, 520 is busy or free.
  • Fig. 5 shows a schematic flow diagram depicting steps of a method executed by the Flash memory controller 500.
  • the Flash memory controller 500 receives an instruction related to one of the chip dies of the one of the Flash memory packages 530, 540, 550, 560 via the host interface 570.
  • the instruction received by the Flash memory controller 500 in the first step 610 may for example be a read instruction related to the first chip die 531 of the first Flash memory package 530.
  • the Flash memory controller 500 checks the flags 504, 505 to determine whether the required Flash mem- ory interface 510, 520 is busy or occupied.
  • the Flash memory controller 500 for example checks the first flag 504 to determine if the first Flash memory interface 510 is free.
  • the Flash memory controller 500 pushes the retrieved instruction onto the instruction queue 501 in a third step 630 and finishes execution of the method. If the relevant Flash memory interface 510, 520, however, is free, the Flash memory controller 500 checks in a fourth step 640, if an earlier process related to the same chip die 531, 532 of the same Flash memory package 530, 540, 550, 560 has not finished yet. In the given example, the Flash memory controller 500 checks if an earlier process related to the first chip die 531 of the Flash memory package 530 is unfinished. The Flash memory controller 500 performs this check by looking up the process list 502.
  • the Flash memory controller 500 pushes the instruction received in the first step 610 onto the instruction queue 501 and finishes execution. Otherwise the method continues with a fifth step 650 in which the current instruction is pushed onto the instruction queue 501. Afterwards, the Flash memory controller 500 pulls one instruction from the instruction queue 501 in a sixth step 660 and starts executing this instruction. Pushing the instruction received in the first step 610 onto the instruction queue 501 in the fifth step 650 and pulling one instruction from the instruction queue 501 in the sixth step 660 makes sure that instructions received earlier are executed earlier by the Flash memory controller 500.
  • the Flash memory controller 500 marks the first Flash memory interface 510 as busy using the first flag 504, sets up the timer device 503 to trigger an event upon completion of the first sub-step of the process and then starts execution of the first sub-step of the process.
  • the Flash memory controller 500 is further adapted to execute a method depicted in the schematic flow diagram of Fig. 6.
  • the Flash memory controller 500 receives a sub-step completion event from the timer device 503 in a first step 710.
  • the completion event triggered by the timer device 503 indicates that a sub-step of a process started earlier has completed.
  • the Flash memory controller 500 checks if the completed sub-step required using one of the Flash memory interfaces 510, 520. If this was not the case the Flash memory controller 500 directly advances to a fourth step 740. If the completed sub-step, however, did use one of the Flash memory interfaces 510, 520, the
  • Flash memory controller 500 marks the respective Flash memory interface 510, 520 as free in a third step 730 by modifying the respective flag 504, 505. If the completed sub-step for example was using the first Flash memory interface 510 the Flash memory controller 500 marks the first flag 504 as free. The Flash memory controller 500 then advances to the fourth step 740 in which the Flash memory controller 500 checks if the completed sub-step was the last sub-step of the respective process. If this is the case the Flash memory controller 500 completes execution of the respective process and then jumps to the sixth step 660 of the method depicted in Fig. 5 to pull a next instruction from the instruction queue 501 and starts executing that instruction.
  • the Flash memory controller 500 advances to a fifth step 750 in which the Flash memory controller 500 checks if the next sub-step of the respective process will require using one of the Flash memory interfaces 510, 520. If this is not the case the Flash memory controller 500 advances to a ninth sub-step 790. If the next sub-step, however, requires using one of the Flash memory interfaces 510, 520 the Flash memory controller advances to a sixth step
  • the Flash memory controller 500 checks if the respective Flash memory interface 510, 520 is currently free. The Flash memory controller 500 does so by checking the flags 504, 505. If the next sub-step of the current process for example requires using the first Flash memory interface 510 the Flash memory controller 500 checks the first flag 504. If the required Flash memory interface 510, 520 is available the Flash memory controller 500 advances to an eighth step 780. Otherwise the Flash memory controller 500 waits until the respective Flash memory interface 510, 520 becomes free in a seventh step 770. Once the required Flash memory interface 510, 520 becomes free the Flash memory controller 500 continues with the eighth step 780. In the eighth step 780 the Flash memory controller 500 marks the respective Flash memory interface 510, 520 as busy by modifying one of the flags 504, 505. Then the Flash memory controller 500 continues with the ninth step 790 in which the Flash memory controller 500 sets up the timer device 503 to trigger an event upon completion of the next sub-step of the current process and then starts executing the next sub-step of the current process.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Read Only Memory (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

L'invention porte sur un contrôleur de mémoire flash couplé à un premier boîtier de mémoire flash par l'intermédiaire d'une première interface de mémoire flash et à un second boîtier de mémoire flash par l'intermédiaire de la première interface de mémoire flash. Le contrôleur de mémoire flash est conçu pour recevoir une première instruction concernant le premier boîtier de mémoire flash et pour exécuter un premier traitement en fonction de la première instruction. Le contrôleur de mémoire flash est en outre conçu pour recevoir une seconde instruction concernant le second boîtier de mémoire flash et pour exécuter un second traitement en fonction de la seconde instruction. Le contrôleur de mémoire flash est en outre conçu pour scinder le premier traitement en au moins deux premières sous-étapes et pour scinder le second traitement en au moins deux secondes sous-étapes. Le contrôleur de mémoire flash est en outre conçu pour exécuter les premières et secondes sous-étapes, et pour entrelacer l'exécution des premières et secondes sous-étapes.
PCT/IB2010/055684 2009-12-11 2010-12-09 Contrôleur de mémoire flash WO2011070526A1 (fr)

Priority Applications (4)

Application Number Priority Date Filing Date Title
GB1207123.9A GB2488259A (en) 2009-12-11 2010-12-09 Flash memory controller
US13/515,118 US8996794B2 (en) 2009-12-11 2010-12-09 Flash memory controller
DE112010003762T DE112010003762B4 (de) 2009-12-11 2010-12-09 Flash-Speicher-Steuereinheit
CN201080056012.6A CN102652313B (zh) 2009-12-11 2010-12-09 闪速存储器控制器及其操作方法

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP09178949.5 2009-12-11
EP09178949 2009-12-11

Publications (1)

Publication Number Publication Date
WO2011070526A1 true WO2011070526A1 (fr) 2011-06-16

Family

ID=43806796

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/IB2010/055684 WO2011070526A1 (fr) 2009-12-11 2010-12-09 Contrôleur de mémoire flash

Country Status (5)

Country Link
US (1) US8996794B2 (fr)
CN (1) CN102652313B (fr)
DE (1) DE112010003762B4 (fr)
GB (1) GB2488259A (fr)
WO (1) WO2011070526A1 (fr)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103092782A (zh) * 2011-07-14 2013-05-08 Lsi公司 用于闪存器件的闪存控制器硬件架构
EP2546756A3 (fr) * 2011-07-14 2013-10-09 LSI Corporation Utilisation efficace d'interface flash
US8806112B2 (en) 2011-07-14 2014-08-12 Lsi Corporation Meta data handling within a flash media controller

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9256384B2 (en) * 2013-02-04 2016-02-09 Avago Technologies General Ip (Singapore) Pte. Ltd. Method and system for reducing write latency in a data storage system by using a command-push model
US9195406B2 (en) * 2013-06-28 2015-11-24 Micron Technology, Inc. Operation management in a memory device
US20160124639A1 (en) * 2014-11-05 2016-05-05 SanDisk Technologies, Inc. Dynamic storage channel
GB2539445A (en) 2015-06-16 2016-12-21 Nordic Semiconductor Asa Data processing
CN105426122B (zh) * 2015-11-02 2019-09-03 深圳忆联信息系统有限公司 一种数据处理的方法、电子设备及存储装置
KR102509048B1 (ko) * 2016-04-26 2023-03-10 에스케이하이닉스 주식회사 반도체 패키지
KR102430209B1 (ko) * 2017-09-07 2022-08-05 삼성전자주식회사 저장 장치 및 저장 장치에 포함된 컨트롤러들

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080005471A1 (en) * 2000-01-06 2008-01-03 Super Talent Electronics, Inc. Flash Memory Controller For Electronic Data Flash Card
WO2008070173A1 (fr) * 2006-12-06 2008-06-12 Fusion Multisystems, Inc. (Dba Fusion-Io) Dispositif, système et procédé de stockage à semi-conducteurs sous forme de cache pour stockage rémanent de grande capacité
US20090164703A1 (en) * 2007-12-21 2009-06-25 Spansion Llc Flexible flash interface
WO2009140112A1 (fr) * 2008-05-13 2009-11-19 Rambus Inc. Commandes de programme fractionnaires pour mémoires

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5890193A (en) * 1995-07-28 1999-03-30 Micron Technology, Inc. Architecture for state machine for controlling internal operations of flash memory
US8341332B2 (en) * 2003-12-02 2012-12-25 Super Talent Electronics, Inc. Multi-level controller with smart storage transfer manager for interleaving multiple single-chip flash memory devices
JP2003036681A (ja) * 2001-07-23 2003-02-07 Hitachi Ltd 不揮発性記憶装置
KR101437517B1 (ko) * 2007-10-23 2014-09-05 삼성전자주식회사 인터리빙 기법을 이용한 메모리 시스템, 및 그 방법
US8738841B2 (en) * 2007-12-27 2014-05-27 Sandisk Enterprise IP LLC. Flash memory controller and system including data pipelines incorporating multiple buffers
TW201009577A (en) * 2008-08-27 2010-03-01 Phison Electronics Corp Data transfer method for flash memory and flash memory storage system and controller using the same
US8370603B2 (en) * 2008-12-23 2013-02-05 Apple Inc. Architecture for address mapping of managed non-volatile memory

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080005471A1 (en) * 2000-01-06 2008-01-03 Super Talent Electronics, Inc. Flash Memory Controller For Electronic Data Flash Card
WO2008070173A1 (fr) * 2006-12-06 2008-06-12 Fusion Multisystems, Inc. (Dba Fusion-Io) Dispositif, système et procédé de stockage à semi-conducteurs sous forme de cache pour stockage rémanent de grande capacité
US20090164703A1 (en) * 2007-12-21 2009-06-25 Spansion Llc Flexible flash interface
WO2009140112A1 (fr) * 2008-05-13 2009-11-19 Rambus Inc. Commandes de programme fractionnaires pour mémoires

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
LEE, JONGMIN ET AL.: "CPS-SIM: Configurable and Accurate Clock PrecisionSolid State Drive Simulator", ACM, 2 PENN PLAZA, SUITE 701 - NEW YORK USA, 12 March 2009 (2009-03-12), XP040464994 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103092782A (zh) * 2011-07-14 2013-05-08 Lsi公司 用于闪存器件的闪存控制器硬件架构
EP2546755A3 (fr) * 2011-07-14 2013-10-09 LSI Corporation Architecture de matériel de contrôleur flash pour dispositifs flash
EP2546756A3 (fr) * 2011-07-14 2013-10-09 LSI Corporation Utilisation efficace d'interface flash
US8806112B2 (en) 2011-07-14 2014-08-12 Lsi Corporation Meta data handling within a flash media controller

Also Published As

Publication number Publication date
DE112010003762T5 (de) 2012-11-15
CN102652313A (zh) 2012-08-29
DE112010003762B4 (de) 2012-12-06
US20120278544A1 (en) 2012-11-01
US8996794B2 (en) 2015-03-31
GB2488259A (en) 2012-08-22
CN102652313B (zh) 2015-04-15
GB201207123D0 (en) 2012-06-06

Similar Documents

Publication Publication Date Title
US8996794B2 (en) Flash memory controller
TWI628542B (zh) 快閃記憶體的垃圾回收斷電回復方法以及使用該方法的裝置
US8966231B2 (en) Modifying commands
JP5213965B2 (ja) 1セル当り単一ビットnandフラッシュメモリをエミュレートする1セル当り多ビットnandフラッシュメモリ用コントローラ
US8171242B2 (en) Systems and methods for scheduling a memory command for execution based on a history of previously executed memory commands
US8495332B2 (en) Controller for optimizing throughput of read operations
EP2022059B1 (fr) Procédé et appareil permettant d'améliorer les capacités de stockage au moyen d'un effacement d'arrière-plan
WO2015123413A1 (fr) Mise en file d'attente d'une commande
US20130060991A1 (en) Solid state drive and garbage collection control method thereof
TWI467574B (zh) 記憶體儲存裝置、記憶體控制器與其資料傳輸方法
TWI512609B (zh) 讀取命令排程方法以及使用該方法的裝置
CN109814811B (zh) 一种减小NVMe SSD响应延迟影响高速数据存储设备写入速度的方法
EP2876541A1 (fr) Système de stockage et procédé de commande correspondant
TWI612473B (zh) 垃圾回收方法以及使用該方法的裝置
TWI588652B (zh) 讀取及寫入命令排程方法以及使用該方法的裝置
TWI626540B (zh) 一般及垃圾回收的資料存取方法以及使用該方法的裝置
TW201905679A (zh) 資料儲存裝置、非揮發式記憶體操作方法及操作指令執行方法
CN112256203B (zh) Flash存储器的写入方法、装置、设备、介质及系统
US9471227B2 (en) Implementing enhanced performance with read before write to phase change memory to avoid write cancellations
TWI631565B (zh) 快閃記憶體之廢料收集方法以及使用該方法的裝置
CN113821175A (zh) 基于存储内容优先的ssd指令调度方法及系统
US8166228B2 (en) Non-volatile memory system and method for reading and storing sub-data during partially overlapping periods
TWI602186B (zh) 快閃記憶體之廢料收集方法以及使用該方法的裝置
TWI621015B (zh) 讀取及寫入命令排程方法以及使用該方法的裝置
KR20120069953A (ko) 비휘발성 메모리 장치 및 그의 제어 방법

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 201080056012.6

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 10807746

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 1207123

Country of ref document: GB

Kind code of ref document: A

Free format text: PCT FILING DATE = 20101209

WWE Wipo information: entry into national phase

Ref document number: 1207123.9

Country of ref document: GB

WWE Wipo information: entry into national phase

Ref document number: 1120100037620

Country of ref document: DE

Ref document number: 112010003762

Country of ref document: DE

WWE Wipo information: entry into national phase

Ref document number: 13515118

Country of ref document: US

122 Ep: pct application non-entry in european phase

Ref document number: 10807746

Country of ref document: EP

Kind code of ref document: A1

ENPC Correction to former announcement of entry into national phase, pct application did not enter into the national phase

Ref country code: GB