TWI520139B - 資料儲存裝置以及快閃記憶體控制方法 - Google Patents
資料儲存裝置以及快閃記憶體控制方法 Download PDFInfo
- Publication number
- TWI520139B TWI520139B TW103138991A TW103138991A TWI520139B TW I520139 B TWI520139 B TW I520139B TW 103138991 A TW103138991 A TW 103138991A TW 103138991 A TW103138991 A TW 103138991A TW I520139 B TWI520139 B TW I520139B
- Authority
- TW
- Taiwan
- Prior art keywords
- data
- physical page
- physical
- flash memory
- receiving block
- 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)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- 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)
Description
本發明係有關於快閃記憶體(flash memory)實現之資料儲存裝置以及快閃記憶體控制方法。
現今資料儲存裝置常以快閃記憶體(flash memory)為儲存媒體。例如,快閃記憶體常用作記憶卡(memory card)、通用序列匯流排閃存裝置(USB flash device)、固態硬碟(SSD)...等產品。另外有一種應用是採多晶片封裝、將一非及閘型快閃記憶體與其控制晶片包裝在同一封裝中-稱為嵌入式快閃記憶體模組(如eMMC)。
快閃記憶體的實體空間通常包括複數個物理區塊(blocks)。各物理區塊包括複數個物理頁(pages)。針對快閃記憶體而設計的抹除操作須以物理區塊為抹除單位,一物理區塊接著一物理區塊地釋放儲存空間。資料更新時,新版資料係寫入閒置空間,而非覆寫在舊版資料上。因此,快閃記憶體-特別是架構複雜(包括多階以及單階存儲單元)之快閃記憶體-之管理遠比其他傳統儲存媒體複雜。
本案揭露快閃記憶體所實現的資料儲存裝置以及快閃記憶體控制方法,所控制之快閃記憶體包括多階存儲單元
(Multi-Level Cells,簡稱MLCs)以及單階存儲單元(Single Level Cells,簡稱SLCs),係將零散資料以及序列資料分開寫入該快閃記憶體。
根據本案一種實施方式所實現的一資料儲存裝置包括一快閃記憶體以及一控制單元。該快閃記憶體包括多階存儲單元以及單階存儲單元,且係劃分為複數個物理區塊,各物理區塊包括複數個物理頁。該控制單元係耦接該快閃記憶體至一主機,且包括一微控制器以及一隨機存取記憶體。該微控制器係運作來將該主機所下達的資料在寫入該快閃記憶體之前先快取於該隨機存取記憶體之中。該微控制器係運作來配置該快閃記憶體該些物理區塊供應包含多階存儲單元的一第一資料接收區塊以及包括單階存儲單元的一第二資料接收區塊。在該微控制器控制下,自該隨機存取記憶體上傳至該第一資料接收區塊的各物理頁所各自含括的係序列資料(sequential data)。至於零散資料則是快取於該隨機存取記憶體組成一物理頁後寫入該第二資料接收區塊。
根據本案另外一種實施方式所實現的一快閃記憶體控制方法包括以下步驟:為一快閃記憶體供應一隨機存取記憶體,該快閃記憶體包括多階存儲單元以及單階存儲單元,且係劃分為複數個物理區塊,各物理區塊包括複數個物理頁;將主機下達的資料於寫入該快閃記憶體前先快取於該隨機存取記憶體中;以及配置該快閃記憶體的該等物理區塊供應包括多階存儲單元的一第一資料接收區塊、以及包括單階存儲單元的一第二資料接收區塊。特別是,自該隨機存取記憶體上傳至該
第一資料接收區塊的各物理頁係各自包含序列資料。至於零散資料則是快取於該隨機存取記憶體中組成一物理頁後寫入該第二資料接收區塊。
下文特舉實施例,並配合所附圖示,詳細說明本發明內容。
100‧‧‧快閃記憶體
102‧‧‧物理頁
104、106、108以及110‧‧‧物理區段
300‧‧‧資料儲存裝置
302‧‧‧主機
304‧‧‧快閃記憶體
306‧‧‧控制單元
308‧‧‧系統內程式物理區塊
310‧‧‧多階存儲單元之閒置物理區塊
312‧‧‧單階存儲單元之閒置物理區塊
314‧‧‧資料集合
320‧‧‧微控制器
322‧‧‧隨機存取記憶體
324‧‧‧唯讀記憶體
Cached_Data‧‧‧一物理頁的快取資料
HA、HB、HC以及HD‧‧‧四個主機頁的資料
Hm(LBAk0~LBAk0+7)、Hm+1(LBAk1~LBAk1+7)、Hm+2(LBAk2~LBAk2+7)、Hm+3(LBAk3~LBAk3+7)‧‧‧主機頁
R_MLC、R_SLC‧‧‧資料接收區塊
S402…S414‧‧‧步驟
第1圖圖解一快閃記憶體100的儲存空間規劃;第2A圖圖解多階存儲單元(MLCS)的存儲內容分布;第2B圖圖解單階存儲單元(SLCs)的存儲內容分布;第3圖為方塊圖,根據本案一種實施方式圖解一資料儲存裝置300;第4圖為流程圖,根據本案一種實施方式圖解如何將一物理頁的快取資料Cached_Data自隨機存取記憶體322上傳至快閃記憶體304;以及第5A圖以及第5B圖係基於第4圖圖解一連串的快取資料係如何寫入快閃記憶體304。
以下敘述列舉本發明的多種實施例。以下敘述介紹本發明的基本概念,且並非意圖限制本發明內容。實際發明範圍應依照申請專利範圍界定之。
第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)。寫入一物理頁的四個主機頁可為零散(random)或序列(sequential)資料。例如,倘若寫入物理頁102的四個主機頁Hm、Hm+1、Hm+2以及Hm+3為零散資料,則邏輯位址LBAk1非接續邏輯位址LBAk0+7、或邏輯位址LBAk2非接續邏輯位址LBAk1+7、或邏輯位址LBAk3非接續邏輯位址LBAk2+7。倘若寫入物理頁102的四個主機頁Hm、Hm+1、Hm+2以及Hm+3包含序列資料,則邏輯位址LBAk1接續邏輯位址LBAk0+7、且邏輯位址LBAk2接續邏輯位址LBAk1+7、且邏輯位址LBAk3接續邏輯位址LBAk2+7。本案所揭露技術教示零散資料以及序列資料如何分開寫入快閃記憶體100。
第2A圖圖解多階存儲單元(MLCs)的存儲內容分布。2B圖圖解單階存儲單元(SLCs)的存儲內容分布。參閱第2A圖,各多階存儲單元係儲存兩位元的資料。各多階存儲單元係處於四種狀態’11’、’10’、’01’以及’00’之一。參閱第2B圖,各單階存儲單元係儲存單一位元的資料。各單階存儲單元係處於兩種狀態’1’與’0’之一。單階存儲單元的優點係寫入速度快、能量消耗低、且具有良好的存儲耐久性。多階存儲單元的優點主要
是高資料密度。本案一種實施方式係常態將資料以單階存儲單元儲存,以受益於其高寫入速度、低功率消耗以及高存儲耐久性。然而,倘若寫入資料經判斷確定為序列資料,則將之寫入多階存儲單元而非單階存儲單元,以期提升資料密度。
第3圖為方塊圖,根據本案一種實施方式圖解一資料儲存裝置300。資料儲存裝置300係耦接主機302,以根據主機302下達的指令運作。資料儲存裝置300包括快閃記憶體304以及控制單元306。以下討論如何將零散資料以及序列資料分開寫入快閃記憶體304。
快閃記憶體304的物理區塊係配置作多種用途。部分物理區塊308係儲存系統內程式(in-system programs,簡稱ISPs)。部分物理區塊310為包含多階存儲單元(MLCs)的閒置物理區塊。部分物理區塊312為包含單階存儲單元(SLCs)的閒置物理區塊。兩種資料寫入區塊R_MLC以及R_SLC係分別配置自該些閒置物理區塊310(多階存儲單元)以及該些閒置物理區塊312(單階存儲單元),以接收寫入資料,並於後續作為資料區塊推入資料集合314。快閃記憶體304可更包括未顯示在圖上的尚未作規劃之物理區塊。
控制單元306係耦接該快閃記憶體304至主機302,且包括一微控制器320、一隨機存取記憶體322以及一唯讀記憶體324。唯讀程式碼係儲存於唯讀記憶體324中。微控制器320包括執行該唯讀記憶體324內的唯讀程式碼或/以及該快閃記憶體304之該些物理區塊308內的系統內程式碼,據以操作該快閃記憶體304。以下段落將討論該快閃記憶體304之控制與管
理。
微控制器320係運作來對快閃記憶體304作以上物理區塊配置(例如,配置該快閃記憶體304供應上述兩個資料接收區塊R_MLC以及R_SLC)。微控制器320更在將主機302下達的資料寫入該快閃記憶體304前,先以隨機存取記憶體322快取收集之。如圖所示,四個主機頁HA、HB、HC以及HD係快取於隨機存取記憶體322且結合成一物理頁的快取資料Cache_Data,以寫入該快閃記憶體的一物理頁中。在微控制器320操作下,自隨機存取記憶體322上傳至該資料接收區塊R_MLC的各物理頁的資料係各自包含序列資料,且零散資料係快取於該隨機存取記憶體322中,待組成一物理頁後寫入該資料接收區塊R_SLC。
第4圖為流程圖,根據本案一種實施方式圖解一個物理頁的快取資料Cached_Data如何自隨機存取記憶體322上傳至該快閃記憶體304。如步驟S402以及S404所示,常態設定係將一個物理頁的快取資料Cached_Data寫入該資料接收區塊R_SLC,以達到快速寫入、低耗能、以及存儲耐久…等優點。在步驟S404寫入一個物理頁的快取資料Cached_Data至該資料接收區塊R_SLC後,步驟S406將檢查已在步驟S404中自該隨機存取記憶體322上傳至該資料接收區塊R_SLC的該個物理頁之資料型態。若步驟S406判定步驟S404自該隨機存取記憶體322上傳至該資料接收區塊R_SLC的該個物理頁係包含序列資料,則流程進行步驟S408,自該隨機存取記憶體322獲取另一物理頁的快取資料,繼而執行步驟S410,檢查步驟S408自該隨機存
取記憶體322所獲取的該另一物理頁的快取資料之資料型態。若步驟S410判定步驟S408自該隨機存取記憶體322所獲取的該另一物理頁的快取資料係包含零散資料,流程進行步驟S414,將步驟S408自該隨機存取記憶體322所獲取的該另一物理頁的快取資料寫入該資料接收區塊R_SLC。步驟S414後,流程則是再次進行步驟S402、S404以及S406。或者,若步驟S410判定步驟S408自該隨機存取記憶體322所獲取的該另一物理頁的快取資料係包含序列資料,則流程進行步驟S412,將步驟S408自該隨機存取記憶體322所獲取的該另一物理頁的快取資料寫入該資料接收區塊R_MLC。步驟S412後,流程則是再次進行步驟S408以及S410。
根據第4圖所示流程圖,微控制器320係運作來在寫入資料至該資料接收區塊R_MLC(如,步驟S412)前先檢查資料型態(如,步驟S410),以確認自該隨機存取記憶體322上傳至該資料接收區塊R_MLC的各物理頁資料係各自包含序列資料。若自隨機存取記憶體322上傳至該資料接收區塊R_SLC的一物理頁之快取資料(命名為Cached_DataA)係包含零散資料,微控制器322係運作來將稍晚於該物理頁資料Cached_DataA快取於該隨機存取記憶體322中的另一物理頁之資料(命名為Cached_DataB)寫入該資料接收區塊R_SLC,如於步驟S414後執行之步驟S404。微控制器322係更運作來檢查快取資料Cached_DataB係包含序列資料、或零散資料(例如,步驟S406),以預測晚於快取資料Cached_DataB快取於該隨機存取記憶體322中的一物理頁之快取資料(命名為Cached_DataC)之資料型
態。若快取資料Cached_DataB包含零散資料,微控制器320將推測快取資料Cached_DataC亦包含零散資料,且將快取資料Cached_DataC寫入資料接收區塊R_SLC(例如,步驟S406後執行的步驟S404)。若快取資料Cached_DataB包含序列資料,微控制器320係運作來在將快取資料Cached_DataC寫入快閃記憶體304前,檢查快取資料Cached_DataC的資料型態(例如,步驟S410)。若快取資料Cached_DataC確認包含序列資料,微控制器320係運作來寫入該快取資料Cached_DataC至該資料接收區塊R_MLC(如,步驟S412)。若快取資料Cached_DataC確認包含零散資料,微控制器320係運作來寫入該快取資料Cached_DataC至該資料接收區塊R_SLC(如,步驟S414)。
基於第4圖所示流程,第5A圖以及第5B圖說明一連串的快取資料係如何寫入快閃記憶體304。首先,根據步驟S402自隨機存取記憶體322獲取包含主機頁H0、H2、H60以及H50的一個物理頁的快取資料Cached_Data1。該物理頁的快取資料Cached_Data1係根據步驟S404寫入該資料接收區塊R_SLC。步驟S406則判斷出該物理頁的快取資料Cached_Data1係包含零散資料。因此,步驟S402再次實行,自隨機存取記憶體322獲取包含主機頁H32、H33、H34以及H35的另一個物理頁的快取資料Cached_Data2。該物理頁的快取資料Cached_Data2係根據步驟S404寫入該資料接收區塊R_SLC。步驟S406將判斷出該物理頁的快取資料Cached_Data2係包含序列資料,繼而,步驟S408將自隨機存取記憶體322獲取包含主機頁H36、H37、H38以及H39的另一個物理頁的快取資料Cached_Data3。步驟S410
判斷出該物理頁的快取資料Cached_Data3係包含序列資料,繼而,步驟S412將該物理頁的快取資料Cached_Data3寫入該資料接收區塊R_MLC。隨後,步驟S408再次執行,自隨機存取記憶體322獲取包含主機頁H35、H36、H80以及H90的另一個物理頁的快取資料Cached_Data4。步驟S410將判斷出該物理頁的快取資料Cached_Data4係包含零散資料。因此,步驟S414接續施行,將該個物理頁的快取資料Cached_Data4寫入該資料接收區塊R_SLC。步驟S402將隨後再次執行。參閱第5B圖,資料接收區塊R_SLC僅儲存序列資料,且零散資料係必然寫入該資料接收區塊R_SLC。
其他採用上述概念控制一快閃記憶體的技術都屬於本案所欲保護的範圍。基於以上技術內容,本案更涉及快閃記憶體的控制方法,不限定以特定架構的控制單元實現。
雖然本發明已以較佳實施例揭露如上,然其並非用以限定本發明,任何熟悉此項技藝者,在不脫離本發明之精神和範圍內,當可做些許更動與潤飾,因此本發明之保護範圍當視後附之申請專利範圍所界定者為準。
300‧‧‧資料儲存裝置
302‧‧‧主機
304‧‧‧快閃記憶體
306‧‧‧控制單元
308‧‧‧系統內程式物理區塊
310‧‧‧多階存儲單元之閒置物理區塊
312‧‧‧單階存儲單元之閒置物理區塊
314‧‧‧資料集合
320‧‧‧微控制器
322‧‧‧隨機存取記憶體
324‧‧‧唯讀記憶體
Cached_Data‧‧‧一物理頁的快取資料
HA、HB、HC以及HD‧‧‧四個主機頁的資料
R_MLC、R_SLC‧‧‧資料接收區塊
Claims (12)
- 一種資料儲存裝置,包括:一快閃記憶體,具有多階存儲單元以及單階存儲單元,其中該快閃記憶體係劃分為複數個物理區塊,且上述物理區塊各自包括複數個物理頁;以及一控制單元,耦接該快閃記憶體至一主機,且包括一微控制器以及一隨機存取記憶體;其中:該微控制器係運作來在將該主機所下達的資料寫入該快閃記憶體前,先以該隨機存取記憶體快取之;該微控制器更運作來配置該快閃記憶體的該等物理區塊供應包含多階存儲單元的一第一資料接收區塊、以及包含單階存儲單元的一第二資料接收區塊;其中:自該隨機存取記憶體上傳至該第一資料接收區塊的各物理頁各自係包含序列資料;且快取於該隨機存取記憶體中組成一物理頁的零散資料係寫入該第二資料接收區塊。
- 如申請專利範圍第1項所述之資料儲存裝置,其中:該微控制器係運作來在寫入資料至該第一資料接收區塊之前先做資料型態檢查,以確保自該隨機存取記憶體上傳至該第一資料接收區塊的各物理頁係各自包含序列資料。
- 如申請專利範圍第1項所述之資料儲存裝置,其中: 在判定自該隨機存取記憶體上傳至該第二資料接收區塊的一第一物理頁之資料係包含零散資料時,該微控制器係運作使一第二物理頁的資料係寫入該第二資料接收區塊,該第二物理頁的資料係晚於該第一物理頁的資料快取於該隨機存取記憶體中。
- 如申請專利範圍第3項所述之資料儲存裝置,其中:該微控制器係更運作來檢查該第二物理頁之資料係包含序列資料或零散資料,以推測一第三物理頁之資料的資料型態,該第三物理頁的資料係晚於該第二物理的資料快取於該隨機存取記憶體中。
- 如申請專利範圍第4項所述之資料儲存裝置,其中:該第二物理頁的資料包含零散資料時,該微控制器係運作來推測該第三物理頁之資料係包含零散資料,並將該第三物理頁之資料寫入該第二資料接收區塊。
- 如申請專利範圍第4項所述之資料儲存裝置,其中:該第二物理頁的資料包含序列資料時,該微控制器係運作來在寫入該第三物理頁之資料至該快閃記憶體前,先檢查該第三物理頁之資料的資料型態;該第三物理頁的資料經確認為包含序列資料時,該微控制器係運作來寫入該第三物理頁之資料至該第一資料接收區塊;且該第三物理頁的資料經確認為包含零散資料時,該微控制器係運作來寫入該第三物理頁之資料至該第二資料接收區塊。
- 一種快閃記憶體控制方法,包括:為一快閃記憶體供應一隨機存取記憶體,該快閃記憶體具有多階存儲單元以及單階存儲單元,且係劃分為複數個物理區塊,且上述物理區塊各自包括複數個物理頁;在將一主機所下達的資料寫入該快閃記憶體前,先以該隨機存取記憶體快取之;以及配置該快閃記憶體的該等物理區塊供應包含多階存儲單元的一第一資料接收區塊、以及包含單階存儲單元的一第二資料接收區塊;其中:自該隨機存取記憶體上傳至該第一資料接收區塊的各物理頁係各自包含序列資料;且快取於該隨機存取記憶體中以組成一物理頁的零散資料係寫入該第二資料接收區塊。
- 如申請專利範圍第7項所述之快閃記憶體控制方法,更包括:在寫入資料至該第一資料接收區塊之前先做資料型態檢查,以確保自該隨機存取記憶體上傳至該第一資料接收區塊的各物理頁係各自包含序列資料。
- 如申請專利範圍第7項所述之快閃記憶體控制方法,其中:在判定自該隨機存取記憶體上傳至該第二資料接收區塊的一第一物理頁之資料係包含零散資料時,使一第二物理頁的資料係寫入該第二資料接收區塊,該第二物理頁的資料係晚於該第一物理頁的資料快取於該隨機存取記憶體中。
- 如申請專利範圍第9項所述之快閃記憶體控制方法,更包括:檢查該第二物理頁之資料係包含序列資料或零散資料,以推測一第三物理頁之資料的資料型態,該第三物理頁的資料係晚於該第二物理的資料快取於該隨機存取記憶體中。
- 如申請專利範圍第10項所述之快閃記憶體控制方法,更包括:在該第二物理頁的資料包含零散資料時,推測該第三物理頁之資料係包含零散資料,並將該第三物理頁之資料寫入該第二資料接收區塊。
- 如申請專利範圍第10項所述之快閃記憶體控制方法,其中:該第二物理頁的資料包含序列資料時,該第三物理頁之資料的資料型態係在寫入該快閃記憶體前作檢查;該第三物理頁的資料經確認為包含序列資料時,該第三物理頁之資料係寫入該第一資料接收區塊;且該第三物理頁的資料經確認為包含零散資料時,該第三物理頁之資料係寫入該第二資料接收區塊。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201361920830P | 2013-12-26 | 2013-12-26 | |
US14/534,603 US9645896B2 (en) | 2013-12-26 | 2014-11-06 | Data storage device and flash memory control method |
Publications (2)
Publication Number | Publication Date |
---|---|
TW201526003A TW201526003A (zh) | 2015-07-01 |
TWI520139B true TWI520139B (zh) | 2016-02-01 |
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 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144257A TWI516935B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144258A TWI570737B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
TW103144256A TWI575373B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
Family Applications Before (2)
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 | 資料儲存裝置以及快閃記憶體控制方法 |
Family Applications After (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW103144257A TWI516935B (zh) | 2013-12-26 | 2014-12-18 | 資料儲存裝置以及快閃記憶體控制方法 |
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) | US9645896B2 (zh) |
CN (6) | CN104750619B (zh) |
TW (6) | TWI561982B (zh) |
Families Citing this family (84)
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 |
CN106095699B (zh) * | 2015-03-20 | 2020-12-01 | 爱思开海力士有限公司 | 用于快闪存储器的可扩展spor算法 |
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 | 慧榮科技股份有限公司 | 動態邏輯分段方法以及使用該方法的裝置 |
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 |
TWI646461B (zh) * | 2016-10-12 | 2019-01-01 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
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 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料維護方法 |
US10019314B2 (en) | 2016-04-27 | 2018-07-10 | Silicon Motion Inc. | Flash memory apparatus and storage management method for flash memory |
CN107391026B (zh) | 2016-04-27 | 2020-06-02 | 慧荣科技股份有限公司 | 闪存装置及闪存存储管理方法 |
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 |
US9910772B2 (en) * | 2016-04-27 | 2018-03-06 | Silicon Motion Inc. | Flash memory apparatus and storage management method for flash memory |
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 |
CN111679787B (zh) | 2016-04-27 | 2023-07-18 | 慧荣科技股份有限公司 | 闪存装置、闪存控制器及闪存存储管理方法 |
TW201742063A (zh) | 2016-05-30 | 2017-12-01 | 慧榮科技股份有限公司 | 資料儲存方法及發生電源中斷事件後之系統初始化之方法 |
CN106201903B (zh) * | 2016-07-05 | 2019-07-30 | 深圳市领存技术有限公司 | 一种三维闪存擦除控制方法及其系统 |
KR20180019419A (ko) | 2016-08-16 | 2018-02-26 | 삼성전자주식회사 | 메모리 컨트롤러, 메모리 시스템 및 그 동작방법 |
KR20180031851A (ko) * | 2016-09-19 | 2018-03-29 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 메모리 시스템의 동작 방법 |
TWI640868B (zh) * | 2016-10-07 | 2018-11-11 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料寫入方法 |
TWI607312B (zh) | 2016-10-07 | 2017-12-01 | 慧榮科技股份有限公司 | 資料儲存裝置及其資料寫入方法 |
TWI619018B (zh) * | 2016-11-10 | 2018-03-21 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之垃圾蒐集方法 |
TWI670640B (zh) * | 2016-11-25 | 2019-09-01 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之資料儲存方法與資料回復程序、以及採用這些方法的資料儲存裝置 |
TWI591533B (zh) | 2016-11-25 | 2017-07-11 | 慧榮科技股份有限公司 | 可用於資料儲存裝置之資料儲存方法與資料回復程序、以及採用這些方法的資料儲存裝置 |
TWI627531B (zh) * | 2016-11-28 | 2018-06-21 | 慧榮科技股份有限公司 | 資料儲存裝置以及其操作方法 |
KR20180080589A (ko) * | 2017-01-04 | 2018-07-12 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
TWI659307B (zh) * | 2017-01-06 | 2019-05-11 | 慧榮科技股份有限公司 | 資料儲存裝置以及快閃記憶體控制方法 |
TWI653533B (zh) * | 2017-03-07 | 2019-03-11 | 慧榮科技股份有限公司 | 資料儲存裝置以及其操作方法 |
TWI644250B (zh) * | 2017-03-07 | 2018-12-11 | 慧榮科技股份有限公司 | 電子系統及其資料維護方法 |
TWI602116B (zh) | 2017-03-07 | 2017-10-11 | Silicon Motion Inc | 資料儲存裝置及其資料維護方法 |
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 |
CN108959108B (zh) * | 2017-05-26 | 2021-08-24 | 上海宝存信息科技有限公司 | 固态硬盘访问方法以及使用该方法的装置 |
TWI633437B (zh) * | 2017-05-26 | 2018-08-21 | 慧榮科技股份有限公司 | 偵測使用中邏輯頁面之資料儲存裝置與資料儲存方法 |
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 | 北京京存技术有限公司 | 闪存转换层的管理方法、装置及计算机可读存储介质 |
TWI668700B (zh) * | 2017-12-22 | 2019-08-11 | 慧榮科技股份有限公司 | 資料儲存裝置與記憶體裝置之資料處理方法 |
TWI649755B (zh) * | 2017-12-22 | 2019-02-01 | 慧榮科技股份有限公司 | 資料儲存裝置與記憶體裝置之資料處理方法 |
TWI645404B (zh) * | 2017-12-28 | 2018-12-21 | 慧榮科技股份有限公司 | 資料儲存裝置以及非揮發式記憶體操作方法 |
TWI670594B (zh) * | 2018-01-18 | 2019-09-01 | 慧榮科技股份有限公司 | 資料儲存裝置 |
CN108255436A (zh) * | 2018-01-25 | 2018-07-06 | 广东美的制冷设备有限公司 | 数据存取方法、存取装置、家电设备和可读存储介质 |
TWI664527B (zh) | 2018-03-20 | 2019-07-01 | 慧榮科技股份有限公司 | 用來於一記憶裝置中進行初始化之方法、記憶裝置及其控制器以及電子裝置 |
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 | 江苏华存电子科技有限公司 | 一种混合型记录实体映像表的方法 |
CN118210738A (zh) * | 2018-10-29 | 2024-06-18 | 美光科技公司 | Slc高速缓存分配 |
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 |
CN111399750B (zh) * | 2019-01-03 | 2023-05-26 | 慧荣科技股份有限公司 | 闪存数据写入方法及计算机可读取存储介质 |
TWI709854B (zh) * | 2019-01-21 | 2020-11-11 | 慧榮科技股份有限公司 | 資料儲存裝置及用於存取邏輯至物理位址映射表之方法 |
JP6708762B1 (ja) * | 2019-01-29 | 2020-06-10 | ウィンボンド エレクトロニクス コーポレーション | 半導体記憶装置 |
CN111610929B (zh) * | 2019-02-26 | 2023-04-14 | 慧荣科技股份有限公司 | 数据储存装置以及非挥发式存储器控制方法 |
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设备 |
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 | 深圳市朗科科技股份有限公司 | 闪存介质中的数据管理方法 |
WO2004079575A1 (fr) | 2003-03-04 | 2004-09-16 | Netac Technology Co., Ltd. | Procede de gestion de donnees pour support a memoire flash |
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 | 삼성전자주식회사 | 데이터의 특성에 따라 싱글 레벨 셀 또는 멀티 레벨 셀에데이터를 저장하는 불휘발성 메모리 시스템 |
US20080313364A1 (en) * | 2006-12-06 | 2008-12-18 | David Flynn | Apparatus, system, and method for remote direct memory access to a solid-state storage device |
US8621137B2 (en) * | 2007-12-27 | 2013-12-31 | Sandisk Enterprise Ip Llc | Metadata rebuild in a flash memory controller following a loss of power |
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 | 三星电子株式会社 | 存储器装置、存储器卡、固态驱动器、系统及其操作方法 |
JP2014513850A (ja) | 2011-05-17 | 2014-06-05 | サンディスク テクノロジィース インコーポレイテッド | 小さな論理グループがアクティブなslcおよびmlcメモリパーティションに分散させられる不揮発性メモリおよび方法 |
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 |
CN103106143B (zh) * | 2011-11-11 | 2016-01-13 | 光宝科技股份有限公司 | 固态储存装置及其逻辑至实体对应表建立方法 |
CN102591748A (zh) | 2011-12-29 | 2012-07-18 | 记忆科技(深圳)有限公司 | 固态硬盘及其掉电保护方法、系统 |
US9244833B2 (en) | 2012-05-30 | 2016-01-26 | Silicon Motion, Inc. | Data-storage device and flash memory control method |
TWI544334B (zh) | 2012-05-30 | 2016-08-01 | 慧榮科技股份有限公司 | 資料儲存裝置與資料儲存裝置操作方法 |
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 |
TWI477966B (zh) | 2012-05-31 | 2015-03-21 | Silicon Motion Inc | 資料儲存裝置與快閃記憶體操作方法 |
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,603 patent/US9645896B2/en active Active
- 2014-11-06 US US14/534,569 patent/US9645895B2/en active Active
- 2014-11-06 US US14/534,633 patent/US9684568B2/en active Active
- 2014-11-06 US US14/534,686 patent/US9542278B2/en active Active
- 2014-11-06 US US14/534,535 patent/US9645894B2/en active Active
- 2014-11-06 US US14/534,488 patent/US9632880B2/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 CN201410743192.5A patent/CN104750619B/zh active 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-18 TW TW103144257A patent/TWI516935B/zh active
- 2014-12-18 TW TW103144258A patent/TWI570737B/zh active
- 2014-12-18 TW TW103144256A patent/TWI575373B/zh active
- 2014-12-25 CN CN201410825548.XA patent/CN104750626B/zh active Active
- 2014-12-25 CN CN201410821110.4A patent/CN104750615B/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
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI520139B (zh) | 資料儲存裝置以及快閃記憶體控制方法 | |
US11461233B2 (en) | Handling asynchronous power loss in a memory sub-system that programs sequentially | |
US20240120000A1 (en) | Lifetime mixed level non-volatile memory system | |
US9081665B2 (en) | Apparatus, methods and architecture to increase write performance and endurance of non-volatile solid state memory components | |
CN104461397A (zh) | 一种固态硬盘及其读写方法 | |
US11410734B1 (en) | Voltage bin selection for blocks of a memory device after power up of the memory device | |
US11868643B2 (en) | Background memory scan block selection | |
TWI692688B (zh) | 快閃記憶體控制器及相關電子裝置 | |
US20220019370A1 (en) | Partial zone memory unit handling in a zoned namespace of a memory device | |
KR20220114078A (ko) | 캐시의 데이터 블록의 기록 모드 변경을 기반으로 한 미디어 관리 동작 수행 | |
US11714722B2 (en) | Power loss recovery for memory devices | |
US20230069382A1 (en) | Managing host input/output in a memory system executing a table flush | |
US11526299B2 (en) | Elastic buffer for media management of a memory sub-system | |
US20240028230A1 (en) | Storage Access Communications and Data Placement for Improved Performance and Reduced Write Amplification | |
US20240028231A1 (en) | Random Storage Access and Data Erasure for Improved Performance and Reduced Write Amplification | |
US11967386B2 (en) | Memory sub-system for memory cell touch-up | |
US11144450B2 (en) | Maintaining sequentiality for media management of a memory sub-system | |
US20240176527A1 (en) | Memory device region allocation using lifetime hints | |
US20240152279A1 (en) | Memory sub-system for memory cell in-field touch-up | |
US11221949B2 (en) | Multi state purgatory for media management for a memory subsystem | |
US20240152287A1 (en) | Adaptive generation of memory partitions | |
WO2023034535A1 (en) | Virtual management unit scheme for two-pass programming in a memory sub-system | |
EP4396688A1 (en) | Virtual management unit scheme for two-pass programming in a memory sub-system |