TW201527974A - 資料儲存裝置以及快閃記憶體控制方法 - Google Patents
資料儲存裝置以及快閃記憶體控制方法 Download PDFInfo
- Publication number
- TW201527974A TW201527974A TW103144257A TW103144257A TW201527974A TW 201527974 A TW201527974 A TW 201527974A TW 103144257 A TW103144257 A TW 103144257A TW 103144257 A TW103144257 A TW 103144257A TW 201527974 A TW201527974 A TW 201527974A
- Authority
- TW
- Taiwan
- Prior art keywords
- flash memory
- link table
- logical
- physical address
- address mapping
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1446—Point-in-time backing up or restoration of persistent data
- G06F11/1458—Management of the backup or restore process
- G06F11/1469—Backup restoration techniques
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1008—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
- G06F11/1072—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices in multilevel memories
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1405—Saving, restoring, recovering or retrying at machine instruction level
- G06F11/141—Saving, restoring, recovering or retrying at machine instruction level for bus or memory accesses
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1415—Saving, restoring, recovering or retrying at system level
- G06F11/1435—Saving, restoring, recovering or retrying at system level using file system or storage system metadata
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0604—Improving or facilitating administration, e.g. storage management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0629—Configuration or reconfiguration of storage systems
- G06F3/0631—Configuration or reconfiguration of storage systems by allocating resources to storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/0652—Erasing, e.g. deleting, data cleaning, moving of data to a wastebasket
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C11/00—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C11/56—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/52—Protection of memory contents; Detection of errors in memory contents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1032—Reliability improvement, data loss prevention, degraded operation etc
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/60—Details of cache memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7201—Logical to physical mapping or translation of blocks or pages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7202—Allocation control and policies
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7203—Temporary buffering, e.g. using volatile buffer or dedicated buffer blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7209—Validity control, e.g. using flags, time stamps or sequence numbers
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/04—Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
- G11C2029/0411—Online error correction
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C2211/00—Indexing scheme relating to digital stores characterized by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C2211/56—Indexing scheme relating to G11C11/56 and sub-groups for features not covered by these groups
- G11C2211/564—Miscellaneous aspects
- G11C2211/5641—Multilevel memory having cells with different number of storage levels
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Human Computer Interaction (AREA)
- Library & Information Science (AREA)
- Computer Hardware Design (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
- Memory System (AREA)
- Read Only Memory (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
高抹除效率的資料儲存裝置以及快閃記憶體控制方法。一微控制器係設置來在一快閃記憶體上維護紀載一主機以及該快閃記憶體之間映射資訊的複數個邏輯-物理位址映射表以及一鏈結表。鏈結表標示該等邏輯-物理位址映射表的位置,且鏈結表各欄位係對應該等邏輯-物理位址映射表其一。抹除邏輯位址對應N個邏輯-物理位址映射表的使用者資料時,微控制器係設置來令該鏈結表中對應上述N個邏輯-物理位址映射表的N個欄位無效。N為整數。
Description
本發明係有關於快閃記憶體(flash memory)實現之資料儲存裝置以及快閃記憶體控制方法。
現今資料儲存裝置常以快閃記憶體(flash memory)為儲存媒體。例如,快閃記憶體常用作記憶卡(memory card)、通用序列匯流排閃存裝置(USB flash device)、固態硬碟(SSD)...等產品。另外有一種應用是採多晶片封裝、將一非及閘型快閃記憶體與其控制晶片包裝在同一封裝中-稱為嵌入式快閃記憶體模組(如eMMC)。
快閃記憶體的實體空間通常包括複數個區塊(blocks)。各區塊包括複數個物理頁(pages)。針對快閃記憶體而設計的抹除操作須以區塊為抹除單位,一次釋放一區塊的儲存空間。資料更新時,新資料係寫入閒置空間,而非覆寫在舊資料上。物理-邏輯位址映射資訊需紀載於一快閃記憶體中,以管理該快閃記憶體。快閃記憶體的管理遠較其他傳統儲存媒體複雜,特別是大尺寸快閃記憶體更不易管理。大尺寸快閃記憶體之映射資訊管理須妥善設計。
採用快閃記憶體的資料儲存裝置以及快閃記憶體
控制方法,其中包括高效率抹除技術。
根據本案一種實施方式所實現的資料儲存裝置包括一快閃記憶體以及一控制單元。該快閃記憶體係劃分為複數個區塊。各區塊包括複數個物理頁。該控制單元耦接該快閃記憶體至一主機,且具有一微控制器。該微控制器係設置來在該快閃記憶體上維護紀載有該主機以及該快閃記憶體之間映射資訊的複數個邏輯-物理位址映射表以及一鏈結表。該鏈結表標示該等邏輯-物理位址映射表的位置。該鏈結表各欄位對應一個邏輯-物理位址映射表。抹除邏輯位址對應N個邏輯-物理位址映射表的使用者資料時,該微控制器係設置來令該鏈結表中對應上述N個邏輯-物理位址映射表的N個欄位無效。N為整數。
根據本案一種實施方式所實現的快閃記憶體控制方法包括:在一快閃記憶體上維護紀載有一主機以及該快閃記憶體之間映射資訊的複數個邏輯-物理位址映射表以及一鏈結表,其中該快閃記憶體所供應的儲存空間係劃分為複數個區塊,各區塊包括複數個物理頁,該鏈結表標示該等邏輯-物理位址映射表的位置,該鏈結表各欄位對應該等邏輯-物理位址映射表格其一;以及,在抹除邏輯位址對應N個邏輯-物理位址映射表的使用者資料時,令該鏈結表中對應上述N個邏輯-物理位址映射表的N個欄位無效,其中,N為整數。
下文特舉實施例,並配合所附圖示,詳細說明本發明內容。
100‧‧‧快閃記憶體
102‧‧‧物理頁
104、106、108以及110‧‧‧區段
300‧‧‧資料儲存裝置
302‧‧‧主機
304‧‧‧快閃記憶體
306‧‧‧控制單元
308‧‧‧系統內程式區塊
310‧‧‧系統資訊區塊
312‧‧‧資料集合
320‧‧‧微控制器
322‧‧‧隨機存取記憶體
324‧‧‧唯讀記憶體
330‧‧‧系統區塊
332‧‧‧鏈結表H2FLink的N個欄位
334‧‧‧供鏈結表指標*H2FLink下載儲存的空間
336‧‧‧供鏈結表H2FLink下載儲存的空間
338‧‧‧N個欄位332於隨機存取記憶體322上的內容
340‧‧‧閒置空間
342‧‧‧更新過的鏈結表指標
(B_N,P_N)‧‧‧(區塊編號,物理頁編號)
BLK4、BLK2…BLKN‧‧‧區塊
H2F‧‧‧邏輯-物理位址映射表
H2F1…H2Fi…H2Fi+N-1…H2FK‧‧‧邏輯-物理位址映射表
H2FLink‧‧‧鏈結表
Hm(LBAk0~LBAk0+7)、Hm+1(LBAk1~LBAk1+7)、Hm+2(LBAk2~LBAk2+7)、Hm+3(LBAk3~LBAk3+7)‧‧‧主機頁
S502…S508‧‧‧步驟
*H2F1…*H2Fi-1、*H2Fi…*H2Fi+N-1、*H2Fi+N…*H2FK‧‧‧邏輯-物理位址映射表指標
*H2FLink‧‧‧鏈結表指標
第1圖圖解一快閃記憶體100的儲存空間規劃;第2圖根據本案一種實施方式圖解一邏輯-物理位址映射表H2F;第3圖為方塊圖,根據本案一種實施方式圖解一資料儲存裝置300;第4圖更詳細分解第3圖鏈結表H2FLink之更新過程;以及第5圖為流程圖,根據本案一種實施方式圖解如何抹除其邏輯位址對應鏈結表H2FLink中N個欄位332的大尺寸使用者資料,其邏輯-物理位址映射資訊係儲存於N個邏輯-物理位址映射表H2Fi…H2Fi+N-1中。
以下敘述列舉本發明的多種實施例。以下敘述介紹本發明的基本概念,且並非意圖限制本發明內容。實際發明範圍應依照申請專利範圍界定之。
第1圖圖解一快閃記憶體100的儲存空間規劃。快閃記憶體100所供應的儲存空間係劃分為複數個區塊(blocks)BLK1、BLK2…BLKN…等。各區塊包括複數個物理頁(pages)。各物理頁包括複數區段(sectors)。例如,區塊BLKN上的物理頁102包括四個區段104、106、108以及110。
若各區段係配置儲存一主機頁的使用者資料(對應一串邏輯位址,如LBAk~LBAk+7),各物理頁係配置給四個主機頁使用。例如,區段104、106、108以及110係分別對應主機頁Hm(即,LBAk0~LBAk0+7)、Hm+1(即,LBAk1~LBAk1+7)、
Hm+2(即,LBAk2~LBAk2+7)、Hm+3(即,LBAk3~LBAk3+7)。若一區塊包括128個物理頁,則係有128x4個主機頁對應一區塊之128x4個區段。針對各區塊,如此128x4個區段以及128x4個主機頁之間的映射資訊需記錄下來,供管理儲存空間使用。大尺寸記憶體所需管理的映射資訊量也大。
在一種實施方式中,可觀資料量的映射資訊係記錄於快閃記憶體100中,作非揮發性儲存。映射資訊係設計為多階層架構。映射關係係以複數個邏輯-物理位址映射表(簡稱H2Fs)以及標示該等邏輯-物理位址映射表H2Fs位置的一鏈結表記錄在快閃記憶體中。
第2圖根據本案一種實施方式圖解一邏輯-物理位址映射表H2F。該邏輯-物理位址映射表H2F為16K位元組,等同一個物理頁尺寸。該邏輯-物理位址映射表H2F各欄位佔4位元組。因此,各邏輯-物理位址映射表存有4K(=16KB/4B)個主機頁的映射資訊。各欄位對應一主機頁,且係紀載一區塊號碼B_N以及一物理頁號碼P_N,顯示對應之主機頁儲存於快閃記憶體何處。以上例子並不意圖限定表格尺寸為16K位元組,更不意圖限定各主機頁的映射資訊為4位元組。
第3圖為方塊圖,根據本案一種實施方式圖解一資料儲存裝置300。資料接收裝置300係根據主機302所下達的指令運作,包括一快閃記憶體304以及一控制單元306。快閃記憶體304的複數個區塊(blocks)係配置作多種用途。部分區塊308係用於儲存系統內程式碼(in-system programs,簡稱ISPs)。部分區塊310儲存系統資訊(system information)。使用者資料係儲
存在資料集合312。快閃記憶體304可更包括未作任何配置使用的區塊(free blocks)、閒置區塊(spare blocks)以及資料接收區塊,該些區塊未顯示於圖示中。
控制單元306耦接該快閃記憶體304至該主機302,且包括一微控制器320、一隨機存取記憶體322以及一唯讀記憶體324。唯讀程式碼係儲存於唯讀記憶體324中。微控制器320包括執行該唯讀記憶體324內的唯讀程式碼(ROM code)或/以及執行該快閃記憶體304之該些區塊308內的系統內程式碼,據以操作該快閃記憶體304。微控制器320係設置來執行該快閃記憶體304之區塊配置(如第3圖所示)。
微控制器320係更設置來在該快閃記憶體304上供應一鏈結表指標*H2FLink、複數個邏輯-物理位址映射表H2F1…H2Fi…H2Fi+N-1…H2FK、以及一鏈結表H2FLink,以記錄主機302以及快閃記憶體304之間的邏輯-物理位址映射資訊。系統區塊330上的鏈結表指標*H2FLink係標示鏈結表H2FLink位置。鏈結表*H2FLink可以一區塊號碼以及一物理頁號碼標示鏈結表H2FLink位置。鏈結表H2FLink係標示上述該等邏輯-物理位址映射表H2F1…H2Fi…H2Fi+N-1…H2FK之位置。鏈結表H2FLink的複數個欄位分別對應該等邏輯-物理位址映射表H2F1…H2Fi…H2Fi+N-1…H2FK。在一種實施方式中,鏈結表H2FLink各欄位係儲存一區塊號碼以及一物理頁號碼,標示所對應的邏輯-物理位址映射表之位置。若欲抹除邏輯位址對應N個邏輯-物理位址映射表H2Fi…H2Fi+N-1的使用者資料,相關操作討論如下。鏈結表H2FLink中,N個欄位332對應N個
邏輯-物理位址映射表H2Fi…H2Fi+N-1。微控制器320係設置來讀取該系統區塊330,以自該快閃記憶體304下載鏈結表指標*H2FLink於隨機存取記憶體322的空間334。此外,基於鏈結表指標*H2FLink,微控制器320自快閃記憶體304下載鏈結表H2FLink至隨機存取記憶體的空間336,並在隨機存取記憶體322上令鏈結表的N個欄位338(對應332)無效。微控制器320再將如此N個欄位338內容無效的鏈結表上傳回快閃記憶體304(例如,寫入快閃記憶體304的閒置空間340)。上傳如此N個欄位338內容無效的鏈結表回快閃記憶體304(寫入閒置空間340)時,微控制器320更將更新系統區塊330記錄更新過的鏈結表指標342,以標示更新後的鏈結表位置340。如此一來,面對大尺寸抹除要求(如,抹除其邏輯位址對應N個邏輯-物理位址映射表H2Fi…H2Fi+N-1的使用者資料,即,抹除一序列資料,其邏輯位址含括N個邏輯-物理位址映射表H2Fi…H2Fi+N-1),也僅會耗費少量系統資源。本案令大尺寸抹除操作可簡單藉由修正鏈結表指標*H2FLink以及鏈結表H2FLink達到目的,無須自快閃記憶體304將N個邏輯-物理位址映射表H2Fi…H2Fi+N-1全數載入該隨機存取記憶體322作映射資訊修正。資料儲存裝置300具有顯著提升的系統效率。
第4圖更詳細分解第3圖鏈結表H2FLink之更新過程。如圖所示,鏈結表H2FLink儲存有指標*H2F1…*H2FK,分別指向邏輯-物理位址映射表H2F1…H2FK。抹除邏輯位址對應N個邏輯-物理位址映射表H2Fi…H2Fi+N-1的使用者資料時,鏈結表H2FLink遭下載至隨機存取記憶體322的空間336,且鏈結
表的N個欄位338(對應332)在隨機存取記憶體322上被轉化為無效資料。接著,如此N個欄位338內容無效的鏈結表上傳回快閃記憶體304,儲存於空間340。原來的鏈結表H2FLink轉化為無效。
第5圖為流程圖,根據本案一種實施方式圖解如何抹除邏輯位址對應鏈結表H2FLink中N個欄位332的大尺寸使用者資料,其邏輯-物理位址映射資訊係儲存於N個邏輯-物理位址映射表H2Fi…H2Fi+N-1。以下基於第3圖架構說明第5圖流程。
步驟S502存取系統區塊330,以獲得鏈結表指標*H2FLink、並將之暫存於隨機存取記憶體322的空間334。步驟S504自快閃記憶體304下載鏈結表H2FLink,且將之暫存於隨機存取記憶體322的空間336。步驟S506令隨機存取記憶體322所儲存的鏈結表之N個欄位338無效,並將如此N個欄位338內容無效的鏈結表上傳回快閃記憶體304,儲存於空間340。步驟S508更新空間334的鏈結表指標,並將更新後的鏈結表指標重新上傳回該快閃記憶體304,存至空間342。
其他採用上述概念控制一快閃記憶體的技術都屬於本案所欲保護的範圍。基於以上技術內容,本案更涉及快閃記憶體的控制方法,不限定以特定架構的控制單元實現。
雖然本發明已以較佳實施例揭露如上,然其並非用以限定本發明,任何熟悉此項技藝者,在不脫離本發明之精神和範圍內,當可做些許更動與潤飾,因此本發明之保護範圍當視後附之申請專利範圍所界定者為準。
300‧‧‧資料儲存裝置
302‧‧‧主機
304‧‧‧快閃記憶體
306‧‧‧控制單元
308‧‧‧系統內程式區塊
310‧‧‧系統資訊區塊
312‧‧‧資料集合
320‧‧‧微控制器
322‧‧‧隨機存取記憶體
324‧‧‧唯讀記憶體
330‧‧‧系統區塊
332‧‧‧鏈結表H2FLink的N個欄位
334‧‧‧供鏈結表指標*H2FLink下載儲存的空間
336‧‧‧供鏈結表H2FLink下載儲存的空間
338‧‧‧N個欄位332於隨機存取記憶體322上所對應的內容
340‧‧‧儲存更新後的鏈結表
342‧‧‧更新過的鏈結表指標
H2F1…H2Fi…H2Fi+N-1…H2FK‧‧‧邏輯-物理位址映射表
H2FLink‧‧‧鏈結表
*H2FLink‧‧‧鏈結表指標
Claims (12)
- 一種資料儲存裝置,包括:一快閃記憶體,劃分為複數個區塊,且上述區塊各自包括複數個物理頁;以及一控制單元,耦接該快閃記憶體至一主機,且包括一微控制器;其中:該微控制器係設置來在該快閃記憶體上維護複數個邏輯-物理位址映射表以及一鏈結表,以記錄該主機以及該快閃記憶體之間的映射資訊;該鏈結表標示上述複數個邏輯-物理位址映射表的位置,且該鏈結表各欄位對應上述該等邏輯-物理位址映射表其一;且抹除邏輯位址對應N個邏輯-物理位址映射表的使用者資料時,該微控制器係設置來令該鏈結表中對應上述N個邏輯-物理位址映射表的N個欄位無效,N為整數。
- 如申請專利範圍第1項所述之資料儲存裝置,其中:該控制單元更包括一隨機存取記憶體;且抹除邏輯位址對應上述N個邏輯-物理位址映射表的使用者資料時,該微控制器係設置來自該快閃記憶體將該鏈結表下載至該隨機存取記憶體,並在該隨機存取記憶體上令該鏈結表上述N個欄位無效,並將上述N個欄位為無效資料的該鏈結表上傳回該快閃記憶體。
- 如申請專利範圍第2項所述之資料儲存裝置,其中: 該微控制器更是設置來配置該快閃記憶體的該等區塊供應一系統區塊;並且該微控制器係設置來在該系統區塊記錄一鏈結表指標,標示該鏈結表的位置。
- 如申請專利範圍第3項所述之資料儲存裝置,其中:該微控制器係根據記錄於該系統區塊的該鏈結表指標,自該快閃記憶體下載該鏈結表至該隨機存取記憶體;且將上述N個欄位為無效資料的該鏈結表上傳回該快閃記憶體時,該微控制器更以更新後的鏈結表指標更新該系統區塊。
- 如申請專利範圍第3項所述之資料儲存裝置,其中:該鏈結表指標以一區塊號碼以及一物理頁號碼標示該鏈結表的位置。
- 如申請專利範圍第1項所述之資料儲存裝置,其中:該鏈結表各欄位儲存一區塊號碼以及一物理頁號碼標示所對應的邏輯-物理位址映射表的位置。
- 一種快閃記憶體控制方法,包括:在一快閃記憶體上維護複數個邏輯-物理位址映射表以及一鏈結表,以記錄一主機以及該快閃記憶體之間的映射資訊,其中,該快閃記憶體提供的儲存空間係劃分為複數個區塊,且上述區塊各自包括複數個物理頁,且該鏈結表標示上述複數個邏輯-物理位址映射表的位置,且該鏈結表各欄位對應一個邏輯-物理位址映射表;並且 在抹除邏輯位址對應N個邏輯-物理位址映射表的使用者資料時,令該鏈結表中對應上述N個邏輯-物理位址映射表的N個欄位無效,其中,N為整數。
- 如申請專利範圍第7項所述之快閃記憶體控制方法,更包括:供應一隨機存取記憶體;以及在抹除邏輯位址對應上述N個邏輯-物理位址映射表的使用者資料時,自該快閃記憶體下載該鏈結表至該隨機存取記憶體,並在該隨機存取記憶體上令該鏈結表上述N個欄位無效,並將上述N個欄位為無效資料的該鏈結表上傳回該快閃記憶體。
- 如申請專利範圍第8項所述之快閃記憶體控制方法,更包括:配置該快閃記憶體的該等區塊供應一系統區塊;並且在該系統區塊記錄一鏈結表指標,標示該鏈結表的位置。
- 如申請專利範圍第9項所述之快閃記憶體控制方法,更包括:根據記錄於該系統區塊的該鏈結表指標,自該快閃記憶體下載該鏈結表至該隨機存取記憶體;且將上述N個欄位為無效資料的該鏈結表上傳回該快閃記憶體時,更以更新後的鏈結表指標更新該系統區塊。
- 如申請專利範圍第9項所述之快閃記憶體控制方法,其中:該鏈結表指標以一區塊號碼以及一物理頁號碼標示該鏈結表的位置。
- 如申請專利範圍第7項所述之快閃記憶體控制方法,其中:該鏈結表各欄位儲存一區塊號碼以及一物理頁號碼標示所對應的邏輯-物理位址映射表的位置。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201361920830P | 2013-12-26 | 2013-12-26 | |
US14/534,633 US9684568B2 (en) | 2013-12-26 | 2014-11-06 | Data storage device and flash memory control method |
Publications (2)
Publication Number | Publication Date |
---|---|
TW201527974A true TW201527974A (zh) | 2015-07-16 |
TWI516935B TWI516935B (zh) | 2016-01-11 |
Family
ID=53481879
Family Applications (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW103138870A TWI561982B (en) | 2013-12-26 | 2014-11-10 | Data storage device and flash memory control method |
TW103138872A TWI611293B (zh) | 2013-12-26 | 2014-11-10 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103138991A TWI520139B (zh) | 2013-12-26 | 2014-11-11 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144258A TWI570737B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144256A TWI575373B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144257A TWI516935B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
Family Applications Before (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW103138870A TWI561982B (en) | 2013-12-26 | 2014-11-10 | Data storage device and flash memory control method |
TW103138872A TWI611293B (zh) | 2013-12-26 | 2014-11-10 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103138991A TWI520139B (zh) | 2013-12-26 | 2014-11-11 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144258A TWI570737B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144256A TWI575373B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
Country Status (3)
Country | Link |
---|---|
US (8) | US9684568B2 (zh) |
CN (6) | CN104750625B (zh) |
TW (6) | TWI561982B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI664527B (zh) * | 2018-03-20 | 2019-07-01 | 慧榮科技股份有限公司 | 用來於一記憶裝置中進行初始化之方法、記憶裝置及其控制器以及電子裝置 |
Families Citing this family (85)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9811275B2 (en) * | 2015-02-27 | 2017-11-07 | Toshiba Memory Corporation | Memory system and data control method |
US10007451B2 (en) * | 2015-03-20 | 2018-06-26 | SK Hynix Inc. | Scalable SPOR algorithm for flash memories |
US9703498B1 (en) * | 2015-06-29 | 2017-07-11 | EMC IP Holding Company LLC | Allocating space in a file system from sequential and random cursors |
TWI563510B (en) * | 2015-07-24 | 2016-12-21 | Phison Electronics Corp | Mapping table accessing method, memory control circuit unit and memory storage device |
TWI575374B (zh) * | 2015-08-04 | 2017-03-21 | 群聯電子股份有限公司 | 映射表格更新方法、記憶體儲存裝置及記憶體控制電路單元 |
TWI534619B (zh) * | 2015-09-11 | 2016-05-21 | 慧榮科技股份有限公司 | 動態邏輯分段方法以及使用該方法的裝置 |
TWI646461B (zh) * | 2016-10-12 | 2019-01-01 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
TWI537729B (zh) | 2015-10-15 | 2016-06-11 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
US10073769B2 (en) | 2015-10-15 | 2018-09-11 | Silicon Motion, Inc. | Data storage device and data maintenance method thereof |
TWI604308B (zh) | 2015-11-18 | 2017-11-01 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
KR102625637B1 (ko) * | 2016-02-01 | 2024-01-17 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
CN105868122A (zh) * | 2016-03-28 | 2016-08-17 | 深圳市硅格半导体股份有限公司 | 快闪存储设备的数据处理方法及装置 |
TWI603193B (zh) * | 2016-03-31 | 2017-10-21 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
CN111679787B (zh) | 2016-04-27 | 2023-07-18 | 慧荣科技股份有限公司 | 闪存装置、闪存控制器及闪存存储管理方法 |
US9910772B2 (en) * | 2016-04-27 | 2018-03-06 | Silicon Motion Inc. | Flash memory apparatus and storage management method for flash memory |
US10019314B2 (en) | 2016-04-27 | 2018-07-10 | Silicon Motion Inc. | Flash memory apparatus and storage management method for flash memory |
US10289487B2 (en) | 2016-04-27 | 2019-05-14 | Silicon Motion Inc. | Method for accessing flash memory module and associated flash memory controller and memory device |
US10133664B2 (en) | 2016-04-27 | 2018-11-20 | Silicon Motion Inc. | Method, flash memory controller, memory device for accessing 3D flash memory having multiple memory chips |
CN107391026B (zh) | 2016-04-27 | 2020-06-02 | 慧荣科技股份有限公司 | 闪存装置及闪存存储管理方法 |
TW201742063A (zh) | 2016-05-30 | 2017-12-01 | 慧榮科技股份有限公司 | 資料儲存方法及發生電源中斷事件後之系統初始化之方法 |
CN106201903B (zh) * | 2016-07-05 | 2019-07-30 | 深圳市领存技术有限公司 | 一种三维闪存擦除控制方法及其系统 |
KR20180019419A (ko) | 2016-08-16 | 2018-02-26 | 삼성전자주식회사 | 메모리 컨트롤러, 메모리 시스템 및 그 동작방법 |
KR102711037B1 (ko) * | 2016-09-19 | 2024-09-30 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 메모리 시스템의 동작 방법 |
TWI607312B (zh) | 2016-10-07 | 2017-12-01 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料寫入方法 |
TWI640868B (zh) * | 2016-10-07 | 2018-11-11 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料寫入方法 |
TWI619018B (zh) * | 2016-11-10 | 2018-03-21 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之垃圾蒐集方法 |
TWI591533B (zh) | 2016-11-25 | 2017-07-11 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之資料儲存方法與資料回復程序、以及採用這些方法的資料儲存裝置 |
TWI670640B (zh) * | 2016-11-25 | 2019-09-01 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之資料儲存方法與資料回復程序、以及採用這些方法的資料儲存裝置 |
TWI627531B (zh) * | 2016-11-28 | 2018-06-21 | 慧榮科技股份有限公司 | 資料儲存裝置以及其操作方法 |
KR20180080589A (ko) * | 2017-01-04 | 2018-07-12 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
TWI659307B (zh) * | 2017-01-06 | 2019-05-11 | 慧榮科技股份有限公司 | 資料儲存裝置以及快閃記憶體控制方法 |
TWI602116B (zh) | 2017-03-07 | 2017-10-11 | Silicon Motion Inc | 資料儲存裝置及其資料維護方法 |
TWI653533B (zh) * | 2017-03-07 | 2019-03-11 | 慧榮科技股份有限公司 | 資料儲存裝置以及其操作方法 |
TWI644250B (zh) * | 2017-03-07 | 2018-12-11 | 慧榮科技股份有限公司 | 電子系統及其資料維護方法 |
CN108733575B (zh) * | 2017-04-20 | 2022-12-27 | 深圳市得一微电子有限责任公司 | 一种断电重启后逻辑对物理映像表的重建方法、固态硬盘 |
TWI639917B (zh) * | 2017-04-25 | 2018-11-01 | 慧榮科技股份有限公司 | 資料儲存裝置及映射表重建方法 |
US10141050B1 (en) * | 2017-04-27 | 2018-11-27 | Pure Storage, Inc. | Page writes for triple level cell flash memory |
TWI633437B (zh) * | 2017-05-26 | 2018-08-21 | 慧榮科技股份有限公司 | 偵測使用中邏輯頁面之資料儲存裝置與資料儲存方法 |
CN108959108B (zh) | 2017-05-26 | 2021-08-24 | 上海宝存信息科技有限公司 | 固态硬盘访问方法以及使用该方法的装置 |
KR102233400B1 (ko) * | 2017-05-29 | 2021-03-26 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
TWI672590B (zh) * | 2017-06-27 | 2019-09-21 | 慧榮科技股份有限公司 | 資料儲存裝置 |
TWI630540B (zh) * | 2017-07-13 | 2018-07-21 | 慧榮科技股份有限公司 | 資料儲存裝置及非揮發式記憶體操作方法 |
CN107391046B (zh) * | 2017-08-02 | 2021-04-20 | 郑州云海信息技术有限公司 | 一种raid系统的数据写入方法及装置 |
CN109582599B (zh) * | 2017-09-29 | 2023-12-22 | 上海宝存信息科技有限公司 | 数据储存装置以及非挥发式存储器操作方法 |
CN108132853A (zh) * | 2017-11-24 | 2018-06-08 | 北京动力机械研究所 | 用于发动机控制器软件的上电校验双冗余引导加载方法 |
TWI733964B (zh) * | 2017-12-13 | 2021-07-21 | 英業達股份有限公司 | 記憶體整體測試之系統及其方法 |
CN107967125A (zh) * | 2017-12-20 | 2018-04-27 | 北京京存技术有限公司 | 闪存转换层的管理方法、装置及计算机可读存储介质 |
TWI649755B (zh) | 2017-12-22 | 2019-02-01 | 慧榮科技股份有限公司 | 資料儲存裝置與記憶體裝置之資料處理方法 |
TWI668700B (zh) * | 2017-12-22 | 2019-08-11 | 慧榮科技股份有限公司 | 資料儲存裝置與記憶體裝置之資料處理方法 |
TWI645404B (zh) * | 2017-12-28 | 2018-12-21 | 慧榮科技股份有限公司 | 資料儲存裝置以及非揮發式記憶體操作方法 |
TWI670594B (zh) * | 2018-01-18 | 2019-09-01 | 慧榮科技股份有限公司 | 資料儲存裝置 |
CN108255436A (zh) * | 2018-01-25 | 2018-07-06 | 广东美的制冷设备有限公司 | 数据存取方法、存取装置、家电设备和可读存储介质 |
TWI679538B (zh) * | 2018-03-31 | 2019-12-11 | 慧榮科技股份有限公司 | 資料儲存系統之控制單元以及邏輯至物理映射表更新方法 |
JP2019185350A (ja) * | 2018-04-09 | 2019-10-24 | 東芝メモリ株式会社 | メモリシステム及びメモリシステムの制御方法 |
TWI669610B (zh) * | 2018-06-13 | 2019-08-21 | 慧榮科技股份有限公司 | 資料儲存裝置以及非揮發式記憶體控制方法 |
TWI678622B (zh) * | 2018-06-15 | 2019-12-01 | 慧榮科技股份有限公司 | 資料儲存裝置的開發系統以及產品化方法 |
US10534551B1 (en) * | 2018-06-22 | 2020-01-14 | Micron Technology, Inc. | Managing write operations during a power loss |
CN110955384B (zh) * | 2018-09-26 | 2023-04-18 | 慧荣科技股份有限公司 | 数据储存装置以及非挥发式存储器控制方法 |
CN109446109B (zh) * | 2018-10-25 | 2021-06-29 | 江苏华存电子科技有限公司 | 一种混合型记录实体映像表的方法 |
US11341048B2 (en) * | 2018-10-29 | 2022-05-24 | Micron Technology, Inc. | SLC cache allocation |
CN109582222B (zh) * | 2018-10-31 | 2020-11-24 | 华中科技大学 | 一种主机感知瓦记录磁盘中持久缓存的清理方法 |
TW202018513A (zh) * | 2018-11-07 | 2020-05-16 | 威剛科技股份有限公司 | 固態硬碟及其資料存取的方法 |
KR20200058867A (ko) * | 2018-11-20 | 2020-05-28 | 에스케이하이닉스 주식회사 | 메모리 시스템의 복구 동작 중 비휘발성 메모리 블록의 반복 접근을 줄이는 방법 및 장치 |
TWI704456B (zh) * | 2018-11-22 | 2020-09-11 | 慧榮科技股份有限公司 | 資料儲存裝置與資料存取方法 |
KR102637478B1 (ko) | 2018-12-05 | 2024-02-15 | 삼성전자주식회사 | 오픈 채널 솔리드 스테이트 드라이브, 이를 포함하는 비휘발성 메모리 시스템 및 오픈 채널 솔리드 스테이트 드라이브의 파워 로스 프로텍션 방법 |
TWI749279B (zh) * | 2018-12-18 | 2021-12-11 | 慧榮科技股份有限公司 | 資料儲存裝置與資料處理方法 |
US11288185B2 (en) | 2019-01-03 | 2022-03-29 | Silicon Motion, Inc. | Method and computer program product for performing data writes into a flash memory |
TWI739075B (zh) * | 2019-01-03 | 2021-09-11 | 慧榮科技股份有限公司 | 閃存的資料寫入方法及電腦程式產品 |
TWI709854B (zh) * | 2019-01-21 | 2020-11-11 | 慧榮科技股份有限公司 | 資料儲存裝置及用於存取邏輯至物理位址映射表之方法 |
JP6708762B1 (ja) * | 2019-01-29 | 2020-06-10 | ウィンボンド エレクトロニクス コーポレーション | 半導体記憶装置 |
CN111610929B (zh) * | 2019-02-26 | 2023-04-14 | 慧荣科技股份有限公司 | 数据储存装置以及非挥发式存储器控制方法 |
TWI710905B (zh) * | 2019-05-06 | 2020-11-21 | 慧榮科技股份有限公司 | 資料儲存裝置及邏輯至物理位址映射表之載入方法 |
TWI695264B (zh) * | 2019-05-20 | 2020-06-01 | 慧榮科技股份有限公司 | 資料儲存裝置與資料處理方法 |
TWI745695B (zh) * | 2019-05-22 | 2021-11-11 | 慧榮科技股份有限公司 | 用來進行無預警斷電復原管理之方法、記憶裝置及其控制器以及電子裝置 |
CN112100087B (zh) * | 2019-06-17 | 2024-04-02 | 慧荣科技股份有限公司 | 数据储存装置以及非挥发式存储器控制方法 |
TWI726524B (zh) * | 2019-12-09 | 2021-05-01 | 新唐科技股份有限公司 | 電子處理裝置及記憶體控制方法 |
TWI738308B (zh) * | 2020-04-27 | 2021-09-01 | 宇瞻科技股份有限公司 | 基於分頁模式備份資料的固態硬碟以及基於分頁模式的固態硬碟資料備份方法 |
CN112506814B (zh) * | 2020-11-17 | 2024-03-22 | 合肥康芯威存储技术有限公司 | 一种存储器及其控制方法与存储系统 |
CN112559386B (zh) * | 2020-12-22 | 2024-06-18 | 深圳忆联信息系统有限公司 | 提升ssd性能的方法、装置、计算机设备及存储介质 |
CN112668642A (zh) * | 2020-12-28 | 2021-04-16 | 高新兴智联科技有限公司 | 一种机动车电子标识与视频结合系统及方法 |
KR20220142192A (ko) * | 2021-04-14 | 2022-10-21 | 에스케이하이닉스 주식회사 | 저장 장치 및 그 동작 방법 |
CN113535092B (zh) * | 2021-07-20 | 2024-05-17 | 阿里巴巴创新公司 | 用于减少内存元数据的存储引擎、方法和可读介质 |
US11615020B2 (en) | 2021-08-12 | 2023-03-28 | Micron Technology, Inc. | Implementing mapping data structures to minimize sequentially written data accesses |
CN114356246B (zh) * | 2022-03-17 | 2022-05-13 | 北京得瑞领新科技有限公司 | Ssd内部数据的存储管理方法、装置、存储介质及ssd设备 |
CN118689408A (zh) * | 2024-08-26 | 2024-09-24 | 合肥康芯威存储技术有限公司 | 一种存储设备及其数据处理方法 |
Family Cites Families (55)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7886108B2 (en) | 2000-01-06 | 2011-02-08 | Super Talent Electronics, Inc. | Methods and systems of managing memory addresses in a large capacity multi-level cell (MLC) based flash memory device |
US8078794B2 (en) | 2000-01-06 | 2011-12-13 | Super Talent Electronics, Inc. | Hybrid SSD using a combination of SLC and MLC flash memory arrays |
US8266367B2 (en) | 2003-12-02 | 2012-09-11 | Super Talent Electronics, Inc. | Multi-level striping and truncation channel-equalization for flash-memory system |
US6970890B1 (en) | 2000-12-20 | 2005-11-29 | Bitmicro Networks, Inc. | Method and apparatus for data recovery |
US6895490B1 (en) * | 2001-04-09 | 2005-05-17 | Matrix Semiconductor, Inc. | Method for making a write-once memory device read compatible with a write-many file system |
US7085879B2 (en) * | 2002-02-27 | 2006-08-01 | Microsoft Corporation | Dynamic data structures for tracking data stored in a flash memory device |
CN100590737C (zh) | 2003-01-26 | 2010-02-17 | 深圳市朗科科技股份有限公司 | 闪存介质中的数据管理方法 |
US7904635B2 (en) | 2003-03-04 | 2011-03-08 | Netac Technology Co., Ltd. | Power cut data recovery and data management method for flash media |
TW594477B (en) * | 2003-05-02 | 2004-06-21 | Genesys Logic Inc | Method and related device for accessing non-volatile memory of dual platforms for PC and X-BOX |
US6988175B2 (en) | 2003-06-30 | 2006-01-17 | M-Systems Flash Disk Pioneers Ltd. | Flash memory management method that is resistant to data corruption by power loss |
US7509474B2 (en) | 2005-06-08 | 2009-03-24 | Micron Technology, Inc. | Robust index storage for non-volatile memory |
KR101257848B1 (ko) | 2005-07-13 | 2013-04-24 | 삼성전자주식회사 | 복합 메모리를 구비하는 데이터 저장 시스템 및 그 동작방법 |
US20070156998A1 (en) * | 2005-12-21 | 2007-07-05 | Gorobets Sergey A | Methods for memory allocation in non-volatile memories with a directly mapped file storage system |
US20100299494A1 (en) | 2005-12-22 | 2010-11-25 | Nxp B.V. | Memory with block-erasable locations and a linked chain of pointers to locate blocks with pointer information |
US7711923B2 (en) * | 2006-06-23 | 2010-05-04 | Microsoft Corporation | Persistent flash memory mapping table |
CN100583293C (zh) | 2006-08-09 | 2010-01-20 | 安国国际科技股份有限公司 | 存储装置及其读写方法 |
KR100771521B1 (ko) * | 2006-10-30 | 2007-10-30 | 삼성전자주식회사 | 멀티 레벨 셀을 포함하는 플래시 메모리 장치 및 그것의데이터 쓰기 방법 |
KR100833188B1 (ko) | 2006-11-03 | 2008-05-28 | 삼성전자주식회사 | 데이터의 특성에 따라 싱글 레벨 셀 또는 멀티 레벨 셀에데이터를 저장하는 불휘발성 메모리 시스템 |
CN101715575A (zh) * | 2006-12-06 | 2010-05-26 | 弗森多系统公司(dba弗森-艾奥) | 采用数据管道管理数据的装置、系统和方法 |
US7934052B2 (en) | 2007-12-27 | 2011-04-26 | Pliant Technology, Inc. | System and method for performing host initiated mass storage commands using a hierarchy of data structures |
KR101077339B1 (ko) | 2007-12-28 | 2011-10-26 | 가부시끼가이샤 도시바 | 반도체 기억 장치 |
KR101067457B1 (ko) * | 2008-03-01 | 2011-09-27 | 가부시끼가이샤 도시바 | 메모리 시스템 |
TWI472916B (zh) * | 2008-06-02 | 2015-02-11 | A Data Technology Co Ltd | 記憶體儲存空間管理方法 |
US8843691B2 (en) | 2008-06-25 | 2014-09-23 | Stec, Inc. | Prioritized erasure of data blocks in a flash storage device |
US8321652B2 (en) * | 2008-08-01 | 2012-11-27 | Infineon Technologies Ag | Process and method for logical-to-physical address mapping using a volatile memory device in solid state disks |
CN101667157A (zh) | 2008-09-04 | 2010-03-10 | 群联电子股份有限公司 | 闪存数据传输方法、闪存储存系统及控制器 |
TWI467369B (zh) | 2008-10-01 | 2015-01-01 | A Data Technology Co Ltd | 混合密度記憶體系統及其控制方法 |
JP5198245B2 (ja) * | 2008-12-27 | 2013-05-15 | 株式会社東芝 | メモリシステム |
US8412880B2 (en) | 2009-01-08 | 2013-04-02 | Micron Technology, Inc. | Memory system controller to manage wear leveling across a plurality of storage nodes |
US8832353B2 (en) * | 2009-04-07 | 2014-09-09 | Sandisk Technologies Inc. | Host stop-transmission handling |
US20100306451A1 (en) | 2009-06-01 | 2010-12-02 | Joshua Johnson | Architecture for nand flash constraint enforcement |
US8688894B2 (en) | 2009-09-03 | 2014-04-01 | Pioneer Chip Technology Ltd. | Page based management of flash storage |
TWI407310B (zh) | 2009-10-09 | 2013-09-01 | Silicon Motion Inc | 資料儲存裝置及資料存取方法 |
US8291194B2 (en) | 2009-11-16 | 2012-10-16 | Mediatek Inc. | Methods of utilizing address mapping table to manage data access of storage medium without physically accessing storage medium and related storage controllers thereof |
US9104546B2 (en) | 2010-05-24 | 2015-08-11 | Silicon Motion Inc. | Method for performing block management using dynamic threshold, and associated memory device and controller thereof |
KR101662827B1 (ko) | 2010-07-02 | 2016-10-06 | 삼성전자주식회사 | 쓰기 패턴에 따라 데이터 블록의 쓰기 모드를 선택하는 메모리 시스템 및 그것의 데이터 쓰기 방법 |
KR101811297B1 (ko) | 2011-03-15 | 2017-12-27 | 삼성전자주식회사 | 불휘발성 메모리를 제어하는 메모리 컨트롤러 |
CN102682848B (zh) | 2011-03-16 | 2016-12-07 | 三星电子株式会社 | 存储器装置、存储器卡、固态驱动器、系统及其操作方法 |
US20120297121A1 (en) | 2011-05-17 | 2012-11-22 | Sergey Anatolievich Gorobets | Non-Volatile Memory and Method with Small Logical Groups Distributed Among Active SLC and MLC Memory Partitions |
JP2014513850A (ja) * | 2011-05-17 | 2014-06-05 | サンディスク テクノロジィース インコーポレイテッド | 小さな論理グループがアクティブなslcおよびmlcメモリパーティションに分散させられる不揮発性メモリおよび方法 |
CN103106143B (zh) * | 2011-11-11 | 2016-01-13 | 光宝科技股份有限公司 | 固态储存装置及其逻辑至实体对应表建立方法 |
CN102591748A (zh) | 2011-12-29 | 2012-07-18 | 记忆科技(深圳)有限公司 | 固态硬盘及其掉电保护方法、系统 |
TWI544334B (zh) | 2012-05-30 | 2016-08-01 | 慧榮科技股份有限公司 | 資料儲存裝置與資料儲存裝置操作方法 |
US9244833B2 (en) | 2012-05-30 | 2016-01-26 | Silicon Motion, Inc. | Data-storage device and flash memory control method |
TWI477966B (zh) | 2012-05-31 | 2015-03-21 | Silicon Motion Inc | 資料儲存裝置與快閃記憶體操作方法 |
US20130326169A1 (en) * | 2012-05-31 | 2013-12-05 | Amir Shaharabany | Method and Storage Device for Detection of Streaming Data Based on Logged Read/Write Transactions |
US8910017B2 (en) | 2012-07-02 | 2014-12-09 | Sandisk Technologies Inc. | Flash memory with random partition |
US9146857B2 (en) * | 2012-08-18 | 2015-09-29 | Storart Technology Co. Ltd. | Method for mapping management |
US9268682B2 (en) * | 2012-10-05 | 2016-02-23 | Skyera, Llc | Methods, devices and systems for physical-to-logical mapping in solid state drives |
US9098400B2 (en) * | 2012-10-31 | 2015-08-04 | International Business Machines Corporation | Dynamic tuning of internal parameters for solid-state disk based on workload access patterns |
US8954694B2 (en) * | 2012-11-15 | 2015-02-10 | Western Digital Technologies, Inc. | Methods, data storage devices and systems for fragmented firmware table rebuild in a solid state drive |
CN103150125B (zh) | 2013-02-20 | 2015-06-17 | 郑州信大捷安信息技术股份有限公司 | 提高掉电保护数据缓冲存储器使用寿命的方法及智能卡 |
US8990458B2 (en) | 2013-02-28 | 2015-03-24 | Kabushiki Kaisha Toshiba | Controller, semiconductor storage device and method of controlling data writing |
US20150127687A1 (en) * | 2013-11-04 | 2015-05-07 | Roger Graves | System and methods for creating and modifying a hierarchial data structure |
US20150261444A1 (en) | 2014-03-12 | 2015-09-17 | Kabushiki Kaisha Toshiba | Memory system and information processing device |
-
2014
- 2014-11-06 US US14/534,633 patent/US9684568B2/en active Active
- 2014-11-06 US US14/534,535 patent/US9645894B2/en active Active
- 2014-11-06 US US14/534,603 patent/US9645896B2/en active Active
- 2014-11-06 US US14/534,488 patent/US9632880B2/en active Active
- 2014-11-06 US US14/534,686 patent/US9542278B2/en active Active
- 2014-11-06 US US14/534,569 patent/US9645895B2/en active Active
- 2014-11-10 TW TW103138870A patent/TWI561982B/zh active
- 2014-11-10 TW TW103138872A patent/TWI611293B/zh active
- 2014-11-11 TW TW103138991A patent/TWI520139B/zh active
- 2014-12-08 CN CN201410743784.7A patent/CN104750625B/zh active Active
- 2014-12-08 CN CN201410742700.8A patent/CN104750618B/zh active Active
- 2014-12-08 CN CN201410743192.5A patent/CN104750619B/zh active Active
- 2014-12-18 TW TW103144258A patent/TWI570737B/zh active
- 2014-12-18 TW TW103144256A patent/TWI575373B/zh active
- 2014-12-18 TW TW103144257A patent/TWI516935B/zh active
- 2014-12-25 CN CN201410821110.4A patent/CN104750615B/zh active Active
- 2014-12-25 CN CN201410825548.XA patent/CN104750626B/zh active Active
- 2014-12-25 CN CN201410821785.9A patent/CN104750616B/zh active Active
-
2017
- 2017-02-21 US US15/437,543 patent/US9727271B2/en active Active
- 2017-05-17 US US15/597,742 patent/US9842030B2/en active Active
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI664527B (zh) * | 2018-03-20 | 2019-07-01 | 慧榮科技股份有限公司 | 用來於一記憶裝置中進行初始化之方法、記憶裝置及其控制器以及電子裝置 |
US10782901B2 (en) | 2018-03-20 | 2020-09-22 | Silicon Motion, Inc. | Method for performing initialization in a memory device, associated memory device and controller thereof, and associated electronic device |
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI516935B (zh) | 資料儲存裝置以及快閃記憶體控制方法 | |
US10657047B2 (en) | Data storage device and method of performing partial garbage collection | |
KR102149817B1 (ko) | 메모리 어드레싱 | |
CN107111551B (zh) | 用于高速缓存经压缩的数据背景的装置、系统和方法 | |
KR101903577B1 (ko) | 다양한 워크로드들에 대한 솔리드 스테이트 드라이브들의 내부 사전 컨디셔닝 | |
EP3436953B1 (en) | Method and apparatus for processing sequential writes to a block group of physical blocks in a memory device | |
US8595424B2 (en) | Cluster based non-volatile memory translation layer | |
TWI544334B (zh) | 資料儲存裝置與資料儲存裝置操作方法 | |
TWI627531B (zh) | 資料儲存裝置以及其操作方法 | |
TWI639918B (zh) | 資料儲存裝置以及其操作方法 | |
US20190339904A1 (en) | Solid state drive using two-level indirection architecture | |
US20190188130A1 (en) | Data Storage Device and Non-Volatile Memory Control Method | |
KR20100003244A (ko) | 판독 실패 관리 방법 및 시스템 | |
CN112099985B (zh) | 数据储存装置以及非挥发式存储器控制方法 | |
TWI718709B (zh) | 資料儲存裝置以及非揮發式記憶體控制方法 | |
KR20140033362A (ko) | 웨어 레벨링을 사용한 메모리 디바이스의 암호화 | |
CN112130750B (zh) | 数据储存装置以及非挥发式存储器控制方法 | |
CN112100087B (zh) | 数据储存装置以及非挥发式存储器控制方法 | |
JP6179355B2 (ja) | 情報処理装置、データ転送制御方法及びデータ転送制御プログラム | |
CN111611178B (zh) | 数据储存装置以及非挥发式存储器控制方法 | |
JP2012068765A (ja) | メモリコントローラ及びメモリコントローラを備えるフラッシュメモリシステム、並びにフラッシュメモリの制御方法 | |
TWI766194B (zh) | 資料儲存裝置以及非揮發式記憶體控制方法 | |
JP2008299455A (ja) | データ記憶装置及びデータ管理方法 | |
JP2010079860A (ja) | 記憶装置およびメモリ制御方法 |