TW202101221A - Data storage device and non-volatile memory control method - Google Patents
Data storage device and non-volatile memory control method Download PDFInfo
- Publication number
- TW202101221A TW202101221A TW108136998A TW108136998A TW202101221A TW 202101221 A TW202101221 A TW 202101221A TW 108136998 A TW108136998 A TW 108136998A TW 108136998 A TW108136998 A TW 108136998A TW 202101221 A TW202101221 A TW 202101221A
- Authority
- TW
- Taiwan
- Prior art keywords
- cyclic redundancy
- redundancy check
- data
- volatile memory
- check code
- Prior art date
Links
- 238000013500 data storage Methods 0.000 title claims abstract description 28
- 238000000034 method Methods 0.000 title claims description 17
- 125000004122 cyclic group Chemical group 0.000 claims abstract description 101
- 238000013507 mapping Methods 0.000 claims abstract description 44
- 238000012937 correction Methods 0.000 claims description 10
- 238000007726 management method Methods 0.000 abstract description 3
- 238000012545 processing Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 2
- 230000007774 longterm Effects 0.000 description 2
- 238000012423 maintenance Methods 0.000 description 2
- 239000007787 solid Substances 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 238000013480 data collection Methods 0.000 description 1
- 238000013523 data management Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000007613 environmental effect Effects 0.000 description 1
- 238000002372 labelling Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 238000013439 planning Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
Images
Landscapes
- Memory System Of A Hierarchy Structure (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
Description
本發明係有關於非揮發式記憶體之控制。The present invention relates to the control of non-volatile memory.
非揮發式記憶體有多種形式─例如,快閃記憶體(flash memory)、磁阻式隨機存取記憶體(Magnetoresistive RAM)、鐵電隨機存取記憶體(Ferroelectric RAM)、電阻式隨機存取記憶體(Resistive RAM)、自旋轉移力矩隨機存取記憶體(Spin Transfer Torque-RAM, STT-RAM)…等,用於長時間資料保存,可做為儲存媒體實現一資料儲存裝置。Non-volatile memory has many forms-for example, flash memory (flash memory), magnetoresistive RAM (Magnetoresistive RAM), ferroelectric random access memory (Ferroelectric RAM), resistive random access Memory (Resistive RAM), Spin Transfer Torque-RAM (STT-RAM)... etc. are used for long-term data storage and can be used as storage media to realize a data storage device.
隨著科技進步,資料儲存裝置的儲存能力越發強大。本技術領域需要足以應付大尺寸儲存的映射資訊管理技術。With the advancement of technology, the storage capacity of data storage devices has become stronger. The technical field needs mapping information management technology that can cope with large-scale storage.
本案所採用的映射資訊格式不須特意規劃無法校正標示位元(UNC bit)。映射資訊格式因而有充裕位元數用於物理位址標示。The mapping information format used in this case does not require special planning and cannot correct the UNC bit. The mapping information format therefore has sufficient bits for physical address marking.
根據本案一種實施方式所實現的一資料儲存裝置包括一非揮發式記憶體以及一控制器。該控制器控制該非揮發式記憶體,且包括一循環冗餘校驗(CRC)引擎。根據一主機下達的一無法校正標示指令(如NVMe的WriteUNC指令),該控制器操作該循環冗餘校驗引擎以一偏移編碼種子對一資料樣板編碼,產生一偏移循環冗餘校驗碼。該控制器將該偏移循環冗餘校驗碼隨該資料樣板程式化至該非揮發式記憶體。該資料樣板必然無法通過循環冗餘校驗。該無法校正標示指令成功運作。A data storage device implemented according to an embodiment of this case includes a non-volatile memory and a controller. The controller controls the non-volatile memory and includes a cyclic redundancy check (CRC) engine. According to an uncorrectable marking command issued by a host (such as NVMe's WriteUNC command), the controller operates the cyclic redundancy check engine to encode a data template with an offset coding seed to generate an offset cyclic redundancy check code. The controller programs the offset cyclic redundancy check code along with the data template into the non-volatile memory. The data template must not pass the cyclic redundancy check. The uncorrectable indication command has successfully operated.
一種實施方式中,該無法校正標示指令指示一邏輯位址。該控制器偏移該邏輯位址,產生一偏移邏輯位址。該控制器操作該循環冗餘校驗引擎以該偏移邏輯位址作為該偏移編碼種子。該資料樣板可為零。In one embodiment, the uncorrectable flag command indicates a logical address. The controller offsets the logical address to generate an offset logical address. The controller operates the cyclic redundancy check engine to use the offset logical address as the offset encoding seed. The data template can be zero.
一種實施方式中,根據該主機對該邏輯位址所發出的一讀取指令,該控制器自該非揮發式記憶體取得該資料樣板以及該偏移循環冗餘校驗碼。該控制器操作該循環冗餘校驗引擎以該邏輯位址作為一編碼種子。該控制器操作該循環冗餘校驗引擎以該編碼種子對該資料樣板產生一循環冗餘校驗碼。該控制器操作該循環冗餘校驗引擎比對得該循環冗餘校驗碼不同於該偏移循環冗餘校驗碼,並不以該資料樣板回應該主機。In one embodiment, according to a read command issued by the host to the logical address, the controller obtains the data template and the offset cyclic redundancy check code from the non-volatile memory. The controller operates the cyclic redundancy check engine to use the logical address as an encoding seed. The controller operates the cyclic redundancy check engine to generate a cyclic redundancy check code for the data template using the coding seed. The controller operates the cyclic redundancy check engine to compare and find that the cyclic redundancy check code is different from the offset cyclic redundancy check code, and does not respond to the host with the data template.
一種實施方式中,該控制器係根據該邏輯位址的一映射資訊自該非揮發式記憶體取得該資料樣板以及該偏移循環冗餘校驗碼。該映射資訊採用的一映射資訊格式不包括任何無法校正標示位元。一種實施方式中,該無法校正標示指令的標示單元小於該映射資訊格式管理的資料單元。In one embodiment, the controller obtains the data template and the offset cyclic redundancy check code from the non-volatile memory according to a mapping information of the logical address. A mapping information format adopted by the mapping information does not include any uncorrectable flag bits. In one embodiment, the marking unit of the uncorrectable marking command is smaller than the data unit managed by the mapping information format.
一種實施方式中,關於根據一邏輯位址取自該非揮發式記憶體的一第一區域、且錯誤檢查與糾正失敗的一錯誤資料,該控制器將該錯誤資料以及一循環冗餘校驗碼程式化至該非揮發式記憶體的一第二區域。該循環冗餘校驗碼係隨該錯誤資料由該控制器自該非揮發式記憶體的該第一區域讀出。一種實施方式中,根據該主機對該邏輯位址要求的一讀取指令,該控制器自該非揮發式記憶體的該第二區域取得該錯誤資料以及該循環冗餘校驗碼。該控制器操作該循環冗餘校驗引擎以該邏輯位址作為一編碼種子。該控制器操作該循環冗餘校驗引擎以該編碼種子對該錯誤資料產生一錯誤循環冗餘校驗碼。該控制器操作該循環冗餘校驗引擎比對得該錯誤循環冗餘校驗碼不同於該循環冗餘校驗碼,並不以該錯誤資料回應該主機。In one embodiment, regarding an error data obtained from a first area of the non-volatile memory according to a logical address and error checking and correction failed, the controller sends the error data and a cyclic redundancy check code It is programmed to a second area of the non-volatile memory. The cyclic redundancy check code is read by the controller from the first area of the non-volatile memory along with the error data. In one embodiment, according to a read command requested by the host for the logical address, the controller obtains the error data and the cyclic redundancy check code from the second area of the non-volatile memory. The controller operates the cyclic redundancy check engine to use the logical address as an encoding seed. The controller operates the cyclic redundancy check engine to generate an error cyclic redundancy check code for the error data with the encoding seed. The controller operates the cyclic redundancy check engine to compare and find that the error cyclic redundancy check code is different from the cyclic redundancy check code, and does not respond to the host with the error data.
一種實施方式中,上述錯誤檢查與糾正源於該主機對該非揮發式記憶體的一讀取指令。In one embodiment, the above-mentioned error checking and correction originate from a read command from the host to the non-volatile memory.
一種實施方式中,上述錯誤檢查與糾正源於該控制器對該非揮發式記憶體進行的一垃圾回收。In one embodiment, the above-mentioned error checking and correction result from a garbage collection performed by the controller on the non-volatile memory.
以上記憶體控制器對非揮發式記憶體之操作也可以由其他結構實現。本案更可以前述概念實現非揮發式記憶體的控制方法,包括以下步驟:提供一循環冗餘校驗引擎;根據一主機下達的一無法校正標示指令,操作該循環冗餘校驗引擎以一偏移編碼種子對一資料樣板編碼,產生一偏移循環冗餘校驗碼;且將該偏移循環冗餘校驗碼隨該資料樣板程式化至一非揮發式記憶體。The operation of the above memory controller on the non-volatile memory can also be implemented by other structures. In this case, the aforementioned concept can be used to implement a non-volatile memory control method, including the following steps: providing a cyclic redundancy check engine; operating the cyclic redundancy check engine according to an uncorrectable indication command issued by a host The shift encoding seed encodes a data template to generate an offset cyclic redundancy check code; and the offset cyclic redundancy check code is programmed into a non-volatile memory along with the data template.
下文特舉實施例,並配合所附圖示,詳細說明本發明內容。Hereinafter, specific embodiments are given in conjunction with accompanying drawings to illustrate the content of the present invention in detail.
以下敘述列舉本發明的多種實施例。以下敘述介紹本發明的基本概念,且並非意圖限制本發明內容。實際發明範圍應依照申請專利範圍界定之。The following description lists various embodiments of the present invention. The following description introduces the basic concept of the present invention, and is not intended to limit the content of the present invention. The actual scope of invention shall be defined in accordance with the scope of patent application.
非揮發式記憶體可以是快閃記憶體(Flash Memory)、磁阻式隨機存取記憶體(Magnetoresistive RAM)、鐵電隨機存取記憶體(Ferroelectric RAM)、電阻式記憶體(Resistive RAM,RRAM)、自旋轉移力矩隨機存取記憶體(Spin Transfer Torque-RAM, STT-RAM)…等,提供長時間資料保存之儲存媒體。以下特別以快閃記憶體為例進行討論。Non-volatile memory can be flash memory (Flash Memory), magnetoresistive RAM (Magnetoresistive RAM), ferroelectric random access memory (Ferroelectric RAM), resistive RAM (RRAM) ), Spin Transfer Torque-RAM (STT-RAM), etc., provide storage media for long-term data storage. The following discussion takes the flash memory as an example.
現今資料儲存裝置常以快閃記憶體為儲存媒體,實現記憶卡(Memory Card)、通用序列匯流排閃存裝置(USB Flash Device)、固態硬碟(SSD) …等產品。有一種應用是採多晶片封裝、將快閃記憶體與其控制器包裝在一起─稱為嵌入式快閃記憶體模組(如eMMC)。Nowadays, data storage devices often use flash memory as storage media to realize products such as Memory Card, Universal Serial Bus Flash Device (USB Flash Device), Solid State Drive (SSD)...etc. One application is to use multi-chip packaging to package flash memory and its controller together-called embedded flash memory modules (such as eMMC).
以快閃記憶體為儲存媒體的資料儲存裝置可應用於多種電子裝置中。所述電子裝置包括智慧型手機、穿戴裝置、平板電腦、虛擬實境設備…等。電子裝置的運算模塊可視為主機(Host),操作所使用的資料儲存裝置,以存取其中快閃記憶體。The data storage device using flash memory as the storage medium can be applied to a variety of electronic devices. The electronic devices include smart phones, wearable devices, tablet computers, virtual reality equipment, etc. The computing module of the electronic device can be regarded as a host, which operates the data storage device used to access the flash memory therein.
以快閃記憶體為儲存媒體的資料儲存裝置也可用於建構資料中心。例如,伺服器可操作固態硬碟(SSD)陣列形成資料中心。伺服器即可視為主機,操作所連結之固態硬碟,以存取其中快閃記憶體。Data storage devices using flash memory as storage media can also be used to construct data centers. For example, the server can operate a solid state drive (SSD) array to form a data center. The server can be regarded as the host, operating the connected solid-state drive to access the flash memory.
快閃記憶體有其特殊的儲存特性,以下敘述之。Flash memory has its special storage characteristics, which are described below.
主機(Host)端是以邏輯位址(例如,邏輯區塊位址LBA或全域主機頁編號GHP…等)來區別資料。至於資料實際儲存在快閃記憶體何處,則是以映射資訊管理。The host (Host) uses logical addresses (for example, logical block address LBA or global host page number GHP... etc.) to distinguish data. As for where the data is actually stored in flash memory, it is managed by mapping information.
快閃記憶體之物理空間是劃分為複數個區塊(Blocks)配置使用。第1圖圖解快閃記憶體一區塊Blk之結構。區塊Blk包括複數頁面(Pages),例如,頁面0…頁面255。一種實施方式係根據頁面編號─由低編號至高編號─循序使用一區塊的儲存空間。各頁面包括複數個區段(Sectors),例如32個區段,每一區段可儲存512B長度的使用者資料。一次寫入可能涉及多個區段。例如,在4KB資料管理模式下,可將8個區段視為一個資料單元(Unit),進行管理。一次寫入可能涵蓋8個區段(4KB)長度。16KB長度的頁面可由四個資料單元(32個區段)所組成;四個資料單元的邏輯關係可能不連續。The physical space of the flash memory is divided into a plurality of blocks (Blocks) for allocation. Figure 1 illustrates the structure of a block Blk of the flash memory. The block Blk includes a plurality of pages (Pages), for example,
特別是,同樣邏輯位址的資料更新並非覆寫至舊資料的儲存空間,新版本的資料須寫入空白的區段。舊空間的內容無效。一區塊可能僅零星留存有效資料。由於快閃記憶體的儲存空間需抹除(erase)後方能再次使用,備用區塊逐漸消耗。備用區塊數量不足時(如,低於閥值),垃圾回收(Garbage Collection)需求產生。一區塊留存的零星有效資料經垃圾回收集中到其他空間。徒留無效資料的區塊則抹除釋出,拉升備用區塊數量,確保快閃記憶體之正常使用。垃圾回收也可能使得同區塊內容的邏輯關係更零散。In particular, the data update of the same logical address is not overwritten to the storage space of the old data, and the data of the new version must be written into a blank section. The content of the old space is invalid. A block may only retain valid data sporadically. Since the storage space of the flash memory needs to be erased before it can be used again, the spare blocks are gradually consumed. When the number of spare blocks is insufficient (for example, below the threshold), a garbage collection (Garbage Collection) demand is generated. The scattered valid data stored in one block is collected in other spaces through garbage collection. Blocks with invalid data are erased and released, increasing the number of spare blocks to ensure the normal use of flash memory. Garbage collection may also make the logical relationship with the block content more fragmented.
由前述內容可知,快閃記憶體的空間配置相當複雜。一種實施方式是建立邏輯-物理位址映射表(Logical-to-Physical Addresses Mapping Table,L2P映射表),記錄邏輯位址與物理位址之間的映射資訊,較佳以邏輯位址為索引,物理位址為內容,其中,物理位址例如是物理區塊位址(Physical Block Address,PBA)。一種實施方式是以區塊資訊Blk#、頁面資訊Page#以及資料單元資訊Unit#(或偏移量offset)標示物理位置。或者,多通道(multi channel)技術更包括通道編號CH#如此物理空間標示。It can be seen from the foregoing that the spatial configuration of the flash memory is quite complicated. One implementation is to create a logical-to-physical address mapping table (Logical-to-Physical Addresses Mapping Table, L2P mapping table) to record the mapping information between the logical address and the physical address, preferably using the logical address as an index. The physical address is content, where the physical address is, for example, a physical block address (Physical Block Address, PBA). One implementation is to indicate the physical location of block information Blk#, page information Page#, and data unit information Unit# (or offset). Alternatively, the multi-channel (multi-channel) technology further includes a physical space mark such as the channel number CH#.
第2A圖圖解傳統技術所使用的一種映射資訊格式200,包括32位元(四位元組)來記錄物理位址。各位元規劃如下:
l 位元[31]:無法校正(Uncorrectable,UNC)標示位元,用以標示映射資訊所指內容不可靠,或是技術上而言,UNC表示資料已無法透過錯誤檢查與糾正(ECC)而予以修正,當ECC失敗,UNC標示位元例如會從”0”切換成”1”。造成ECC失敗的可能原因包括環境因素或時間因素所造成的物理錯誤,讀取資料的過程中所產生的錯誤,也可能是資料程式化的過程中所造成的錯誤。
l 位元[30:29]:映射資訊模式(Pattern Mode)位元。一種實施方式中,主機要求寫入快閃記憶體的資料是先快取在一暫存記憶體。待一程式化條件滿足(如,快取達一定量、或定時封存),資料才從暫存記憶體移至快閃記憶體。因此,邏輯位址也有可能是映射到暫存記憶體。映射資訊模式(Pattern Mode)顯示映射資訊是指向暫存記憶體、或是快閃記憶體。00/01代表後續位元[28:0]標示快閃記憶體的物理位址,10代表後續位元[28:0]標示暫存記憶體的物理位址,11代表後續位元[28:0]為無意義的虛置(Dummy)數據。
l 位元[28:0]:快閃記憶體或暫存記憶體的物理位址,或虛置數據。FIG. 2A illustrates a
映射資訊格式200設有映射資訊模式位元[30:29],再扣掉UNC標示位元[31],僅有29位元可用於標示物理位址,這將限制資料儲存裝置所能提供的儲存容量。The
為了避免上述問題,第2B圖圖解本案一種實施方式所使用的一種映射資訊格式210,包括32位元(四位元組),映射資訊格式210不再包含UNC標示位元,如此一來,映射資訊格式210有更多的位元數量可用以表示物理位址,使資料儲存裝置所能提供的儲存容量較之前的儲存容量可以增加1倍,達到本發明的目的。另外,映射資訊格式210也不再包含映射資訊模式位元。以下詳細描述如何不使用UNC標示位元實現無法校正(UNC)。In order to avoid the above problem, Figure 2B illustrates a
第3圖為方塊圖,根據本案一種實施方式圖解資料儲存裝置300,包括快閃記憶體302、控制器304以及暫存記憶體306。主機308透過控制器304操作快閃記憶體302。資料儲存裝置300內部也可經控制器304發動快閃記憶體302之最佳化操作;例如,整理快閃記憶體302空間,使其發揮最大儲存效能。控制器304進行運算時是以暫存記憶體306暫存資料。暫存記憶體306可為動態隨機存取記憶體(DRAM)或SRAM。FIG. 3 is a block diagram illustrating a data storage device 300 according to an embodiment of the present invention, which includes a
快閃記憶體302包括複數個區塊。儲存系統資訊的區塊稱系統區塊池310。例如,儲存映射資訊的系統區塊是用於映射資訊的非揮發式儲存。取自備用區塊池312的主動區塊A0用於程式化主機308要求的寫入資料。主動區塊A0程式化完成後即屬資料區塊,推入資料區塊池314。運行一段時間後,某些資料區塊可能因為資料頻繁更新,僅留零星的有效資料。該些資料區塊將藉垃圾回收(Garbage Collection)釋出,重新歸類至備用區塊池312。取自備用區塊池312的目的區塊A1即用於垃圾回收的有效資料收集。目的區塊A1填滿資料後,也被推入該資料區塊池314。The
如圖所示,控制器304是先將資料快取於該暫存記憶體306的資料快取空間316,再自資料快取空間316程式化至該主動區塊A0。控制器304可利用暫存記憶體306的空間318動態維護映射資訊。控制器304包括循環冗餘校驗(CRC)引擎320。主機308發下的無法校正標示指令(稱UNC標示指令,例如:Write UNC指令)包括一個目標邏輯位址LBA。控制器304執行主機308所發下的UNC標示指令時,先對目標邏輯位址LBA以產生偏移邏輯位址LBA_UNC,再命令CRC引擎320將該偏移邏輯位址LBA_UNC作為編碼種子,再對資料樣板(Pattern)P進行編碼,最後產生偏移循環冗餘校驗碼CRC_UNC。之後,控制器304將該資料樣板P以及該偏移循環冗餘校驗碼CRC_UNC程式化至主動區塊A0的閒置資料單元330,例如,將資料樣板P填入閒置資料單元330的資料區332,偏移循環冗餘校驗碼CRC_UNC則填入閒置資料單元330的元資料(Metadata)區334,完成UNC標示,也完成UNC標示指令的執行。之後,再更新目標邏輯位址LBA的映射資訊。一種實施方式中,資料樣版P為“0”或是目標邏輯位址LBA所對應的物理位址中所儲存的原始資料。As shown in the figure, the
之後,如果主機308欲讀取目標邏輯位址LBA的資料時,CRC引擎320是根據目標邏輯位址LBA作為編碼種子S,並以該編碼種子S對取自資料區332的資料樣板P計算出CRC。此時,CRC顯然不同於元資料區334所儲存的偏移循環冗餘校驗碼CRC_UNC,因此,控制器304回應預設訊息給主機308,預設訊息例如是目標邏輯位址LBA尚未記錄,或目標邏輯位址LBA已被清除等。如此一來,在本發明中UNC標示指令不但被執行,且執行的結果符合UNC的精神,讓目標邏輯位址LBA的資料無效化或不被採用。Later, if the
一種實施方式中,主機308以讀取指令要求讀取目標邏輯位址LBA。控制器304自資料區塊338的資料單元340取得的是錯誤資料D_ERR(資料區342)以及循環冗餘校驗碼CRC(元資料區344)。控制器304對錯誤資料D_ERR進行ECC處理,結果為ECC失敗。因應之,控制器304將錯誤資料D_ERR以及循環冗餘校驗碼CRC再次程式化至主動區塊A0(例如,資料單元330的資料區332以及元資料區334),完成UNC標示。之後,主機308欲讀取目標邏輯位址LBA的資料時,控制器304操作CRC引擎320,根據目標邏輯位址LBA對取自資料區332的錯誤資料D_ERR進行計算並得到錯誤循環冗餘校驗碼CRC_ERR,這顯然不同於元資料區334儲存的循環冗餘校驗碼CRC,所以控制器304回應預設訊息給主機308。UNC標示使目標邏輯位址LBA的資料無效化或不被採用,符合被標示為UNC的精神。In one embodiment, the
垃圾回收(Garbage Collection)程序執行時也可能發生ECC失敗的情況。一種實施方式中,控制器304以資料區塊338為垃圾回收程序的來源區塊(Source Block),自資料單元340取得錯誤資料D_ERR(資料區342)以及循環冗餘校驗碼CRC(元資料區344),以複製到目的區塊A1。複製前,控制器304對錯誤資料D_ERR進行ECC處理,結果為ECC失敗。控制器304將錯誤資料D_ERR以及循環冗餘校驗碼CRC程式化至目的區塊A1上(例如,資料空間350的資料區352以及元資料區354),完成UNC標示。之後,主機308欲讀取目標邏輯位址LBA的資料時,控制器304操作該CRC引擎320,根據目標邏輯位址LBA對取自資料區352的錯誤資料D_ERR計算出錯誤循環冗餘校驗碼CRC_ERR,這顯然不同於元資料區334儲存的循環冗餘校驗碼CRC,則控制器304回應預設訊息給主機308。UNC標示使目標邏輯位址LBA的資料無效化或不被採用,符合被標示為UNC的精神。ECC failure may also occur during the execution of garbage collection (Garbage Collection) programs. In one embodiment, the
一種實施方式中,CRC引擎320是以區段長度(512B)為單位進行CRC編碼。每區段對應2B長度的CRC數值。一筆資料單元長度(4KB)的資料可產生8筆的循環冗餘校驗碼CRC。更短長度(小於4KB)的資料也可有相應的CRC數值。例如,僅512B的資料可對應1筆循環冗餘校驗碼CRC(2B)。因此,採用循環冗餘校驗碼CRC或偏移循環冗餘校驗碼CRC_UNC來實行UNC標示的方法,可適用於區段長度(512B)、資料單元長度(4KB)或是其他長度的資料。本案技術使得無法校正標示指令的標示單元小於映射資訊格式210管理的資料單元。In one embodiment, the
第4圖對應UNC標示指令(Write UNC)圖解快閃記憶體302中一個頁面的一個資料單元400,資料單元400包括8個區為4KB(8*512B),分別對應至邏輯位址LBA#0~#7。該UNC標示指令包括:起始邏輯位址LBA#4,邏輯位址長度等於4,因此,控制器304需對邏輯位址LBA#0~#7中的邏輯位址LBA#4~#7進行UNC標示。如圖所示,控制器304將目標邏輯位址LBA#0~#3的資料D以及循環冗餘校驗碼CRC程式化至資料單元400的前四個區段。至於要做UNC標示的邏輯位置LBA#4~#7,控制器304操作該CRC引擎320以偏移的邏輯位址LBA#5~#8對邏輯位置LBA#4~#7的資料D進行編碼,獲得偏移的循環冗餘校驗碼CRC_UNC#4~#7。控制器304將邏輯位置LBA#4~#7的資料D以及偏移的循環冗餘校驗碼CRC_UNC#4~#7程式化至資料單元400的後四個區段,完成UNC標示指令的執行。Figure 4 corresponds to the UNC marking command (Write UNC) to illustrate a
第5圖為流程圖,根據本案一種實施方式圖解UNC標示指令(Write UNC)的處理流程。Figure 5 is a flowchart illustrating the processing flow of the UNC marking command (Write UNC) according to an embodiment of this case.
步驟S502,控制器304接收來自主機308的UNC標示指令(Write UNC),其中,UNC標示指令包括目標邏輯位址。In step S502, the
步驟S504,控制器304產生偏移邏輯位址LBA_UNC,其中,偏移邏輯位址LBA_UNC可依據目標邏輯位址而產生,或是隨機產生。In step S504, the
步驟S506,控制器304操作CRC引擎320以偏移邏輯位址LBA_UNC對資料樣版P進行編碼,獲得偏移循環冗餘校驗碼CRC_UNC,其中,資料樣版P為“0”或是目標邏輯位址LBA所對應的物理位址中所儲存的原始資料。In step S506, the
步驟S508,控制器304將資料樣版P以及偏移循環冗餘校驗碼CRC_UNC程式化至主動區塊A0的閒置資料單元330。In step S508, the
第6圖為流程圖,根據本案一種實施方式圖解控制器304如何處理主機308的讀取要求。Figure 6 is a flowchart illustrating how the
步驟S602,控制器304接收來自主機308的讀取指令,其中,讀取指令包括目標邏輯位址LBA。In step S602, the
步驟S604,控制器304根據目標邏輯位址LBA以及L2P映射表取得目標邏輯位址LBA所對應的物理位址,其中,物理位址為PBA。In step S604, the
步驟S606,控制器304自物理位址取得資料D_read以及循環冗餘校驗碼CRC_read。Step S606, the
步驟S608,控制器304操作CRC引擎320以該循環冗餘校驗碼CRC_read對資料D_read進行編碼以取得循環冗餘校驗碼CRC_ref。In step S608, the
步驟S610,控制器304比對該循環冗餘校驗碼CRC_read以及循環冗餘校驗碼CRC_ref,如果比對結果為不相同則執行步驟S612,控制器304輸出預設訊息至主機308。另外,控制器304不回傳資料D_read至主機308。如果比對結果為相同則執行步驟S614,控制器304回傳資料D_read給主機308,完成讀取指令的執行。In step S610, the
以上記憶體控制器304對快閃記憶體302之操作設計也可以由其他結構實現。凡是根據前述概念操作快閃記憶體、使映射資料省略UNC標示專屬位元的技術,都屬於本案欲保護範圍。本案更可以前述概念實現非揮發式記憶體的控制方法。The above operation design of the
雖然本發明已以較佳實施例揭露如上,然其並非用以限定本發明,任何熟悉此項技藝者,在不脫離本發明之精神和範圍內,當可做些許更動與潤飾,因此本發明之保護範圍當視後附之申請專利範圍所界定者為準。Although the present invention has been disclosed as above in the preferred embodiment, it is not intended to limit the present invention. Anyone familiar with the art can make some changes and modifications without departing from the spirit and scope of the present invention. Therefore, the present invention The scope of protection shall be subject to the scope of the attached patent application.
200、210:映射資訊格式
300:資料儲存裝置
302:快閃記憶體
304:控制器
306:暫存記憶體
308:主機
310:系統區塊池
312:備用區塊池
314:資料區塊池
316:資料快取空間
318:空間,動態維護映射資訊
320:循環冗餘校驗引擎
330、332、334:資料單元以及其中資料區與元資料區
338:資料區塊
340、342、344:資料單元以及其中資料區與元資料區
350、352、354:資料單元以及其中資料區與元資料區
400:資料單元
A0:主動區塊
A1:目的區塊
LBA:邏輯位址
S502…S508、S602…S614:步驟200, 210: mapping information format
300: Data storage device
302: flash memory
304: Controller
306: Temporary memory
308: host
310: System block pool
312: Spare Block Pool
314: Data Block Pool
316: data cache space
318: Space, dynamic maintenance of mapping information
320: Cyclic
第1圖圖解快閃記憶體一區塊Blk之結構;
第2A圖圖解傳統技術所使用的一種映射資訊格式200;
第2B圖圖解本案一種實施方式所使用的一種映射資訊格式210;
第3圖為方塊圖,根據本案一種實施方式圖解一資料儲存裝置300;
第4圖對應一UNC標示指令(WriteUNC)圖解快閃記憶體302一區塊上的一資料單元400;
第5圖為流程圖,根據本案一種實施方式圖解UNC標示指令(WriteUNC)的處理流程;且
第6圖為流程圖,根據本案一種實施方式圖解控制器304如何處理主機308的讀取要求。Figure 1 illustrates the structure of a block Blk of the flash memory;
Figure 2A illustrates a
300:資料儲存裝置 300: Data storage device
302:快閃記憶體 302: flash memory
304:控制器 304: Controller
306:暫存記憶體 306: Temporary memory
308:主機 308: host
310:系統區塊池 310: System block pool
312:備用區塊池 312: Spare Block Pool
314:資料區塊池 314: Data Block Pool
316:資料快取空間 316: data cache space
318:空間,動態維護映射資訊 318: Space, dynamic maintenance of mapping information
320:循環冗餘校驗引擎 320: Cyclic Redundancy Check Engine
330、332、334:資料單元以及其中資料區與元資料區 330, 332, 334: data unit and its data area and metadata area
338:資料區塊 338: Data Block
340、342、344:資料單元以及其中資料區與元資料區 340, 342, 344: data unit and its data area and metadata area
350、352、354:資料單元以及其中資料區與元資料區 350, 352, 354: data unit and its data area and metadata area
A0:主動區塊 A0: Active block
A1:目的區塊 A1: Destination block
Claims (20)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911235103.5A CN112099985B (en) | 2019-06-17 | 2019-12-05 | Data storage device and non-volatile memory control method |
US16/774,300 US11314586B2 (en) | 2019-06-17 | 2020-01-28 | Data storage device and non-volatile memory control method |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201962862196P | 2019-06-17 | 2019-06-17 | |
US62/862,196 | 2019-06-17 |
Publications (2)
Publication Number | Publication Date |
---|---|
TW202101221A true TW202101221A (en) | 2021-01-01 |
TWI723581B TWI723581B (en) | 2021-04-01 |
Family
ID=75234646
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW108136997A TWI766194B (en) | 2019-06-17 | 2019-10-15 | Data storage device and non-volatile memory control method |
TW108136998A TWI723581B (en) | 2019-06-17 | 2019-10-15 | Data storage device and non-volatile memory control method |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW108136997A TWI766194B (en) | 2019-06-17 | 2019-10-15 | Data storage device and non-volatile memory control method |
Country Status (1)
Country | Link |
---|---|
TW (2) | TWI766194B (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI805449B (en) * | 2021-11-21 | 2023-06-11 | 慧榮科技股份有限公司 | Method for performing access control of memory device with aid of multi-stage garbage collection management, memory controller of memory device, and memory device |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8443263B2 (en) * | 2009-12-30 | 2013-05-14 | Sandisk Technologies Inc. | Method and controller for performing a copy-back operation |
DE112013000601T5 (en) * | 2012-01-17 | 2014-12-18 | Intel Corporation | Command confirmation techniques for accessing a storage device by a remote client |
US9329948B2 (en) * | 2012-09-15 | 2016-05-03 | Seagate Technology Llc | Measuring cell damage for wear leveling in a non-volatile memory |
US10642743B2 (en) * | 2017-06-28 | 2020-05-05 | Arm Limited | Apparatus and method of handling caching of persistent data |
TWI680374B (en) * | 2017-10-20 | 2019-12-21 | 慧榮科技股份有限公司 | Storage device and interface chip thereof |
TWI658363B (en) * | 2017-10-20 | 2019-05-01 | 慧榮科技股份有限公司 | Storage device and interface chip thereof |
TWI646543B (en) * | 2017-11-03 | 2019-01-01 | 大陸商深圳大心電子科技有限公司 | Data encoding method, data decoding method and storage controller |
-
2019
- 2019-10-15 TW TW108136997A patent/TWI766194B/en active
- 2019-10-15 TW TW108136998A patent/TWI723581B/en active
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI805449B (en) * | 2021-11-21 | 2023-06-11 | 慧榮科技股份有限公司 | Method for performing access control of memory device with aid of multi-stage garbage collection management, memory controller of memory device, and memory device |
US11809314B2 (en) | 2021-11-21 | 2023-11-07 | Silicon Motion, Inc. | Method and apparatus for performing access control of memory device with aid of multi-stage garbage collection management |
Also Published As
Publication number | Publication date |
---|---|
TWI723581B (en) | 2021-04-01 |
TW202101220A (en) | 2021-01-01 |
TWI766194B (en) | 2022-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11461233B2 (en) | Handling asynchronous power loss in a memory sub-system that programs sequentially | |
TWI661307B (en) | Data storage device, host system connected with data storage device, and method for writing data storage device | |
CN112099985B (en) | Data storage device and non-volatile memory control method | |
US8296498B2 (en) | Method and system for virtual fast access non-volatile RAM | |
US8904261B2 (en) | Data management in solid state storage devices | |
JP6018696B2 (en) | Semiconductor storage | |
US11681472B2 (en) | Unmap data pattern for coarse mapping memory sub-system | |
CN108733510A (en) | Data storage device and mapping table reconstruction method | |
US20200089566A1 (en) | Apparatus for diagnosing memory system and operating method thereof | |
TWI718709B (en) | Data storage device and non-volatile memory control method | |
CN112130750B (en) | Data storage device and non-volatile memory control method | |
US10446252B2 (en) | Data storage device and method for data error management | |
CN110908930B (en) | Memory controller, operation method thereof, and storage device | |
CN113590503B (en) | Garbage recycling method and garbage recycling system for non-volatile memory | |
TW202032375A (en) | Data storage device and control method for non-volatile memory | |
CN112100087B (en) | Data storage device and non-volatile memory control method | |
US11782788B2 (en) | Error-correction-detection coding for hybrid memory module | |
JP2012058770A (en) | Memory controller, flash memory system equipped with memory controller and control method of flash memory | |
TWI723581B (en) | Data storage device and non-volatile memory control method | |
JP2012068765A (en) | Memory controller, flash memory system with memory controller, and control method of flash memory | |
JP2012037971A (en) | Memory controller, nonvolatile memory system provided with memory controller, and method for controlling nonvolatile memory |