TWI769100B - Method for managing flash memory module and associated flash memory controller and electronic device - Google Patents

Method for managing flash memory module and associated flash memory controller and electronic device Download PDF

Info

Publication number
TWI769100B
TWI769100B TW110138992A TW110138992A TWI769100B TW I769100 B TWI769100 B TW I769100B TW 110138992 A TW110138992 A TW 110138992A TW 110138992 A TW110138992 A TW 110138992A TW I769100 B TWI769100 B TW I769100B
Authority
TW
Taiwan
Prior art keywords
flash memory
block
blocks
data
memory controller
Prior art date
Application number
TW110138992A
Other languages
Chinese (zh)
Other versions
TW202205087A (en
Inventor
杜建東
蕭佳容
楊宗杰
Original Assignee
慧榮科技股份有限公司
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 慧榮科技股份有限公司 filed Critical 慧榮科技股份有限公司
Priority to TW110138992A priority Critical patent/TWI769100B/en
Publication of TW202205087A publication Critical patent/TW202205087A/en
Application granted granted Critical
Publication of TWI769100B publication Critical patent/TWI769100B/en

Links

Images

Landscapes

  • Read Only Memory (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

The present invention provides a flash memory controller, wherein the flash memory controller is arranged to access a flash memory module, and the flash memory controller includes a ROM, a microprocessor and a timer. The ROM stores a program code, the microprocessor is configured to execute the program code to control the access of the flash memory module, and the timer is used to generate time information. In the operations of the flash memory controller, the microprocessor refers to the time information to perform dummy read operations upon at least a portion of the blocks, wherein the dummy read operations are not triggered by read commands from a host device.

Description

管理快閃記憶體模組的方法及相關的快閃記憶體控制器與電 子裝置 Method for managing a flash memory module and associated flash memory controller and power supply sub device

本發明係有關於快閃記憶體控制器。 The present invention relates to a flash memory controller.

隨著快閃記憶體技術的演進,快閃記憶體晶片中之記憶單元由平面排列的方式改變為多層堆疊的模式,以使得單一晶片可以包含更多的記憶單元,以提升快閃記憶體晶片的容量。然而,上述立體快閃記憶體(3D flash memory)會遭遇到一些讀取品質上的問題,例如若是一區塊內的資料長時間沒有被讀取,則該區塊內的資料品質便會快速劣化,而造成後續該區塊的資料在解碼上的困難,或甚至無法被正確的讀取。因此,如何提出一種有效率的管理方法來避免資料保存上的問題是一個重要的技術方向。 With the evolution of flash memory technology, the memory cells in the flash memory chip are changed from a planar arrangement to a multi-layer stacking mode, so that a single chip can contain more memory cells, so as to improve the flash memory chip. capacity. However, the above-mentioned 3D flash memory will encounter some problems in reading quality. For example, if the data in a block has not been read for a long time, the quality of the data in the block will be fast. Deterioration, which makes it difficult to decode the data of the subsequent block, or even cannot be read correctly. Therefore, how to propose an efficient management method to avoid the problem of data preservation is an important technical direction.

因此,本發明的目的之一在於提出一種管理快閃記憶體的方法,其可以有效地避免上述區塊內的資料因為長時間沒有讀取而發生劣化的情形,以解決先前技術中的問題。 Therefore, one of the objectives of the present invention is to provide a method for managing a flash memory, which can effectively avoid the deterioration of the data in the above-mentioned blocks due to the long-term non-reading, so as to solve the problems in the prior art.

在本發明的一個實施例中,揭露一種快閃記憶體控制器,其中該快閃記憶體控制器係用來存取一快閃記憶體模組,且該快閃記憶體控制器包含有一唯讀記憶體、一微處理器以及一計時器。該唯讀記憶體係用來儲存一程式碼,該微處理器用來執行該程式碼以控制對該快閃記憶體模組之存取,且該計時器用以產生一時間資訊。在該快閃記憶體控制器的操作中,該微處理器根據該計時器所產生的該時間資訊,以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發。 In one embodiment of the present invention, a flash memory controller is disclosed, wherein the flash memory controller is used to access a flash memory module, and the flash memory controller includes a unique Read memory, a microprocessor and a timer. The ROM system is used to store a code, the microprocessor is used to execute the code to control access to the flash memory module, and the timer is used to generate time information. In the operation of the flash memory controller, the microprocessor performs a redundant read operation on at least a part of the plurality of blocks according to the time information generated by the timer, wherein the Redundant read operations are not triggered by a read command from a master.

在本發明的另一個實施例中,揭露了一種管理一快閃記憶體模組的方法,其中該快閃記憶體模組包含了多個快閃記憶體晶片,每一個快閃記憶體晶片包含了多個區塊,每一個區塊包含多個資料頁,且該方法包含有:使用一計時器以產生一時間資訊;以及根據該計時器所產生的該時間資訊,以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發。 In another embodiment of the present invention, a method for managing a flash memory module is disclosed, wherein the flash memory module includes a plurality of flash memory chips, and each flash memory chip includes A plurality of blocks are formed, each block includes a plurality of data pages, and the method includes: using a timer to generate a time information; and according to the time information generated by the timer, to the plurality of areas At least a portion of the blocks perform a redundant read operation, wherein the redundant read operation is not triggered by a read command from a master device.

在本發明的另一個實施例中,揭露了一種電子裝置,其包含有一快閃記憶體模組以及一快閃記憶體控制器,其中該快閃記憶體模組包含了多個快閃記憶體晶片,每一個快閃記憶體晶片包含了多個區塊,每一個區塊包含多個資料頁。在該快閃記憶體控制器的操作中,該快閃記憶體控制器根據一計時器所產生的時間資訊以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發。 In another embodiment of the present invention, an electronic device is disclosed, which includes a flash memory module and a flash memory controller, wherein the flash memory module includes a plurality of flash memories Chip, each flash memory chip includes a plurality of blocks, and each block includes a plurality of data pages. In the operation of the flash memory controller, the flash memory controller performs a redundant read operation on at least a part of the plurality of blocks according to time information generated by a timer, wherein The redundant read operation is not triggered by a read command from a master.

100:記憶裝置 100: Memory Device

110:快閃記憶體控制器 110: Flash memory controller

112:微處理器 112: Microprocessor

112C:程式碼 112C: Code

112M:唯讀記憶體 112M: read-only memory

114:控制邏輯 114: Control logic

116:緩衝記憶體 116: Buffer memory

118:介面邏輯 118: Interface logic

119:計時器 119: Timer

120:快閃記憶體模組 120: Flash memory module

130:主裝置 130: Main unit

132:編碼器 132: Encoder

134:解碼器 134: decoder

N1~NK:接腳 N1~NK: pin

200,B1~BN:區塊 200, B1~BN: block

202:浮閘電晶體 202: floating gate transistor

BL1,BL2,BL3:位元線 BL1, BL2, BL3: bit lines

WL0~WL2,WL4~WL6:字元線 WL0~WL2,WL4~WL6: word lines

L1~L8:電壓位準 L1~L8: Voltage level

Vt1~Vt7:臨界電壓 Vt1~Vt7: Threshold voltage

400:區塊記錄表 400: Block record table

500,600:區塊讀取時間記錄表 500,600: Block read time record table

800~804:步驟 800~804: Steps

第1圖為依據本發明一實施例之一種記憶裝置的示意圖。 FIG. 1 is a schematic diagram of a memory device according to an embodiment of the present invention.

第2圖為依據本發明一實施例之快閃記憶體中一區塊的示意圖。 FIG. 2 is a schematic diagram of a block in a flash memory according to an embodiment of the present invention.

第3圖為三層式儲存區塊之每一個記憶單元中多個寫入電壓位準以及多個臨界電壓的示意圖。 FIG. 3 is a schematic diagram of a plurality of write voltage levels and a plurality of threshold voltages in each memory cell of the three-layer memory block.

第4圖為根據本發明一實施例之區塊記錄表的示意圖。 FIG. 4 is a schematic diagram of a block record table according to an embodiment of the present invention.

第5圖為根據本發明一實施例之區塊讀取時間記錄表的示意圖。 FIG. 5 is a schematic diagram of a block read time record table according to an embodiment of the present invention.

第6圖為根據本發明一實施例之區塊讀取時間記錄表的示意圖。 FIG. 6 is a schematic diagram of a block read time record table according to an embodiment of the present invention.

第7圖為根據本發明一實施例之更新區塊讀取時間記錄表的示意圖。 FIG. 7 is a schematic diagram of an update block read time record table according to an embodiment of the present invention.

第8圖為根據本發明一實施例之一種管理一快閃記憶體模組的方法的流程圖。 FIG. 8 is a flowchart of a method for managing a flash memory module according to an embodiment of the present invention.

第1圖為依據本發明一實施例之一種記憶裝置100的示意圖。記憶裝置100包含有一快閃記憶體(Flash Memory)模組120以及一快閃記憶體控制器110,且快閃記憶體控制器110用來存取快閃記憶體模組120。依據本實施例,快閃記憶體控制器110包含一微處理器112、一唯讀記憶體(Read Only Memory,ROM)112M、一控制邏輯114、一緩衝記憶體116、一介面邏輯118以及一計時器119。唯讀記憶體112M係用來儲存一程式碼112C,而微處理器112則用來執行程式碼112C以控制對快閃記憶體模組120之存取(Access)。控制邏輯114包含了一編碼器132以及一解碼器134,其中編碼器132用來對寫入到快閃記憶體模組120中的資料進行編碼以產生對應的校驗碼(或稱,錯誤更正碼(Error Correction Code),ECC),而解碼器134用來將從快閃記憶體模組120所讀出的資料進行解碼。 FIG. 1 is a schematic diagram of a memory device 100 according to an embodiment of the present invention. The memory device 100 includes a flash memory module 120 and a flash memory controller 110 , and the flash memory controller 110 is used for accessing the flash memory module 120 . According to this embodiment, the flash memory controller 110 includes a microprocessor 112, a read only memory (ROM) 112M, a control logic 114, a buffer memory 116, an interface logic 118, and a Timer 119. The ROM 112M is used to store a code 112C, and the microprocessor 112 is used to execute the code 112C to control access to the flash memory module 120 . The control logic 114 includes an encoder 132 and a decoder 134, wherein the encoder 132 is used to encode the data written into the flash memory module 120 to generate a corresponding check code (or error correction code). code (Error Correction Code, ECC), and the decoder 134 is used for decoding the data read from the flash memory module 120 .

此外,快閃記憶體控制器110與快閃記憶體模組120均包含了多個相互連接的接腳N1~NK,以供彼此之間的資料及命令的傳輸。由於接腳N1~NK的功用可參考快閃記憶體的相關規格書,故細節不再此敘述。 In addition, both the flash memory controller 110 and the flash memory module 120 include a plurality of interconnected pins N1 ˜NK for transmitting data and commands between each other. Since the functions of pins N1~NK can refer to the relevant specifications of the flash memory, the details will not be described here.

於典型狀況下,快閃記憶體模組120包含了多個快閃記憶體晶片,而每一個快閃記憶體晶片包含複數個區塊(block),而快閃記憶體控制器110對快閃記憶體模組120進行抹除資料運作係以區塊為單位來進行。另外,一區塊可記錄特定數量的資料頁(page),其中快閃記憶體控制器110對快閃記憶體模組120進行寫入資料之運作係以資料頁為單位來進行寫入。在本實施例中,快閃記憶體模組120為一立體NAND型快閃記憶體(3D NAND-type flash)模組。 In a typical situation, the flash memory module 120 includes a plurality of flash memory chips, and each flash memory chip includes a plurality of blocks, and the flash memory controller 110 controls the flash memory. The operation of erasing data by the memory module 120 is performed in units of blocks. In addition, a block can record a specific number of data pages, wherein the operation of the flash memory controller 110 to write data to the flash memory module 120 is performed in units of data pages. In this embodiment, the flash memory module 120 is a three-dimensional NAND-type flash memory (3D NAND-type flash) module.

實作上,透過微處理器112執行程式碼112C之快閃記憶體控制器110可利用其本身內部之元件來進行諸多控制運作,例如:利用控制邏輯114來控制快閃記憶體模組120之存取運作(尤其是對至少一區塊或至少一資料頁之存取運作)、利用緩衝記憶體116進行所需之緩衝處理、以及利用介面邏輯118來與一主裝置(Host Device)130溝通。緩衝記憶體116係以隨機存取記憶體(Random Access Memory,RAM)來實施。例如,緩衝記憶體116可以是靜態隨機存取記憶體(Static RAM,SRAM),但本發明不限於此。 In practice, the flash memory controller 110 that executes the code 112C through the microprocessor 112 can use its own internal components to perform various control operations. For example, the control logic 114 is used to control the flash memory module 120. Access operations (especially access operations to at least one block or at least one data page), use the buffer memory 116 to perform required buffering, and use the interface logic 118 to communicate with a Host Device 130 . The buffer memory 116 is implemented by random access memory (Random Access Memory, RAM). For example, the buffer memory 116 may be a static random access memory (Static RAM, SRAM), but the invention is not limited thereto.

在一實施例中,記憶裝置100可以是可攜式記憶裝置(例如:符合SD/MMC、CF、MS、XD標準之記憶卡),且主裝置130為一可與記憶裝置連接的電子裝置,例如手機、筆記型電腦、桌上型電腦...等等。而在另一實施例中,記憶裝置100可以是固態硬碟或符合通用快閃記憶體儲存(Universal Flash Storage,UFS)或嵌入式多媒體記憶卡(Embedded Multi Media Card,EMMC)規格 之嵌入式儲存裝置,以設置在一電子裝置中,例如設置在手機、筆記型電腦、桌上型電腦之中,而此時主裝置130可以是該電子裝置的一處理器。 In one embodiment, the memory device 100 may be a portable memory device (eg, a memory card conforming to SD/MMC, CF, MS, XD standards), and the host device 130 is an electronic device that can be connected to the memory device, Such as mobile phones, laptops, desktops...etc. In another embodiment, the memory device 100 may be a solid state drive or conform to the Universal Flash Storage (UFS) or Embedded Multi Media Card (EMMC) specifications The embedded storage device is arranged in an electronic device, such as a mobile phone, a notebook computer, a desktop computer, and the main device 130 can be a processor of the electronic device.

第2圖為依據本發明一實施例之快閃記憶體模組120中一區塊200的示意圖,其中快閃記憶體模組120為立體NAND型快閃記憶體。如第2圖所示,區塊200包含了多個記憶單元(例如圖示的浮閘電晶體202或是其他的電荷捕捉(charge trap)元件),其透過多條位元線(圖示僅繪示了BL1~BL3)及多條字元線(例如圖示WL0~WL2、WL4~WL6)來構成立體NAND型快閃記憶體架構。在第2圖中,以最上面的一個平面為例,字元線WL0上的所有浮閘電晶體構成了至少一資料頁,字元線WL1上的所有浮閘電晶體構成了另至少一資料頁,而字元線WL2的所有浮閘電晶體構成了再另至少一資料頁...以此類堆。此外,根據快閃記憶體寫入方式的不同,字元線WL0與資料頁(邏輯資料頁)之間的定義也會有所不同,詳細來說,當使用單層式儲存(Single-Level Cell,SLC)的方式寫入時,字元線WL0上的所有浮閘電晶體僅對應到單一邏輯資料頁;當使用多層式儲存(Multi-Level Cell,MLC)的方式寫入時,字元線WL0上的所有浮閘電晶體對應到兩個邏輯資料頁;當使用三層式儲存(Triple-Level Cell,TLC)的方式寫入時,字元線WL0上的所有浮閘電晶體對應到三個邏輯資料頁;以及當使用四層式儲存(Quad-Level Cell,QLC)的方式寫入時,字元線WL0上的所有浮閘電晶體對應到四個邏輯資料頁。由於本技術領域中具有通常知識者應能了解立體NAND型快閃記憶體的結構以及字元線及資料頁之間的關係,故相關的細節在此不予贅述。 FIG. 2 is a schematic diagram of a block 200 in the flash memory module 120 according to an embodiment of the present invention, wherein the flash memory module 120 is a three-dimensional NAND type flash memory. As shown in FIG. 2, the block 200 includes a plurality of memory cells (such as the floating thyristor 202 shown in the figure or other charge trap devices), which pass through a plurality of bit lines (the figure only BL1-BL3) and a plurality of word lines (eg, WL0-WL2, WL4-WL6 are shown) are shown to form a three-dimensional NAND-type flash memory structure. In Figure 2, taking the uppermost plane as an example, all the floating thyristors on the word line WL0 constitute at least one data page, and all the floating thyristors on the word line WL1 constitute at least another data page page, and all the floating thyristors of word line WL2 constitute at least one other data page...and so on. In addition, the definition between the word line WL0 and the data page (logical data page) is also different according to the different writing methods of the flash memory. , SLC), all floating gate transistors on the word line WL0 only correspond to a single logical data page; when using the Multi-Level Cell (MLC) method, the word line All floating gate transistors on WL0 correspond to two logical data pages; when using triple-level storage (Triple-Level Cell, TLC) to write, all floating gate transistors on word line WL0 correspond to three and when writing in a quad-level cell (QLC) manner, all the floating gate transistors on the word line WL0 correspond to four logical data pages. Since those skilled in the art should be able to understand the structure of the 3D NAND flash memory and the relationship between word lines and data pages, the relevant details are omitted here.

在記憶裝置100的操作中,由於快閃記憶體模組120內的一區塊在有資料寫入的狀態下,若是該區塊長時間沒有被讀取,則該區塊的資料品質便會大幅度下降,因而造成解碼器134在解碼上的困難。因此,在本實施例中,微處 理器112會根據計時器119所產生的時間資訊,以對快閃記憶體模組120內有儲存資料之至少一部份區塊進行冗餘讀取(dummy read)操作,以避免區塊內的資料因為長時間沒有讀取而劣化。詳細來說,上述冗餘讀取操作指的是微處理器112實質上並不會真的自快閃記憶體模組120中取得該區塊的內容,且冗餘讀取操作也並非是由主裝置130的讀取命令所觸發的(亦即,微處理器112並非是因為主裝置130的要求才對該區塊進行冗餘讀取操作)。 During the operation of the memory device 100, since a block in the flash memory module 120 is in the state of data being written, if the block has not been read for a long time, the data quality of the block will be reduced. is greatly reduced, thereby causing decoding difficulties for the decoder 134. Therefore, in this embodiment, the micro The processor 112 performs a dummy read operation on at least a part of the blocks in the flash memory module 120 storing data according to the time information generated by the timer 119, so as to avoid the block The data is degraded because it has not been read for a long time. In detail, the above redundant read operation refers to the fact that the microprocessor 112 does not actually obtain the content of the block from the flash memory module 120, and the redundant read operation is not performed by Triggered by a read command from the master device 130 (ie, the microprocessor 112 does not perform a redundant read operation on the block because of a request from the master device 130).

在本實施例中,當微處理器112對該區塊進行冗餘讀取操作時,微處理器112會發送一讀取請求至快閃記憶體模組120,但此時微處理器112會關閉快閃記憶體控制器110的一讀取致能接腳(read enable pin)(例如,第1圖所示的接腳N2),亦即快閃記憶體控制器110無法自快閃記憶體模組120取得所要求讀取的資料。在接收到來自快閃記憶體控制器110的該讀取請求之後,快閃記憶體模組120便對該區塊的一或多個資料頁進行讀取,並僅將所讀取的內容暫存在本身的暫存區中,而不會將所讀取的資料傳送至快閃記憶體控制器110。如上所述,透過對該區塊進行冗餘讀取操作,可以避免該區塊內的資料品質因為長時間沒有讀取而下降。 In this embodiment, when the microprocessor 112 performs a redundant read operation on the block, the microprocessor 112 sends a read request to the flash memory module 120, but at this time, the microprocessor 112 will A read enable pin (eg, pin N2 shown in FIG. 1 ) of the flash memory controller 110 is turned off, that is, the flash memory controller 110 cannot The module 120 obtains the requested data. After receiving the read request from the flash memory controller 110, the flash memory module 120 reads one or more data pages of the block, and only temporarily stores the read content. Stored in its own temporary storage area without transferring the read data to the flash memory controller 110 . As described above, by performing redundant read operations on the block, the quality of the data in the block can be prevented from being degraded due to no reading for a long time.

在一實施例中,由於冗餘讀取操作的目的僅是為了避免該區塊內的資料品質因為長時間沒有讀取而下降,故快閃記憶體控制器110可以僅要求讀取該區塊的一個資料頁即可,以加速冗餘讀取操作的進行。 In one embodiment, since the purpose of the redundant read operation is only to prevent the quality of the data in the block from being degraded due to no reading for a long time, the flash memory controller 110 may only request the block to be read One data page is enough to speed up redundant read operations.

在另一實施例中,微處理器112可以控制/指示快閃記憶體模組120使用一單層式儲存(Single-Level Cell,SLC)讀取模式來對該區塊進行該冗餘讀取操作,而不論該區塊是單層式儲存區塊、雙層式儲存(Multi-Level Cell,MLC)區塊、 三層式儲存(Triple-Level Cell,TLC)區塊、以及四層式儲存(Quad-Level Cell,QLC)區塊中的任一者。以該區塊是三層式儲存區塊來做為說明,請參考第3圖所示之三層式儲存區塊中每一個記憶單元的多個寫入電壓位準L1~L8以及多個臨界電壓(或稱為,讀取電壓)Vt1~Vt7的示意圖。如第3圖所示,每個浮閘電晶體202可以被程式化(programmed(為具有電壓位準L1(亦即(MSB,CSB,LSB)=(1,1,1))、電壓位準L2(亦即(MSB,CSB,LSB)=(1,1,0)、電壓位準L3(亦即(MSB,CSB,LSB)=(1,0,0))、電壓位準L4(亦即(MSB,CSB,LSB)=(0,0,0))、電壓位準L5(亦即(MSB,CSB,LSB)=(0,1,0))、電壓位準L6(亦即(MSB,CSB,LSB)=(0,1,1))、電壓位準L7(亦即(MSB,CSB,LSB)=(0,0,1))或是電壓位準L8(亦即(MSB,CSB,LSB)=(1,0,1))。當快閃記憶體控制器110需要讀取浮閘電晶體202中的最低有效位元(LSB)時,快閃記憶體控制器110會使用臨界電壓Vt1、Vt5去讀取浮閘電晶體202,並根據浮閘電晶體202的導通狀態(是否有電流產生)來產生“1”或是“0”,類似地,當快閃記憶體控制器110需要讀取浮閘電晶體202中的中間有效位元(CSB)時,快閃記憶體控制器110會使用臨界電壓Vt2、Vt4與Vt6去讀取浮閘電晶體202,並根據浮閘電晶體202的導通狀態(是否有電流產生)來產生“1”或是“0”,以供解碼器134進行解碼。類似地,當快閃記憶體控制器110需要讀取浮閘電晶體202中的最高有效位元(MSB)時,快閃記憶體控制器110會使用臨界電壓Vt3與Vt7去讀取浮閘電晶體202,並根據浮閘電晶體202的導通狀態(是否有電流產生)來判斷最高有效位元是“1”或是“0”,以供解碼器134進行解碼。 In another embodiment, the microprocessor 112 can control/instruct the flash memory module 120 to use a single-level cell (SLC) read mode to perform the redundant read of the block operation, regardless of whether the block is a single-level storage block, a multi-level storage (MLC) block, Either a triple-level cell (TLC) block or a quad-level cell (QLC) block. As an illustration, the block is a three-layer storage block, please refer to the multiple write voltage levels L1-L8 and multiple thresholds of each memory cell in the three-layer storage block shown in FIG. 3. A schematic diagram of the voltages (or read voltages) Vt1 to Vt7. As shown in FIG. 3, each floating gate transistor 202 may be programmed (to have a voltage level L1 (ie (MSB,CSB,LSB)=(1,1,1)), a voltage level L2 (ie (MSB, CSB, LSB) = (1, 1, 0), voltage level L3 (ie (MSB, CSB, LSB) = (1, 0, 0)), voltage level L4 (also That is (MSB,CSB,LSB)=(0,0,0)), the voltage level L5 (ie (MSB,CSB,LSB)=(0,1,0)), the voltage level L6 (ie ( MSB,CSB,LSB)=(0,1,1)), voltage level L7 (ie (MSB,CSB,LSB)=(0,0,1)) or voltage level L8 (ie (MSB) ,CSB,LSB)=(1,0,1)). When the flash memory controller 110 needs to read the least significant bit (LSB) in the floating gate transistor 202, the flash memory controller 110 will Use the threshold voltages Vt1, Vt5 to read the floating thyristor 202, and generate "1" or "0" according to the conduction state of the floating thyristor 202 (whether current is generated), similarly, when the flash memory When the controller 110 needs to read the middle significant bit (CSB) in the floating thyristor 202, the flash memory controller 110 uses the threshold voltages Vt2, Vt4 and Vt6 to read the floating thyristor 202, and according to the floating thyristor 202 The conduction state of the thyristor 202 (whether current is generated) generates a "1" or a "0" for decoding by the decoder 134. Similarly, when the flash memory controller 110 needs to read the floating thyristor When the most significant bit (MSB) in 202 is the most significant bit (MSB), the flash memory controller 110 will use the threshold voltages Vt3 and Vt7 to read the floating thyristor 202, and according to the conduction state of the floating thyristor 202 (whether a current is generated or not) ) to determine whether the most significant bit is "1" or "0" for the decoder 134 to decode.

如第3圖所示,一般讀取三層式儲存區塊時會需要使用到多個臨界電壓Vt1~Vt7來讀取資料內容,然而,在微處理器112對該區塊(三層式儲存區塊)進行冗餘讀取操作時,只會使用單一臨界電壓來對每一個記憶單元來進行讀取,例如快閃記憶體模組120僅會使用臨界電壓Vt4來讀取每一個記憶單元,而 其餘的臨界電壓Vt1~Vt3、Vt5~Vt7則不會在冗餘讀取操作中使用。 As shown in FIG. 3, when reading a three-layer storage block, a plurality of threshold voltages Vt1-Vt7 are generally required to read data content. However, when the microprocessor 112 reads the block (three-layer storage block) block) during redundant read operation, only a single threshold voltage is used to read each memory cell, for example, the flash memory module 120 only uses the threshold voltage Vt4 to read each memory cell, and The remaining threshold voltages Vt1-Vt3, Vt5-Vt7 are not used in the redundant read operation.

冗餘讀取操作的時間點以及微處理器112如何選擇需要進行冗餘讀取操作的區塊的多個實施例如下所述。 The timing of the redundant read operation and various embodiments of how the microprocessor 112 selects the blocks that need to perform the redundant read operation are described below.

在第一個實施例中,微處理器112可以建立一區塊記錄表以記錄快閃記憶體模組120中有哪些區塊有儲存資料。參考第4圖所示之區塊記錄表400的示意圖,假設快閃記憶體模組120包含了多個區塊B1~BN,則微處理器112可以在將資料寫入至快閃記憶體模組120的過程中一併更新區塊記錄表400的內容,亦即當快閃記憶體模組120中有區塊被寫入資料時將區塊序號寫入至區塊記錄表400中(例如,圖示的B1、B2、B12、B13、B14),而在快閃記憶體模組120中有區塊被抹除或是被標記為無效時,將對應的區塊序號自區塊記錄表400中移除。因此,微處理器112便可以根據計時器119所產生的時間資訊以週期性地,例如每隔30分鐘,對區塊記錄表400所記錄的區塊進行冗餘讀取操作,以維持這些有儲存資料之區塊的資料品質。 In the first embodiment, the microprocessor 112 can create a block record table to record which blocks in the flash memory module 120 have stored data. Referring to the schematic diagram of the block record table 400 shown in FIG. 4, if the flash memory module 120 includes a plurality of blocks B1-BN, the microprocessor 112 can write data to the flash memory module when During the process of group 120, the contents of the block record table 400 are updated together, that is, when data is written to a block in the flash memory module 120, the block serial number is written into the block record table 400 (for example, , B1, B2, B12, B13, B14 in the figure), and when a block in the flash memory module 120 is erased or marked as invalid, the corresponding block serial number is recorded from the block record table 400 removed. Therefore, the microprocessor 112 can periodically, for example, every 30 minutes, perform redundant read operations on the blocks recorded in the block record table 400 according to the time information generated by the timer 119 to maintain these The data quality of the block where the data is stored.

在本實施例中,區塊記錄表400可以暫存在緩衝記憶體116或是外部的動態隨機存取記憶體中,並在記憶裝置100關機或是需要釋放記憶體空間時將區塊記錄表400寫入至快閃記憶體模組120中。 In this embodiment, the block record table 400 can be temporarily stored in the buffer memory 116 or an external dynamic random access memory, and the block record table 400 can be stored when the memory device 100 is shut down or needs to release memory space. Write to the flash memory module 120 .

在第二個實施例中,微處理器112可以建立一區塊讀取時間記錄表以記錄快閃記憶體模組120中有被讀取過的區塊及對應的時間資訊。參考第5圖所示之區塊讀取時間記錄表500的示意圖,假設快閃記憶體模組120包含了多個區塊B1~BN,則微處理器112可以在將快閃記憶體模組120內每一個區塊被讀取時 記錄該區塊的時間資訊(例如,由主裝置130或是計時器119所獲得的時間戳記)。在一實施例中,區塊讀取時間記錄表500的內容會不斷地更新,亦即區塊讀取時間記錄表500所記錄的是每一個區塊最近一次被讀取的時間點。因此,微處理器112便可以在空閒的時候,或是根據計時器119所產生的時間資訊以週期性地,例如每隔30分鐘,根據區塊讀取時間記錄表500的內容來選擇未讀取時間較長的區塊來進行冗餘讀取操作。舉例來說,假設區塊讀取時間記錄表500記錄了區塊B_4及區塊B_5距離上一次讀取的時間點已經超過了20分鐘,則微處理器112可以優先對區塊B_4及區塊B_5進行冗餘讀取操作。 In the second embodiment, the microprocessor 112 can create a block reading time record table to record the blocks that have been read in the flash memory module 120 and the corresponding time information. Referring to the schematic diagram of the block read time record table 500 shown in FIG. 5, assuming that the flash memory module 120 includes a plurality of blocks B1-BN, the microprocessor 112 can 120 when each block is read Time information for the block is recorded (eg, a time stamp obtained by the host device 130 or the timer 119). In one embodiment, the content of the block read time record table 500 is continuously updated, that is, the block read time record table 500 records the last read time point of each block. Therefore, the microprocessor 112 can select the unread data according to the content of the block read time record table 500 periodically, for example, every 30 minutes, when it is idle, or according to the time information generated by the timer 119. Take longer blocks for redundant read operations. For example, assuming that the block read time record table 500 records that blocks B_4 and B_5 are more than 20 minutes away from the last read time point, the microprocessor 112 can prioritize the block B_4 and block B_5 B_5 performs redundant read operations.

在本實施例中,區塊讀取時間記錄表500可以暫存在緩衝記憶體116或是外部的動態隨機存取記憶體中,並在記憶裝置100關機或是需要釋放記憶體空間時將區塊讀取時間記錄表500寫入至快閃記憶體模組120中。 In this embodiment, the block read time record table 500 can be temporarily stored in the buffer memory 116 or an external dynamic random access memory, and when the memory device 100 is shut down or the memory space needs to be released, the block The read time record table 500 is written into the flash memory module 120 .

在第三個實施例中,微處理器112可以建立一區塊讀取時間記錄表以在有區塊被讀取時即時記錄其區塊序號及對應的時間資訊,且該區塊讀取時間記錄表可以進一步被更新/整理以供後續冗餘讀取操作使用。參考第6圖所示之區塊讀取時間記錄表600的示意圖,假設微處理器112從14點01分開始依序讀取了區塊B_123、B_75、B_67、B_123、B_4、B_5、B_67、B_123,則微處理器112會同時地在區塊讀取時間記錄表600中依序紀錄所讀取的區塊及相對應的時間資訊(例如,圖示的時間戳記),其中上述區塊的讀取操作係根據主裝置130的讀取請求所進行的。接著,微處理器112可以根據計時器119所產生的時間資訊以週期性地,例如每隔5分鐘,來整理區塊讀取時間記錄表600以刪除重複的區塊序號。舉例來說,參考第7圖,由於區塊B_123具有三個讀取紀錄,則微處理器112可以直接將前兩筆讀取紀錄刪除;而區塊B_67具有兩個讀取紀錄,則微處理 器112可以直接將前一筆讀取紀錄刪除,以產生一整理後的區塊讀取時間記錄表600。 In the third embodiment, the microprocessor 112 can establish a block reading time record table to record the block serial number and corresponding time information in real time when a block is read, and the block reading time The record table can be further updated/organized for subsequent redundant read operations. Referring to the schematic diagram of the block reading time record table 600 shown in FIG. 6, it is assumed that the microprocessor 112 sequentially reads blocks B_123, B_75, B_67, B_123, B_4, B_5, B_67, B_123, the microprocessor 112 simultaneously records the read blocks and the corresponding time information (for example, the time stamp shown in the figure) in sequence in the block read time record table 600. The read operation is performed according to the read request of the host device 130 . Then, the microprocessor 112 may periodically, for example, every 5 minutes, sort out the block read time record table 600 according to the time information generated by the timer 119 to delete duplicate block numbers. For example, referring to FIG. 7, since block B_123 has three read records, the microprocessor 112 can directly delete the first two read records; and block B_67 has two read records, then the microprocessor 112 can directly delete the first two read records. The controller 112 can directly delete the previous read record to generate a sorted block read time record table 600 .

接著,微處理器112可以根據計時器119所產生的時間資訊以週期性地,例如每隔10分鐘,來根據區塊讀取時間記錄表600來產生一不要作列表(not to do list),以列出讀取時間較短而不需要進行冗餘讀取操作的區塊。舉例來說,假設目前的時間點是14點40分,且微處理器112設定15分鐘以內有讀取過的區塊不需要進行冗餘讀取操作,則此時該不要作列表可以包含了區塊B5、B67、B123。接著,若是微處理器112要進行操作,微處理器112可以根據第4圖所示的區塊記錄表400以及該不要作列表,以對快閃記憶體模組中120有資料儲存的區塊,但不包含該不要作列表可所包含之區塊B5、B67、B123,來進行冗餘讀取操作。 Next, the microprocessor 112 may periodically, for example, every 10 minutes, generate a not to do list according to the block read time record table 600 according to the time information generated by the timer 119 , to list blocks with shorter read times that do not require redundant read operations. For example, assuming that the current time point is 14:40, and the microprocessor 112 sets that blocks that have been read within 15 minutes do not need to perform redundant read operations, then the do not list can include Blocks B5, B67, B123. Next, if the microprocessor 112 needs to operate, the microprocessor 112 can record the blocks in the flash memory module 120 with data storage according to the block record table 400 shown in FIG. 4 and the do not make list. , but does not include the blocks B5, B67, and B123 included in the do-not-do list for redundant read operations.

最後,在冗餘讀取操作結束後,微處理器112直接將進行冗餘讀取操作的區塊自區塊讀取時間記錄表600中移除,以第7圖的實施例來說,區塊讀取時間記錄表600可以直接刪除區塊B_75、B4的記錄,亦即不需要記錄進行冗餘讀取操作的區塊序號及對應的時間資訊。 Finally, after the redundant read operation is completed, the microprocessor 112 directly removes the block for which the redundant read operation is performed from the block read time record table 600 . The block read time record table 600 can directly delete the records of blocks B_75 and B4, that is, it is not necessary to record the block serial numbers and corresponding time information for redundant read operations.

需注意的是,上述冗餘讀取操作的時間點以及微處理器112如何選擇需要進行冗餘讀取操作的區塊的三個實施例僅是作為範例說明,只要微處理器112可以建立相關的表格以判斷哪些區塊需要進行冗餘讀取操作,其表格內容可以根據工程師的設計而有不同的表現方式,而相關設計上的變化均應隸屬於本發明的範疇。 It should be noted that the above-mentioned time points of the redundant read operation and the three embodiments of how the microprocessor 112 selects the blocks that need to perform the redundant read operation are only for illustrative purposes, as long as the microprocessor 112 can establish the correlation. The table is used to determine which blocks need to perform redundant read operations. The content of the table can be expressed in different ways according to the design of the engineer, and the changes in the relevant design should belong to the scope of the present invention.

第8圖為根據本發明一實施例之一種管理一快閃記憶體模組的方法 的流程圖。參考以上實施例所述的內容,流程如下所述。 FIG. 8 is a method of managing a flash memory module according to an embodiment of the present invention flow chart. With reference to the content described in the above embodiments, the flow is as follows.

步驟800:流程開始。 Step 800: The process starts.

步驟802:使用一計時器以產生一時間資訊。 Step 802: Use a timer to generate time information.

步驟804:根據該計時器所產生的該時間資訊,以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發。 Step 804: Perform a redundant read operation on at least a part of the blocks according to the time information generated by the timer, wherein the redundant read operation is not read by a master device triggered by the command.

簡要歸納本發明,在本發明之快閃記憶體控制器中,透過主動偵測區塊的讀取狀態,並主動地對一段時間內沒有被讀取的區塊進行冗餘讀取操作,可以有效地避免區塊內的資料因為長時間沒有讀取而發生劣化的情形,以增進儲存品質及讀取效率。 Briefly summarizing the present invention, in the flash memory controller of the present invention, by actively detecting the read status of the block, and actively performing redundant read operations on the blocks that have not been read for a period of time, it is possible to It can effectively avoid the deterioration of the data in the block due to the long-term non-reading, so as to improve the storage quality and the reading efficiency.

以上所述僅為本發明之較佳實施例,凡依本發明申請專利範圍所做之均等變化與修飾,皆應屬本發明之涵蓋範圍。 The above descriptions are only preferred embodiments of the present invention, and all equivalent changes and modifications made according to the scope of the patent application of the present invention shall fall within the scope of the present invention.

100:記憶裝置 100: Memory Device

110:快閃記憶體控制器 110: Flash memory controller

112:微處理器 112: Microprocessor

112C:程式碼 112C: Code

112M:唯讀記憶體 112M: read-only memory

114:控制邏輯 114: Control logic

116:緩衝記憶體 116: Buffer memory

118:介面邏輯 118: Interface logic

119:計時器 119: Timer

120:快閃記憶體模組 120: Flash memory module

130:主裝置 130: Main unit

132:編碼器 132: Encoder

134:解碼器 134: decoder

N1~NK:接腳 N1~NK: pin

Claims (6)

一種快閃記憶體控制器,其中該快閃記憶體控制器係用來存取一快閃記憶體模組,該快閃記憶體模組包含了多個快閃記憶體晶片,每一個快閃記憶體晶片包含了多個區塊,每一個區塊包含多個資料頁,且該快閃記憶體控制器包含有:一唯讀記憶體,用來儲存一程式碼;一微處理器,用來執行該程式碼以控制對該快閃記憶體模組之存取;以及一計時器,用以產生一時間資訊;其中該微處理器根據該計時器所產生的該時間資訊,以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發;其中該快閃記憶體控制器包含了一緩衝記憶體,該緩衝記憶體儲存了一區塊記錄表,其中該區塊記錄表只記錄該多個區塊中有儲存資料之區塊的區塊序號;以及該微處理器參考該區塊記錄表以選擇有儲存資料的區塊來作為該至少一部份區塊。 A flash memory controller, wherein the flash memory controller is used to access a flash memory module, the flash memory module includes a plurality of flash memory chips, each flash memory The memory chip includes a plurality of blocks, each block includes a plurality of data pages, and the flash memory controller includes: a read-only memory for storing a program code; a microprocessor for to execute the code to control access to the flash memory module; and a timer to generate time information; wherein the microprocessor generates the time information according to the timer to A redundant read operation is performed on at least a part of the plurality of blocks, wherein the redundant read operation is not triggered by a read command of a master device; wherein the flash memory controller includes a buffer memory the buffer memory stores a block record table, wherein the block record table only records the block serial number of the block in which the data is stored in the plurality of blocks; and the microprocessor refers to the block record table The at least a part of the block is selected as the block with the stored data. 如申請專利範圍第1項所述之快閃記憶體控制器,其中該微處理器根據該計時器所產生的該時間資訊,以週期性地對該至少一部分區塊進行該冗餘讀取操作。 The flash memory controller as described in claim 1, wherein the microprocessor periodically performs the redundant read operation on the at least a part of the blocks according to the time information generated by the timer . 一種管理一快閃記憶體模組的方法,其中該快閃記憶體模組包含了多個快閃記憶體晶片,每一個快閃記憶體晶片包含了多個區塊,每一個區塊包含多個資料頁,且該方法包含有:使用一計時器以產生一時間資訊; 參考一區塊記錄表,其只記錄了該多個區塊中有儲存資料之區塊的區塊序號,以自該多個區塊中選擇出有儲存資料的區塊;以及根據該計時器所產生的該時間資訊,以對所選擇出有儲存資料的區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發。 A method for managing a flash memory module, wherein the flash memory module includes a plurality of flash memory chips, each flash memory chip includes a plurality of blocks, and each block includes a plurality of a data page, and the method includes: using a timer to generate a time information; Referring to a block record table, which only records the block serial numbers of the blocks in which the data is stored in the plurality of blocks, so as to select the blocks in which the data is stored from the plurality of blocks; and according to the timer The generated time information is used to perform a redundant read operation on the selected block storing data, wherein the redundant read operation is not triggered by a read command of a master device. 如申請專利範圍第3項所述之方法,其中根據該計時器所產生的該時間資訊,以對所選擇出有儲存資料的區塊進行該冗餘讀取操作的步驟包含有:根據該計時器所產生的該時間資訊,以週期性地對所選擇出有儲存資料的區塊進行該冗餘讀取操作。 The method of claim 3, wherein the step of performing the redundant read operation on the selected block storing data according to the time information generated by the timer comprises: according to the timing The time information generated by the processor is used to periodically perform the redundant read operation on the selected block with stored data. 一種電子裝置,包含有:一快閃記憶體模組,其中該快閃記憶體模組包含了多個快閃記憶體晶片,每一個快閃記憶體晶片包含了多個區塊,每一個區塊包含多個資料頁;以及一快閃記憶體控制器,用以存取該快閃記憶體模組;其中該快閃記憶體控制器根據一計時器所產生的時間資訊以對該多個區塊中的至少一部分區塊進行一冗餘讀取操作,其中該冗餘讀取操作並非由一主裝置之讀取命令所觸發;其中該快閃記憶體控制器包含了一緩衝記憶體,該緩衝記憶體儲存了一區塊記錄表,其中該區塊記錄表只記錄該多個區塊中有儲存資料之區塊的區塊序號;以及該快閃記憶體控制器參考該區塊記錄表以選擇有儲 存資料的區塊來作為該至少一部份區塊。 An electronic device, comprising: a flash memory module, wherein the flash memory module includes a plurality of flash memory chips, each flash memory chip includes a plurality of blocks, each area The block includes a plurality of data pages; and a flash memory controller for accessing the flash memory module; wherein the flash memory controller according to time information generated by a timer at least a part of the blocks perform a redundant read operation, wherein the redundant read operation is not triggered by a read command of a master device; wherein the flash memory controller includes a buffer memory, The buffer memory stores a block record table, wherein the block record table only records the block serial number of the block in which the data is stored in the plurality of blocks; and the flash memory controller refers to the block record form to select The block storing the data is used as the at least part of the block. 如申請專利範圍第5項所述之電子裝置,其中該快閃記憶體控制器根據該計時器所產生的該時間資訊,以週期性地對該至少一部分區塊進行該冗餘讀取操作。 The electronic device of claim 5, wherein the flash memory controller periodically performs the redundant read operation on the at least a part of the blocks according to the time information generated by the timer.
TW110138992A 2019-01-24 2019-01-24 Method for managing flash memory module and associated flash memory controller and electronic device TWI769100B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
TW110138992A TWI769100B (en) 2019-01-24 2019-01-24 Method for managing flash memory module and associated flash memory controller and electronic device

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
TW110138992A TWI769100B (en) 2019-01-24 2019-01-24 Method for managing flash memory module and associated flash memory controller and electronic device

Publications (2)

Publication Number Publication Date
TW202205087A TW202205087A (en) 2022-02-01
TWI769100B true TWI769100B (en) 2022-06-21

Family

ID=81323468

Family Applications (1)

Application Number Title Priority Date Filing Date
TW110138992A TWI769100B (en) 2019-01-24 2019-01-24 Method for managing flash memory module and associated flash memory controller and electronic device

Country Status (1)

Country Link
TW (1) TWI769100B (en)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI623878B (en) * 2017-07-07 2018-05-11 大心電子(英屬維京群島)股份有限公司 Data reading method and storage controller
TW201828294A (en) * 2017-01-18 2018-08-01 南韓商愛思開海力士有限公司 Semiconductor apparatus, memory module and operation method thereof
CN108932175A (en) * 2017-05-24 2018-12-04 光宝电子(广州)有限公司 The control method of solid state storage device

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TW201828294A (en) * 2017-01-18 2018-08-01 南韓商愛思開海力士有限公司 Semiconductor apparatus, memory module and operation method thereof
CN108932175A (en) * 2017-05-24 2018-12-04 光宝电子(广州)有限公司 The control method of solid state storage device
TWI623878B (en) * 2017-07-07 2018-05-11 大心電子(英屬維京群島)股份有限公司 Data reading method and storage controller

Also Published As

Publication number Publication date
TW202205087A (en) 2022-02-01

Similar Documents

Publication Publication Date Title
TWI696074B (en) Method for managing flash memory module and associated flash memory controller and electronic device
KR100823170B1 (en) Memory system and memory card using bad block as slc mode
TWI545571B (en) Method for accessing flash memory and associated controller and memory device
US11487655B2 (en) Method for managing flash memory module and associated flash memory controller and electronic device based on timing of dummy read operations
TW202203227A (en) Memory device, flash memory controller and associated access method
CN111399751B (en) Flash memory controller, method for managing flash memory module and related electronic device
CN111159069B (en) Flash memory controller, method for managing flash memory module and related electronic device
TWI748542B (en) Electronic device, flash memory controller and method for performing garbage collection operation on flash memory module
TWI759580B (en) Method for managing flash memory module and associated flash memory controller and electronic device
TWI720852B (en) Method for accessing flash memory module and associated flash memory controller and electronic device
TWI769100B (en) Method for managing flash memory module and associated flash memory controller and electronic device
TWI768336B (en) Method for managing flash memory module and associated flash memory controller and electronic device
TWI781886B (en) Method for managing flash memory module and associated flash memory controller and electronic device
TWI852008B (en) Flash memory controller and electronic device
TWI787627B (en) Electronic device, flash memory controller and associated access method
TW202234253A (en) Method for managing flash memory module and associated flash memory controller and electronic device
TW202205290A (en) Memory device, flash memory controller and associated access method
KR20100076692A (en) Nand flash memory device and method of writing data in nand flash memory device