TWI551991B - 記憶體管理方法與系統及其記憶體儲存裝置 - Google Patents
記憶體管理方法與系統及其記憶體儲存裝置 Download PDFInfo
- Publication number
- TWI551991B TWI551991B TW104138377A TW104138377A TWI551991B TW I551991 B TWI551991 B TW I551991B TW 104138377 A TW104138377 A TW 104138377A TW 104138377 A TW104138377 A TW 104138377A TW I551991 B TWI551991 B TW I551991B
- Authority
- TW
- Taiwan
- Prior art keywords
- memory
- unit
- physical
- physical erasing
- control circuit
- Prior art date
Links
Classifications
-
- 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/0632—Configuration or reconfiguration of storage systems by initialisation or re-initialisation of 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/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- 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
- 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
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7205—Cleaning, compaction, garbage collection, erase control
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Description
本發明是有關於一種記憶體管理方法,且特別是有關於一種可保留既有的使用資訊的記憶體管理方法與系統及其記憶體儲存裝置。
數位相機、行動電話與MP3播放器在這幾年來的成長十分迅速,使得消費者對儲存媒體的需求也急速增加。由於可複寫式非揮發性記憶體模組(例如,快閃記憶體)具有資料非揮發性、省電、體積小,以及無機械結構等特性,所以非常適合內建於上述所舉例的各種可攜式多媒體裝置中。
一般來說,利用可複寫式非揮發性記憶體模組作為儲存媒體的記憶體儲存裝置被製造完成後,會進行開卡操作(initialization operation)。一般的開卡操作是將相關資料,如主開機記錄(master boot record, MBR)、分割表區(Partition table, PT)、分割開機區(Partition boot sector, PBS)、系統資訊等,寫入可複寫式非揮發性記憶體模組中。然而,記憶體儲存裝置在經過一段時間的使用之後,可能因人為因素或其他原因而發生異常狀況。在此種狀況下,便需要對記憶體儲存裝置的可複寫式非揮發性記憶體模組重新執行開卡操作,以對可複寫式非揮發性記憶體模組執行格式化操作,以將記憶體儲存裝置恢復至原廠狀態。但實際上,記憶體儲存裝置經過使用後,會記錄對應於可複寫式非揮發性記憶體模組的使用資訊,例如壞塊資訊、抹除次數、使用時間等。而執行格式化操作後,可複寫式非揮發性記憶體模組所儲存的資訊會被抹除,此些既有的使用資訊也就因此而無法被保留。如此一來,將無法得知可複寫式非揮發性記憶體模組的實際使用狀況,可能導致使用上的問題,例如較容易使用到壞塊,或無法根據實際使用狀況來正確估算可複寫式非揮發性記憶體模組的壽命等。因此,如何在重新執行開卡操作後仍保留既有的使用資訊,為此領域技術人員所關心的議題。
本發明提供一種記憶體管理方法與系統及其記憶體儲存裝置,可在重置記憶體儲存裝置時,保留既有的使用資訊,並依據既有的使用資訊建立所需資料。
本發明的一範例實施例提出一種記憶體管理方法,用於記憶體儲存裝置。此記憶體儲存裝置具有可複寫式非揮發性記憶體模組,且此可複寫式非揮發性記憶體模組具有多個實體抹除單元。本記憶體管理方法包括從主機系統接收指令。本記憶體管理方法也包括,根據指令從可複寫式非揮發性記憶體模組中讀取對應於此些實體抹除單元的使用資訊,將使用資訊寫入至此些實體抹除單元之中的第一實體抹除單元中,並為第一實體抹除單元標記辨識旗標。本記憶體管理方法更包括根據辨識旗標抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料,並根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表,並根據記憶體管理表來操作記憶體儲存裝置。
在本發明的一範例實施例中,上述的根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表的步驟是在抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料的步驟之後執行。
在本發明的一範例實施例中,上述的記憶體管理方法更包括在此些實體抹除單元中搜尋未程式化資料的實體抹除單元以作為第一實體抹除單元。倘若此些實體抹除單元中不存在未程式化資料的實體抹除單元,將記憶體儲存裝置宣告為寫入保護狀態。
在本發明的一範例實施例中,上述的記憶體管理方法更包括將來自於主機系統的韌體碼寫入至可複寫式非揮發性記憶體模組中。
在本發明的一範例實施例中,上述的指令為開卡指令,並且開卡指令指示對記憶體儲存裝置執行開卡操作。上述根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表的步驟包括根據儲存在第一實體抹除單元中的使用資訊建立邏輯位址-實體位址映射表以回應於開卡指令。
在本發明的一範例實施例中,上述根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表的步驟包括倘若判斷要使用儲存在第一實體抹除單元中的使用資訊,則根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表。倘若判斷不使用儲存在第一實體抹除單元中的使用資訊,則建立新的記憶體管理表。
在本發明的一範例實施例中,上述使用資訊包括壞區塊資訊。上述的記憶體管理方法更包括根據壞區塊資訊建立壞區塊管理表用以避免存取已損壞的實體抹除單元。
在本發明的一範例實施例中,上述使用資訊包括抹除次數資訊。上述的記憶體管理方法更包括根據抹除次數資訊計算可複寫式非揮發性記憶體模組的使用壽命並根據使用壽命決定是否發出警告訊息,或根據抹除次數資訊執行可複寫式非揮發性記憶體模組的平均抹損操作。
在本發明的一範例實施例中,上述使用資訊包括使用時間資訊。上述的記憶體管理方法更包括根據使用時間資訊計算可複寫式非揮發性記憶體模組的使用壽命,或根據使用時間資訊執行該可複寫式非揮發性記憶體模組的資料更新操作。
在本發明的一範例實施例中,上述使用資訊包括讀取次數資訊。上述的記憶體管理方法更包括根據讀取次數資訊判斷至少一實體程式化單元的被讀取次數,並且倘若此至少一實體程式化單元的被讀取次數達到讀取次數門檻值,對此至少一實體程式化單元所屬的實體抹除單元執行資料更新操作。
在本發明的一範例實施例中,上述記憶體管理表包括邏輯位址-實體位址映射表、抹除次數管理表、使用時間管理表及讀取次數管理表。其中上述根據記憶體管理表來操作記憶體儲存裝置的步驟包括根據邏輯位址-實體位址映射表存取此些實體抹除單元,並根據抹除次數管理表及使用時間管理表計算可複寫式非揮發性記憶體模組的使用壽命及執行可複寫式非揮發性記憶體模組的平均抹損操作,以及根據使用時間管理表及讀取次數管理表執行可複寫式非揮發性記憶體模組的資料更新操作。
本發明一範例實施例提出一種記憶體儲存裝置,包括連接介面單元、可複寫式非揮發性記憶體模組及記憶體控制電路單元。連接介面單元耦接至主機系統。可複寫式非揮發性記憶體模組具有多個實體抹除單元。記憶體控制電路單元耦接至連接介面單元與可複寫式非揮發性記憶體模組,並從主機系統接收指令。再者,記憶體控制電路單元也根據指令從可複寫式非揮發性記憶體模組中讀取對應於此些實體抹除單元的使用資訊,並將使用資訊寫入至此些實體抹除單元之中的第一實體抹除單元中,並為第一實體抹除單元標示辨識旗標。此外,記憶體控制電路單元更根據辨識旗標抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料。並且,記憶體控制電路單元根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表,並根據記憶體管理表來操作記憶體儲存裝置。
在本發明的一範例實施例中,上述記憶體控制電路單元是在抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料之後,根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表。
在本發明的一範例實施例中,上述記憶體控制電路單元更在此些實體抹除單元中搜尋未程式化資料的實體抹除單元以作為第一實體抹除單元。倘若此些實體抹除單元中不存在未程式化資料的實體抹除單元,記憶體控制電路單元將記憶體儲存裝置宣告為寫入保護狀態。
在本發明的一範例實施例中,上述記憶體控制電路單元更將來自於主機系統的韌體碼寫入至可複寫式非揮發性記憶體模組中。
在本發明的一範例實施例中,上述的指令為開卡指令,並且開卡指令指示對記憶體儲存裝置執行開卡操作。上述的記憶體控制電路單元根據儲存在第一實體抹除單元中的使用資訊建立邏輯位址-實體位址映射表以回應於開卡指令。
在本發明的一範例實施例中,倘若判斷要使用儲存在第一實體抹除單元中的使用資訊,上述記憶體控制電路單元更根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表。倘若判斷不使用儲存在第一實體抹除單元中的使用資訊,上述記憶體控制電路單元建立新的記憶體管理表。
在本發明的一範例實施例中,上述使用資訊包括壞區塊資訊。上述記憶體控制電路單元根據壞區塊資訊建立壞區塊管理表。
在本發明的一範例實施例中,上述使用資訊包括抹除次數資訊。上述的記憶體控制電路單元根據抹除次數資訊計算可複寫式非揮發性記憶體模組的使用壽命並根據使用壽命決定是否發出警告訊息,或根據抹除次數資訊執行可複寫式非揮發性記憶體模組的平均抹損操作。
在本發明的一範例實施例中,上述使用資訊包括使用時間資訊。上述的記憶體控制電路單元更包括根據使用時間資訊計算可複寫式非揮發性記憶體模組的使用壽命,或根據使用時間資訊執行該可複寫式非揮發性記憶體模組的資料更新操作。
在本發明的一範例實施例中,上述使用資訊包括讀取次數資訊。上述的記憶體控制電路單元根據讀取次數資訊判斷至少一實體程式化單元的被讀取次數,並且倘若此至少一實體程式化單元的被讀取次數達到讀取次數門檻值,對此至少一實體程式化單元所屬的實體抹除單元執行資料更新操作。
在本發明的一範例實施例中,上述記憶體管理表包括邏輯位址-實體位址映射表、抹除次數管理表、使用時間管理表及讀取次數管理表。上述記憶體控制電路單元根據邏輯位址-實體位址映射表存取此些實體抹除單元。再者,上述記憶體控制電路單元更根據抹除次數管理表及使用時間管理表計算可複寫式非揮發性記憶體模組的使用壽命及執行可複寫式非揮發性記憶體模組的平均抹損操作。此外,上述記憶體控制電路單元也根據使用時間管理表及讀取次數管理表執行可複寫式非揮發性記憶體模組的資料更新操作。
本發明的一範例實施例提出一種記憶體管理系統,包括主機系統及記憶體儲存裝置。主機系統具有記憶體管理單元。記憶體儲存裝置包括連接介面單元、可複寫式非揮發性記憶體模組及記憶體控制電路單元。連接介面單元耦接至主機系統。可複寫式非揮發性記憶體模組具有多個實體抹除單元。記憶體控制電路單元耦接至連接介面單元與可複寫式非揮發性記憶體模組。記憶體管理單元傳送讀取指令至記憶體儲存裝置,並且記憶體控制電路單元根據讀取指令從可複寫式非揮發性記憶體模組中讀取對應於此些實體抹除單元的使用資訊以回應於讀取指令。再者,記憶體管理單元更傳送寫入指令至記憶體儲存裝置,並且記憶體控制電路單元更根據寫入指令寫入使用資訊至此些實體抹除單元中的第一實體抹除單元中以及為第一實體抹除單元標記辨識旗標以回應於寫入指令。此外,記憶體管理單元更傳送抹除指令至記憶體儲存裝置,並且記憶體控制電路單元根據抹除指令依據辨識旗標抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料。並且,記憶體管理單元更傳送建立表格指令至記憶體儲存裝置,而記憶體控制電路單元更根據建立表格指令依據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表,並根據該記憶體管理表來操作該記憶體儲存裝置。
在本發明的一範例實施例中,上述記憶體管理單元是在記憶體控制電路單元抹除此些實體抹除單元中除了第一實體抹除單元以外的至少部份的實體抹除單元的資料之後,傳送建立表格指令至記憶體儲存裝置。
在本發明的一範例實施例中,上述記憶體控制電路單元更根據寫入指令在此些實體抹除單元中搜尋未程式化資料的實體抹除單元以作為第一實體抹除單元。倘若此些實體抹除單元中不存在未程式化資料的實體抹除單元,記憶體控制電路單元更回傳第一錯誤訊息至主機系統以回應於寫入指令。而記憶體管理單元根據第一錯誤訊息傳送寫入保護指令至記憶體儲存裝置,記憶體控制電路單元更根據寫入保護指令將記憶體儲存裝置宣告為寫入保護狀態以回應於寫入保護指令。
在本發明的一範例實施例中,上述記憶體管理單元更傳送更新韌體碼指令至記憶體儲存裝置,並且記憶體控制電路單元根據更新韌體碼指令將來自於主機系統的韌體碼寫入至可複寫式非揮發性記憶體模組中。
在本發明的一範例實施例中,上述記憶體控制電路單元更判斷從主機系統接收的建立表格指令是否指示要使用儲存在第一實體抹除單元中的使用資訊。倘若判斷建立表格指令指示使用儲存在第一實體抹除單元中的使用資訊,記憶體控制電路單元會依據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表。倘若判斷建立表格指令指示不使用儲存在第一實體抹除單元中的使用資訊,記憶體控制電路單元會建立新的記憶體管理表。
在本發明的一範例實施例中,上述使用資訊包括壞區塊資訊。上述記憶體控制電路單元根據壞區塊資訊建立壞區塊管理表。
在本發明的一範例實施例中,上述使用資訊包括抹除次數資訊。上述的記憶體控制電路單元根據抹除次數資訊計算可複寫式非揮發性記憶體模組的使用壽命並根據使用壽命決定是否發出警告訊息,或根據抹除次數資訊執行可複寫式非揮發性記憶體模組的平均抹損操作。
在本發明的一範例實施例中,上述使用資訊包括使用時間資訊。上述的記憶體控制電路單元更包括根據使用時間資訊計算可複寫式非揮發性記憶體模組的使用壽命,或根據使用時間資訊執行該可複寫式非揮發性記憶體模組的資料更新操作。
在本發明的一範例實施例中,上述使用資訊包括讀取次數資訊。上述的記憶體控制電路單元根據讀取次數資訊判斷至少一實體程式化單元的被讀取次數,並且倘若此至少一實體程式化單元的被讀取次數達到讀取次數門檻值,對此至少一實體程式化單元所屬的實體抹除單元執行資料更新操作。
在本發明的一範例實施例中,上述記憶體管理表包括邏輯位址-實體位址映射表、抹除次數管理表、使用時間管理表及一讀取次數管理表。上述記憶體控制電路單元根據邏輯位址-實體位址映射表存取此些實體抹除單元,並根據抹除次數管理表及使用時間管理表計算可複寫式非揮發性記憶體模組的使用壽命及執行可複寫式非揮發性記憶體模組的平均抹損操作。另外,上述記憶體控制電路單元也根據使用時間管理表及讀取次數管理表執行可複寫式非揮發性記憶體模組的資料更新操作。
基於上述,本發明範例實施例所提出的記憶體管理方法與系統及其記憶體儲存裝置,能夠在對記憶體儲存裝置執行格式化操作後,保留既有的使用資訊,並根據既有的使用資訊建立所需資料,達到利用既有的使用資訊對記憶體儲存裝置的可複寫式非揮發性記憶體進行管理的效果。
為讓本發明的上述特徵和優點能更明顯易懂,下文特舉實施例,並配合所附圖式作詳細說明如下。
一般而言,記憶體儲存裝置(亦稱,記憶體儲存系統)包括可複寫式非揮發性記憶體模組與控制器(亦稱,控制電路單元)。通常記憶體儲存裝置是與主機系統一起使用,以使主機系統可將資料寫入至記憶體儲存裝置或從記憶體儲存裝置中讀取資料。
圖1是根據一範例實施例所繪示的主機系統、記憶體儲存裝置及輸入/輸出(I/O)裝置的示意圖。且圖2是根據另一範例實施例所繪示的主機系統、記憶體儲存裝置及輸入/輸出(I/O)裝置的示意圖。
請參照圖1與圖2,主機系統11一般包括處理器111、隨機存取記憶體(random access memory, RAM)112、唯讀記憶體(read only memory, ROM)113及資料傳輸介面114。處理器111、隨機存取記憶體112、唯讀記憶體113及資料傳輸介面114皆耦接至系統匯流排(system bus)110。
在本範例實施例中,主機系統11是透過資料傳輸介面114與記憶體儲存裝置10耦接。例如,主機系統11可經由資料傳輸介面114將資料寫入至記憶體儲存裝置10或從記憶體儲存裝置10中讀取資料。此外,主機系統11是透過系統匯流排110與I/O裝置12耦接。例如,主機系統11可經由系統匯流排110將輸出訊號傳送至I/O裝置12或從I/O裝置12接收輸入訊號。
在本範例實施例中,處理器111、隨機存取記憶體112、唯讀記憶體113及資料傳輸介面114是可設置在主機系統11的主機板20上。資料傳輸介面114的數目可以是一或多個。透過資料傳輸介面114,主機板20可以經由有線或無線方式耦接至記憶體儲存裝置10。記憶體儲存裝置10可例如是隨身碟201、記憶卡202、固態硬碟(Solid State Drive, SSD)203或無線記憶體儲存裝置204。無線記憶體儲存裝置204可例如是近距離無線通訊(Near Field Communication Storage, NFC)記憶體儲存裝置、無線傳真(WiFi)記憶體儲存裝置、藍牙(Bluetooth)記憶體儲存裝置或低功耗藍牙記憶體儲存裝置(例如,iBeacon)等以各式無線通訊技術為基礎的記憶體儲存裝置。此外,主機板20也可以透過系統匯流排110耦接至全球定位系統(Global Positioning System, GPS)模組205、網路介面卡206、無線傳輸裝置207、鍵盤208、螢幕209、喇叭210等各式I/O裝置。例如,在一範例實施例中,主機板20可透過無線傳輸裝置207存取無線記憶體儲存裝置204。
在一範例實施例中,所提及的主機系統為可實質地與記憶體儲存裝置配合以儲存資料的任意系統。雖然在上述範例實施例中,主機系統是以電腦系統來作說明,然而,圖3是根據另一範例實施例所繪示的主機系統與記憶體儲存裝置的示意圖。請參照圖3,在另一範例實施例中,主機系統31也可以是數位相機、攝影機、通訊裝置、音訊播放器、視訊播放器或平板電腦等系統,而記憶體儲存裝置30可為其所使用的SD卡32、CF卡33或嵌入式儲存裝置34等各式非揮發性記憶體儲存裝置。嵌入式儲存裝置34包括嵌入式多媒體卡(embedded MMC, eMMC)341及/或嵌入式多晶片封裝儲存裝置(embedded Multi Chip Package, eMCP)342等各類型將記憶體模組直接耦接於主機系統的基板上的嵌入式儲存裝置。
圖4是根據一範例實施例所繪示的主機系統與記憶體儲存裝置的概要方塊圖。
請參照圖4,記憶體儲存裝置10包括連接介面單元402、記憶體控制電路單元404與可複寫式非揮發性記憶體模組406。
在本範例實施例中,連接介面單元402是相容於序列先進附件(Serial Advanced Technology Attachment, SATA)標準。然而,必須瞭解的是,本發明不限於此,連接介面單元402亦可以是符合並列先進附件(Parallel Advanced Technology Attachment, PATA)標準、電氣和電子工程師協會(Institute of Electrical and Electronic Engineers, IEEE)1394標準、高速周邊零件連接介面(Peripheral Component Interconnect Express, PCI Express)標準、通用序列匯流排(Universal Serial Bus, USB)標準、超高速一代(Ultra High Speed-I, UHS-I)介面標準、超高速二代(Ultra High Speed-II, UHS-II)介面標準、安全數位(Secure Digital, SD)介面標準、記憶棒(Memory Stick, MS)介面標準、多晶片封裝(Multi-Chip Package)介面標準、多媒體儲存卡(Multi Media Card, MMC)介面標準、崁入式多媒體儲存卡(Embedded Multimedia Card, eMMC)介面標準、通用快閃記憶體(Universal Flash Storage, UFS)介面標準、嵌入式多晶片封裝(embedded Multi Chip Package, eMCP)介面標準、小型快閃(Compact Flash, CF)介面標準、整合式驅動電子介面(Integrated Device Electronics, IDE)標準或其他適合的標準。在本範例實施例中,連接介面單元402可與記憶體控制電路單元404封裝在一個晶片中,或者連接介面單元402是佈設於一包含記憶體控制電路單元之晶片外。
記憶體控制電路單元404用以執行以硬體型式或韌體型式實作的多個邏輯閘或控制指令,並且根據主機系統11的指令在可複寫式非揮發性記憶體模組406中進行資料的寫入、讀取與抹除等運作。
可複寫式非揮發性記憶體模組406是耦接至記憶體控制電路單元404,並且用以儲存主機系統11所寫入之資料。可複寫式非揮發性記憶體模組406具有實體抹除單元410(0)~ 410(N)。例如,實體抹除單元410(0)~410(N)可屬於同一個記憶體晶粒(die)或者屬於不同的記憶體晶粒。每一實體抹除單元分別具有複數個實體程式化單元,其中屬於同一個實體抹除單元之實體程式化單元可被獨立地寫入且被同時地抹除。然而,必須瞭解的是,本發明不限於此,每一實體抹除單元是可由64個實體程式化單元、256個實體程式化單元或其他任意個實體程式化單元所組成。
更詳細來說,實體抹除單元為抹除之最小單位。亦即,每一實體抹除單元含有最小數目之一併被抹除之記憶胞。實體程式化單元為程式化的最小單元。即,實體程式化單元為寫入資料的最小單元。每一實體程式化單元通常包括資料位元區與冗餘位元區。資料位元區包含多個實體存取位址用以儲存使用者的資料,而冗餘位元區用以儲存系統的資料(例如,控制資訊與錯誤更正碼)。在本範例實施例中,每一個實體程式化單元的資料位元區中會包含8個實體存取位址,且一個實體存取位址的大小為512位元組(byte)。然而,在其他範例實施例中,資料位元區中也可包含數目更多或更少的實體存取位址,本發明並不限制實體存取位址的大小以及個數。例如,在一範例實施例中,實體抹除單元為實體區塊,並且實體程式化單元為實體頁面或實體扇區,但本發明不以此為限。
在本範例實施例中,可複寫式非揮發性記憶體模組406為多階記憶胞(Multi Level Cell,MLC)NAND型快閃記憶體模組(即,一個記憶胞中可儲存2個資料位元的快閃記憶體模組)。然而,本發明不限於此,可複寫式非揮發性記憶體模組406亦可是單階記憶胞(Single Level Cell,SLC)NAND型快閃記憶體模組(即,一個記憶胞中可儲存1個資料位元的快閃記憶體模組)、複數階記憶胞(Trinary Level Cell,TLC)NAND型快閃記憶體模組(即,一個記憶胞中可儲存3個資料位元的快閃記憶體模組)、其他快閃記憶體模組或其他具有相同特性的記憶體模組。
在本範例實施例中,主機系統11藉由記憶體管理單元408來傳送關於開卡操作的指令至記憶體儲存裝置10,而記憶體控制電路單元404會執行對應操作以回應於從主機系統所接收的指令。例如,記憶體管理單元408包括以軟體程式碼所實作的開卡應用程式,其可於主機系統11的作業系統(operation system,OS)中運行。在本範例實施例中,主機系統11的作業系統為微軟(Microsoft)公司的視窗(Windows)作業系統。然而,必須瞭解的是,本發明不限於此,本發明亦可應用於Linux、Mac或其他作業系統中。
圖5是根據一範例實施例所繪示之記憶體控制電路單元的概要方塊圖。
請參照圖5,記憶體控制電路單元404包括記憶體管理電路502、主機介面504與記憶體介面506、緩衝記憶體508、電源管理電路510與錯誤檢查與校正電路512。
記憶體管理電路502用以控制記憶體控制電路單元404的整體運作。具體來說,記憶體管理電路502具有多個控制指令,並且在記憶體儲存裝置10運作時,此些控制指令會被執行以進行資料的寫入、讀取與抹除等運作。
在本範例實施例中,記憶體管理電路502的控制指令是以韌體型式來實作。例如,記憶體管理電路502具有微處理器單元(未繪示)與唯讀記憶體(未繪示),並且此些控制指令是被燒錄至此唯讀記憶體中。當記憶體儲存裝置10運作時,此些控制指令會由微處理器單元來執行以進行資料的寫入、讀取與抹除等運作。
圖6與圖7是根據一範例實施例所繪示之管理實體抹除單元的範例示意圖。
必須瞭解的是,在此描述可複寫式非揮發性記憶體模組106之實體抹除單元的運作時,以“提取”、“分組”、“劃分”、“關聯”等詞來操作實體抹除單元是邏輯上的概念。也就是說,可複寫式非揮發性記憶體模組之實體抹除單元的實際位置並未更動,而是邏輯上對可複寫式非揮發性記憶體模組的實體抹除單元進行操作。
請參照圖6,記憶體控制電路單元404(或記憶體管理電路502)會將實體抹除單元410(0)~410(N)邏輯地分組為資料區602、閒置區604、系統區606與取代區608。
邏輯上屬於資料區602與閒置區604的實體抹除單元是用以儲存來自於主機系統11的資料。具體來說,資料區602的實體抹除單元是被視為已儲存資料的實體抹除單元,而閒置區604的實體抹除單元是用以替換資料區602的實體抹除單元。也就是說,當從主機系統11接收到寫入指令與欲寫入之資料時,記憶體管理電路502會從閒置區604中提取實體抹除單元,並且將資料寫入至所提取的實體抹除單元中,以替換資料區602的實體抹除單元。
邏輯上屬於系統區606的實體抹除單元是用以記錄系統資料。例如,系統資料包括關於可複寫式非揮發性記憶體模組的製造商與型號、可複寫式非揮發性記憶體模組的實體抹除單元數、每一實體抹除單元的實體程式化單元數等。
邏輯上屬於取代區608中的實體抹除單元是用於壞實體抹除單元取代程序,以取代損壞的實體抹除單元。具體來說,倘若取代區608中仍存有正常之實體抹除單元並且資料區602的實體抹除單元損壞時,記憶體管理電路502會從取代區608中提取正常的實體抹除單元來更換損壞的實體抹除單元。
特別是,資料區602、閒置區604、系統區606與取代區608之實體抹除單元的數量會根據不同的記憶體規格而有所不同。此外,必須瞭解的是,在記憶體儲存裝置10的運作中,實體抹除單元關聯至資料區602、閒置區604、系統區606與取代區608的分組關係會動態地變動。例如,當閒置區604中的實體抹除單元損壞而被取代區608的實體抹除單元取代時,則原本取代區608的實體抹除單元會被關聯至閒置區604。
請參照圖7,記憶體控制電路單元404(或記憶體管理電路502)會配置邏輯單元LBA(0)~LBA(H)以映射資料區602的實體抹除單元,其中每一邏輯單元具有多個邏輯子單元以映射對應之實體抹除單元的實體程式化單元。並且,當主機系統11欲寫入資料至邏輯單元或更新儲存於邏輯單元中的資料時,記憶體控制電路單元404(或記憶體管理電路502)會從閒置區604中提取一個實體抹除單元來寫入資料,以輪替資料區602的實體抹除單元。在本範例實施例中,邏輯子單元可以是邏輯頁面或邏輯扇區。
為了識別每個邏輯單元的資料被儲存在哪個實體抹除單元,在本範例實施例中,記憶體控制電路單元404(或記憶體管理電路502)會記錄邏輯單元與實體抹除單元之間的映射。並且,當主機系統11欲在邏輯子單元中存取資料時,記憶體控制電路單元404(或記憶體管理電路502)會確認此邏輯子單元所屬的邏輯單元,並且在此邏輯單元所映射的實體抹除單元中來存取資料。例如,在本範例實施例中,記憶體控制電路單元404(或記憶體管理電路502)會在可複寫式非揮發性記憶體模組406中儲存邏輯位址-實體位址映射表來記錄每一邏輯單元所映射的實體抹除單元,並且當欲存取資料時記憶體控制電路單元404(或記憶體管理電路502)會將邏輯位址-實體位址映射表載入至緩衝記憶體508來維護。
值得一提的是,由於緩衝記憶體508的容量有限無法儲存記錄所有邏輯單元之映射關係的映射表,因此,在本範例實施例中,記憶體控制電路單元404(或記憶體管理電路502)會將邏輯單元LBA(0)~LBA(H)分組為多個邏輯區域LZ(0)~LZ(M),並且為每一邏輯區域配置一個邏輯位址-實體位址映射表。特別是,當記憶體控制電路單元404(或記憶體管理電路502)欲更新某個邏輯單元的映射時,對應此邏輯單元所屬之邏輯區域的邏輯位址-實體位址映射表會被載入至緩衝記憶體508來被更新。
在本發明另一範例實施例中,記憶體管理電路502的控制指令亦可以程式碼型式儲存於可複寫式非揮發性記憶體模組406的特定區域(例如,記憶體模組中專用於存放系統資料的系統區)中。此外,記憶體管理電路502具有微處理器單元(未繪示)、唯讀記憶體(未繪示)及隨機存取記憶體(未繪示)。特別是,此唯讀記憶體具有驅動碼,並且當記憶體控制電路單元404被致能時,微處理器單元會先執行此驅動碼段來將儲存於可複寫式非揮發性記憶體模組406中之控制指令載入至記憶體管理電路502的隨機存取記憶體中。之後,微處理器單元會運轉此些控制指令以進行資料的寫入、讀取與抹除等運作。
此外,在本發明另一範例實施例中,記憶體管理電路502的控制指令亦可以一硬體型式來實作。例如,記憶體管理電路502包括微控制器、記憶胞管理電路、記憶體寫入電路、記憶體讀取電路、記憶體抹除電路與資料處理電路。記憶胞管理電路、記憶體寫入電路、記憶體讀取電路、記憶體抹除電路與資料處理電路是耦接至微控制器。其中,記憶胞管理電路用以管理可複寫式非揮發性記憶體模組406的實體抹除單元;記憶體寫入電路用以對可複寫式非揮發性記憶體模組406下達寫入指令以將資料寫入至可複寫式非揮發性記憶體模組406中;記憶體讀取電路用以對可複寫式非揮發性記憶體模組406下達讀取指令以從可複寫式非揮發性記憶體模組406中讀取資料;記憶體抹除電路用以對可複寫式非揮發性記憶體模組406下達抹除指令以將資料從可複寫式非揮發性記憶體模組406中抹除;而資料處理電路用以處理欲寫入至可複寫式非揮發性記憶體模組406的資料以及從可複寫式非揮發性記憶體模組406中讀取的資料。
請再參照圖5,主機介面504是耦接至記憶體管理電路502並且用以耦接至連接介面單元402,以接收與識別主機系統11所傳送的指令與資料。也就是說,主機系統11所傳送的指令與資料會透過主機介面504來傳送至記憶體管理電路502。在本範例實施例中,主機介面504是相容於SATA標準。然而,必須瞭解的是本發明不限於此,主機介面504亦可以是相容於PATA標準、IEEE 1394標準、PCI Express標準、USB標準、UHS-I介面標準 、UHS-II介面標準、SD標準 、MS標準、MMC標準、CF標準、IDE標準或其他適合的資料傳輸標準。
記憶體介面506是耦接至記憶體管理電路502並且用以存取可複寫式非揮發性記憶體模組406。也就是說,欲寫入至可複寫式非揮發性記憶體模組406的資料會經由記憶體介面506轉換為可複寫式非揮發性記憶體模組406所能接受的格式。
緩衝記憶體508是耦接至記憶體管理電路502並且用以暫存來自於主機系統11的資料與指令或來自於可複寫式非揮發性記憶體模組406的資料。
電源管理電路510是耦接至記憶體管理電路502並且用以控制記憶體儲存裝置10的電源。
錯誤檢查與校正電路512是耦接至記憶體管理電路502並且用以執行錯誤檢查與校正程序以確保資料的正確性。具體來說,當記憶體管理電路502從主機系統11中接收到寫入指令時,錯誤檢查與校正電路512會為對應此寫入指令的資料產生對應的錯誤檢查與校正碼(Error Checking and Correcting Code, ECC Code),並且記憶體管理電路502會將對應此寫入指令的資料與對應的錯誤檢查與校正碼寫入至可複寫式非揮發性記憶體模組406中。之後,當記憶體管理電路502從可複寫式非揮發性記憶體模組406中讀取資料時會同時讀取此資料對應的錯誤檢查與校正碼,並且錯誤檢查與校正電路512會根據此錯誤檢查與校正碼對所讀取的資料執行錯誤檢查與校正程序。
當記憶體管理電路502根據主機系統11的開卡指令執行開卡操作時,記憶體管理電路502會對實體抹除單元410(0)~410(N)進行初始化動作,並識別出可複寫式非揮發性記憶體模組406的實體抹除單元410(0)~410(N)中的好實體抹除單元,將此些好實體抹除單元分組為資料區602、閒置區604與系統區606並且將剩餘的好實體抹除單元分組至取代區608。舉例而言,在記憶體儲存裝置10被製造完成所進行的開卡(即第一次程式化)過程中,記憶體管理電路502會將實體抹除單元410(0)~410(N)中每一頁面位址的資料抹除為0×FF資料,並進行磁碟掃描(例如,做讀寫測試)以識別出正常的實體抹除單元與損毀的實體抹除單元。此外,記憶體管理電路502還會建立邏輯位址-實體位址映射表來記錄邏輯單元與實體抹除單元之間的映射關係。在完成開卡操作之後,記憶體管理電路502會傳送確認訊息至主機系統11,以回應於開卡指令。例如,記憶體管理電路502會在建立邏輯位址-實體位址映射表之後回應於主機系統。
當開卡操作完成後,在記憶體儲存裝置10的使用過程中,記憶體管理電路502也會將對應於可複寫式非揮發性記憶體模組406的實體抹除單元410(0)~410(N)的使用資訊記錄在可複寫式非揮發性記憶體模組406中。
在本範例實施例中,當要對記憶體儲存裝置10再次執行開卡操作時,記憶體控制電路單元404(或記憶體管理電路502)會先記錄對應於可複寫式非揮發性記憶體模組406的實體抹除單元410(0)~410(N)的目前的使用資訊。使用資訊可包括記憶體控制電路單元404(或記憶體管理電路502)在管理可複寫式非揮發性記憶體模組406時會使用的各種資訊,例如,壞區塊資訊、抹除次數資訊、使用時間資訊或讀取次數資訊等。
更詳細地說,記憶體控制電路單元404(或記憶體管理電路502)可根據壞區塊資訊來建立壞區塊管理表,以記錄可複寫式非揮發性記憶體模組中的壞實體抹除單元,由此避免記憶體控制電路單元404(或記憶體管理電路502)存取已損壞的實體抹除單元。例如,在建立邏輯位址-實體位址映射表時可根據壞區塊管理表來避免將邏輯單元映射至已損壞的實體抹除單元。
抹除次數資訊是記錄可複寫式非揮發性記憶體模組406的實體抹除單元的抹除次數。具體而言,記憶體控制電路單元404(或記憶體管理電路502)可根據抹除次數資訊計算可複寫式非揮發性記憶體模組406的使用壽命以評估可複寫式非揮發性記憶體模組406的耗損程度,並且根據所計算的使用壽命來適時地提醒或警告使用者。例如,在使用壽命符合預設值時,發出警告訊息。再者,記憶體控制電路單元404(或記憶體管理電路502)也可根據抹除次數資訊來執行可複寫式非揮發性記憶體模組406的平均抹損(wear leveling)操作,以平均使用可複寫式非揮發性記憶體模組中的每個實體抹除單元,避免某些「特定」實體抹除單元因過度使用,導致抹除次數過大而造成儲存於其上的資料錯誤發生率提高以及老化速率增加。並且,也可避免某些「特定」實體抹除單元因抹除次數到達製造廠商保證的極限值,被標記成壞實體抹除單元,而不能繼續使用。此外,由於在程式化過程中,可複寫式非揮發性記憶體模組的記憶胞會隨著電子的多次的注入與移除而造成老化,導致電子寫入速度增加並造成臨界電壓分佈變寬。因此,在多次程式化後,記憶胞可能無法被正確地識別其儲存狀態,而產生錯誤位元。而記憶體控制電路單元404(或記憶體管理電路502)也可根據抹除次數資訊來調整可複寫式非揮發性記憶體模組的記憶胞的讀取電壓,以減少錯誤位元產生的機率。
使用時間資訊可記錄記憶體儲存裝置10的總使用時間。例如,使用時間資訊可記錄記憶體儲存裝置10每次從上電到斷電的經過時間,經過時間的總和即為總使用時間。此外,使用時間資訊也可記錄記憶體儲存裝置10從第一次上電後的經過時間以表示總使用時間。由於儲存在可複寫式非揮發性記憶體模組406中各實體抹除單元的資料,若長期不被搬移或更新,將會因電荷洩漏的現象,而改變原儲存的資料。記憶體控制電路單元404(或記憶體管理電路502)可根據使用時間資訊了解可複寫式非揮發性記憶體模組406中各實體抹除單元在這段時間內被使用的狀態,並且根據被使用的狀態來適時地提醒或警告使用者進行資料的搬移或更新,以防止資料的遺失。
另外,在對同一個實體程式化單元所儲存的資料進行多次讀取時,例如十萬至百萬次間的讀取次數,很有可能會對此實體程式化單元鄰近的實體程式化單元所儲存的資料造成影響,因此改變了鄰近的實體程式化單元所儲存的資料。而此類現象以本發明領域具有通常知識者慣稱為「讀取干擾」(read-disturb)。而在本範例實施例中,記憶體控制電路單元404(或記憶體管理電路502)還可根據讀取次數資訊來執行可複寫式非揮發性記憶體模組406的資料更新操作,以防止上述的讀取干擾現象。
記憶體控制電路單元404(或記憶體管理電路502)可根據讀取次數資訊,判斷每一個實體程式化單元被讀取的次數。並且,當某個實體程式化單元被讀取的次數達到一定次數時,記憶體控制電路單元404(或記憶體管理電路502)會對此實體程式化單元所屬的實體抹除單元執行資料更新操作,以對此實體抹除單元進行資料搬移與抹除。
具體而言,使用資訊可被儲存在可複寫式非揮發性記憶體模組406的至少其中一個實體抹除單元中,例如系統區的實體抹除單元。而記憶體控制電路單元404(或記憶體管理電路502)會從可複寫式非揮發性記憶體模組406中讀取使用資訊,並將所讀取的使用資訊寫入至可複寫式非揮發性記憶體模組406中至少一個未寫入資料的實體抹除單元(以下亦參考為第一實體抹除單元)中。在將使用資訊儲存至第一實體抹除單元之後,記憶體控制電路單元404(或記憶體管理電路502)會對第一實體抹除單元之外的至少部份的實體抹除單元進行初始化動作。例如,記憶體控制電路單元404(或記憶體管理電路502)可將實體抹除單元410(0)~410(N)中第一實體抹除單元之外的每一實體程式化單元位址的資料抹除為0×FF資料,並將韌體碼(firmware code)寫入至可複寫式非揮發性記憶體模組406中。此外,記憶體控制電路單元404(或記憶體管理電路502)也會依據儲存在第一實體抹除單元中的使用資訊建立韌體碼運行時所需的記憶體管理表,並根據所建立的記憶體管理表來操作該記憶體儲存裝置10。
記憶體管理表可包括用以存取可複寫式非揮發性記憶體模組406的實體抹除單元的邏輯位址-實體位址映射表。例如,記憶體控制電路單元404(或記憶體管理電路502)會依據壞區塊資訊,將未損壞的實體抹除單元關聯至使用區或閒置區,或以其他管理方式來管理實體抹除單元,本發明並不加以限制。再者,記憶體管理表也可包括根據抹除次數資訊所建立的抹除次數管理表、根據使用時間資訊所建立的使用時間管理表、以及根據讀取次數資訊所建立的讀取次數管理表等。抹除次數管理表及使用時間管理表可用以執行可複寫式非揮發性記憶體模組406的使用壽命計算、平均抹損操作或資料更新操作等管理。讀取次數管理表可用以執行可複寫式非揮發性記憶體模組406的資料更新操作。
圖8A及8B是根據一範例實施例所繪示之記憶體管理方法中將使用資訊寫入至可複寫式非揮發性記憶體模組中的示意圖。
請參考圖8A及8B,對應於可複寫式非揮發性記憶體模組406中的實體抹除單元410(0)~410(N)的使用資訊D1是儲存在實體抹除單元410(S)中。因此,記憶體控制電路單元404(或記憶體管理電路502)會先讀取儲存在實體抹除單元410(S)的使用資訊D1。並且,記憶體控制電路單元404(或記憶體管理電路502)會提取一個尚未寫入資料的實體抹除單元410(K)來將使用資訊D1寫入至實體抹除單元410(K)中,並為實體抹除單元410(K)標記辨識旗標F1,以記錄目前的使用資訊D1。
圖9是根據一範例實施例所繪示之記憶體管理方法中抹除實體抹除單元中的資料的示意圖。
請參考圖9,當要對可複寫式非揮發性記憶體模組406中的實體抹除單元執行抹除操作時,記憶體控制電路單元404(或記憶體管理電路502)會判斷每一個實體抹除單元是否已被標記辨識旗標F1以決定是否對其執行抹除操作。如圖9所示,記憶體控制電路單元404(或記憶體管理電路502)會判斷實體抹除單元410(K)被標記辨識旗標F1而不抹除儲存在實體抹除單元410(K)的資料(即使用資訊D1)。並且,記憶體控制電路單元404(或記憶體管理電路502)會判斷可複寫式非揮發性記憶體模組406中的其他實體抹除單元皆未被標記辨識旗標F1而抹除儲存在此些實體抹除單元的資料。
在本範例實施例中,當記憶體儲存裝置10接收到來自於主機系統的指令時,是藉由本身的韌體碼以進行本發明所提出的記憶體管理方法。而在另一範例實施例中,則可由主機系統11的記憶體管理單元408來指示記憶體控制電路單元404(或記憶體管理電路502)執行對應操作。例如,記憶體儲存裝置10需重新執行開卡操作並將記憶體儲存裝置10耦接至主機系統11時,主機系統11的記憶體管理單元408會傳送指令至記憶體儲存裝置10,使記憶體控制電路單元404(或記憶體管理電路502)根據記憶體管理單元408的指令執行對應操作並回應於主機系統11。在此另一範例實施例中,記憶體管理單元408會先傳送指示讀取使用資訊的讀取指令至記憶體儲存裝置10,而記憶體儲存裝置10的記憶體控制電路單元404(或記憶體管理電路502)會根據所接收的讀取指令從可複寫式非揮發性記憶體模組406中讀取使用資訊並回應於主機系統11。更進一步地,記憶體管理單元408會根據記憶體控制電路單元404(或記憶體管理電路502)的回應訊息下達其他指令,例如,主機系統11接收到記憶體控制電路單元404(或記憶體管理電路502)所傳送的讀取完成的回應訊息時,記憶體管理單元408會傳送指示將使用資訊寫入至可複寫式非揮發性記憶體模組406中的寫入指令至記憶體儲存裝置10,而記憶體儲存裝置10的記憶體控制電路單元404(或記憶體管理電路502)則根據所接收到的寫入指令將使用資訊寫入至可複寫式非揮發性記憶體模組406中尚未寫入資料的一個實體抹除單元中,且為寫入使用資訊的此實體抹除單元標記辨識旗標並回應於主機系統11。再者,當主機系統11接收到記憶體控制電路單元404(或記憶體管理電路502)所傳送的寫入完成的回應訊息時,記憶體管理單元408會傳送指示抹除不具辨識旗標的實體抹除單元的資料的抹除指令至記憶體儲存裝置10,而記憶體儲存裝置10的記憶體控制電路單元404(或記憶體管理電路502)則根據所接收到的抹除指令對可複寫式非揮發性記憶體模組406中不具辨識旗標的實體抹除單元執行抹除操作。除此之外,記憶體控制電路單元404(或記憶體管理電路502)也會根據記憶體管理單元408所傳送的更新韌體碼指令,將來自於主機系統11的更新韌體碼寫入至可複寫式非揮發性記憶體模組406中,以及根據所儲存的使用資訊建立記憶體管理表。並且,記憶體控制電路單元404(或記憶體管理電路502)會在完成相關操作後,傳送確認訊息以回應主機系統11。
圖10是根據一範例實施例所繪示之記憶體管理方法的流程圖。
請參考圖10,在步驟S1001中,記憶體控制電路單元404(或記憶體管理電路502)從主機系統11接收指令。
在步驟S1003中,記憶體控制電路單元404(或記憶體管理電路502)讀取對應於可複寫式非揮發性記憶體模組的實體抹除單元的使用資訊。使用資訊可包括記憶體控制電路單元404(或記憶體管理電路502)在管理可複寫式非揮發性記憶體模組406時會使用的各種資訊,例如,壞區塊資訊、抹除次數資訊、使用時間資訊或讀取次數資訊等。使用資訊已於前述內容中進行說明,在此不再贅述。
在步驟S1005中,記憶體控制電路單元404(或記憶體管理電路502)將使用資訊寫入至可複寫式非揮發性記憶體模組的至少一個實體抹除單元(以下亦參考為第一實體抹除單元)中,並為第一實體抹除單元標記辨識旗標。具體而言,記憶體控制電路單元404(或記憶體管理電路502)會搜尋可複寫式非揮發性記憶體模組中未程式化資料的實體抹除單元來寫入所讀取的使用資訊。在本範例實施例中,用來寫入使用資訊的實體抹除單元可為閒置區中未程式化資料的實體抹除單元。然而,在其他範例實施例中,用來寫入使用資訊的實體抹除單元也可為取代區或系統區中未程式化資料的實體抹除單元,本發明並不加以限制。另外,記憶體控制電路單元404(或記憶體管理電路502)會為第一實體抹除單元標記辨識旗標,例如,將辨識旗標標記為1來表示第一實體抹除單元是用來寫入使用資訊的實體抹除單元或為一防止被抹除或防止被寫入的實體抹除單元。然而,辨識旗標也可標記為0或用更多的位元來表示,本發明並不加以限制。
在步驟S1007中,記憶體控制電路單元404(或記憶體管理電路502)會抹除不具辨識旗標的實體抹除單元,例如可複寫式非揮發性記憶體模組中第一實體抹除單元之外的實體抹除單元的資料。舉例而言,除了用來寫入使用資訊的第一實體抹除單元之外,記憶體控制電路單元404(或記憶體管理電路502)會對可複寫式非揮發性記憶體模組中的至少部份或所有其他實體抹除單元執行抹除操作,以抹除儲存在此些實體抹除單元中的資料。也就是說,寫入使用資訊的第一實體抹除單元在執行抹除操作的過程中會受到保護,必須下達特殊指令才可抹除第一實體抹除單元中所儲存的資料。更詳細地說,記憶體控制電路單元404(或記憶體管理電路502)會根據辨識旗標來判斷要執行抹除操作的實體抹除單元。例如,倘若辨識旗標被標記為1表示為用來寫入使用資訊的實體抹除單元,則記憶體控制電路單元404(或記憶體管理電路502)不會根據一般操作指令對辨識旗標被標記為1的實體抹除單元執行抹除操作。
在步驟S1009中,記憶體控制電路單元404(或記憶體管理電路502)會將來自於主機系統的韌體碼程式化至可複寫式非揮發性記憶體模組中。此韌體碼可為製造商提供的更新韌體碼。
在步驟S1011中,記憶體控制電路單元404(或記憶體管理電路502)會根據寫入至第一實體抹除單元的使用資訊來建立記憶體管理表。具體而言,記憶體控制電路單元404(或記憶體管理電路502)會從第一實體抹除單元讀取使用資訊來建立記憶體管理表,並根據記憶體管理表來操作記憶體儲存裝置。也就是說,記憶體控制電路單元404(或記憶體管理電路502)會以第一實體抹除單元中所儲存的使用資訊作為目前的使用資訊來建立記憶體管理表以管理可複寫式非揮發性記憶體模組,例如,將記憶體管理表載入至緩衝記憶體以進行資料存取及維護。
此外,在執行抹除操作之後,記憶體控制電路單元404(或記憶體管理電路502)也會將與其它與記憶體儲存裝置的運作有關的資料(例如,系統資訊等)儲存至可複寫式非揮發性記憶體模組中。
圖11是根據另一範例實施例所繪示之記憶體管理方法的流程圖。圖11中的步驟S1001~S1009與圖10中相同標號的步驟相同,因此在圖11中將不再贅述。以下僅針對圖11與圖10不同之處進行說明。
請參考圖11,記憶體控制電路單元404(或記憶體管理電路502)將韌體碼程式化至可複寫式非揮發性記憶體模組中之後,在步驟S1101中,記憶體控制電路單元404(或記憶體管理電路502)會判斷是否使用儲存在第一實體抹除單元中的使用資訊。記憶體控制電路單元404(或記憶體管理電路502)可根據來自於主機系統的指令來決定是否使用儲存在第一實體抹除單元中的使用資訊。例如,在主機系統所下達的指令中會指示使用儲存在第一實體抹除單元中的使用資訊。
倘若判斷要使用儲存在第一實體抹除單元中的使用資訊,在步驟S1103中,記憶體控制電路單元404(或記憶體管理電路502)會根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表。換句話說,記憶體控制電路單元404(或記憶體管理電路502)會以儲存在第一實體抹除單元中的使用資訊作為目前的使用資訊。
倘若判斷不使用儲存在第一實體抹除單元中的使用資訊,在步驟S1105中,記憶體控制電路單元404(或記憶體管理電路502)會建立新的記憶體管理表。
綜上所述,本發明的記憶體管理方法與系統及使用此方法的記憶體儲存裝置能夠在對可複寫式非揮發性記憶體模組執行格式化操作時,保留既有的使用資訊,再利用既有的使用資訊對記憶體儲存裝置的可複寫式非揮發性記憶體模組進行管理的,由此避免因遺失既有的使用資訊所造成的管理問題。
雖然本發明已以實施例揭露如上,然其並非用以限定本發明,任何所屬技術領域中具有通常知識者,在不脫離本發明的精神和範圍內,當可作些許的更動與潤飾,故本發明的保護範圍當視後附的申請專利範圍所界定者為準。
10‧‧‧記憶體儲存裝置
11‧‧‧主機系統
12‧‧‧輸入/輸出(I/O)裝置
110‧‧‧系統匯流排
111‧‧‧處理器
112‧‧‧隨機存取記憶體(RAM)
113‧‧‧唯讀記憶體(ROM)
114‧‧‧資料傳輸介面
20‧‧‧主機板
204‧‧‧無線記憶體儲存裝置
205‧‧‧全球定位系統模組
206‧‧‧網路介面卡
207‧‧‧無線傳輸裝置
208‧‧‧鍵盤
209‧‧‧螢幕
210‧‧‧喇叭
30‧‧‧記憶體儲存裝置
31‧‧‧主機系統
32‧‧‧SD卡
33‧‧‧CF卡
34‧‧‧嵌入式儲存裝置
341‧‧‧嵌入式多媒體卡
342‧‧‧嵌入式多晶片封裝儲存裝置
402‧‧‧連接介面單元
404‧‧‧記憶體控制電路單元
406‧‧‧可複寫式非揮發性記憶體模組
408‧‧‧記憶體管理單元
410(0)~410(N)‧‧‧實體抹除單元
502‧‧‧記憶體管理電路
504‧‧‧主機介面
506‧‧‧記憶體介面
508‧‧‧緩衝記憶體
510‧‧‧電源管理電路
512‧‧‧錯誤檢查與校正電路
602‧‧‧資料區
604‧‧‧閒置區
606‧‧‧系統區
608‧‧‧取代區
LBA(0)~LBA(H)‧‧‧邏輯單元
LZ(0)~LZ(M)‧‧‧邏輯區域
D1‧‧‧使用資訊
F1‧‧‧辨識旗標
S1001‧‧‧接收指令的步驟
S1003‧‧‧讀取對應於可複寫式非揮發性記憶體模組的實體抹除單元的使用資訊的步驟
S1005‧‧‧將使用資訊寫入至可複寫式非揮發性記憶體模組的第一實體抹除單元中並為第一實體抹除單元標記辨識旗標的步驟
S1007‧‧‧抹除不具辨識旗標的實體抹除單元的步驟
S1009‧‧‧將來自於主機系統的韌體碼程式化至可複寫式非揮發性記憶體模組中的步驟
S1011‧‧‧根據寫入至第一實體抹除單元的使用資訊來建立記憶體管理表的步驟
S1101‧‧‧判斷是否使用儲存在第一實體抹除單元中的使用資訊的步驟
S1103‧‧‧根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表的步驟
S1105‧‧‧建立新的記憶體管理表的步驟
11‧‧‧主機系統
12‧‧‧輸入/輸出(I/O)裝置
110‧‧‧系統匯流排
111‧‧‧處理器
112‧‧‧隨機存取記憶體(RAM)
113‧‧‧唯讀記憶體(ROM)
114‧‧‧資料傳輸介面
20‧‧‧主機板
204‧‧‧無線記憶體儲存裝置
205‧‧‧全球定位系統模組
206‧‧‧網路介面卡
207‧‧‧無線傳輸裝置
208‧‧‧鍵盤
209‧‧‧螢幕
210‧‧‧喇叭
30‧‧‧記憶體儲存裝置
31‧‧‧主機系統
32‧‧‧SD卡
33‧‧‧CF卡
34‧‧‧嵌入式儲存裝置
341‧‧‧嵌入式多媒體卡
342‧‧‧嵌入式多晶片封裝儲存裝置
402‧‧‧連接介面單元
404‧‧‧記憶體控制電路單元
406‧‧‧可複寫式非揮發性記憶體模組
408‧‧‧記憶體管理單元
410(0)~410(N)‧‧‧實體抹除單元
502‧‧‧記憶體管理電路
504‧‧‧主機介面
506‧‧‧記憶體介面
508‧‧‧緩衝記憶體
510‧‧‧電源管理電路
512‧‧‧錯誤檢查與校正電路
602‧‧‧資料區
604‧‧‧閒置區
606‧‧‧系統區
608‧‧‧取代區
LBA(0)~LBA(H)‧‧‧邏輯單元
LZ(0)~LZ(M)‧‧‧邏輯區域
D1‧‧‧使用資訊
F1‧‧‧辨識旗標
S1001‧‧‧接收指令的步驟
S1003‧‧‧讀取對應於可複寫式非揮發性記憶體模組的實體抹除單元的使用資訊的步驟
S1005‧‧‧將使用資訊寫入至可複寫式非揮發性記憶體模組的第一實體抹除單元中並為第一實體抹除單元標記辨識旗標的步驟
S1007‧‧‧抹除不具辨識旗標的實體抹除單元的步驟
S1009‧‧‧將來自於主機系統的韌體碼程式化至可複寫式非揮發性記憶體模組中的步驟
S1011‧‧‧根據寫入至第一實體抹除單元的使用資訊來建立記憶體管理表的步驟
S1101‧‧‧判斷是否使用儲存在第一實體抹除單元中的使用資訊的步驟
S1103‧‧‧根據儲存在第一實體抹除單元中的使用資訊建立記憶體管理表的步驟
S1105‧‧‧建立新的記憶體管理表的步驟
圖1是根據一範例實施例所繪示的主機系統、記憶體儲存裝置及輸入/輸出(I/O)裝置的示意圖。 圖2是根據另一範例實施例所繪示的主機系統、記憶體儲存裝置及輸入/輸出(I/O)裝置的示意圖。 圖3是根據本發明範例實施例所繪示的主機系統與記憶體儲存裝置的示意圖。 圖4是根據一範例實施例所繪示的主機系統與記憶體儲存裝置的概要方塊圖。 圖5是根據一範例實施例所繪示之記憶體控制電路單元的概要方塊圖。 圖6與圖7是根據一範例實施例所繪示之管理實體抹除單元的範例示意圖。 圖8A及8B是根據一範例實施例所繪示之記錄目前的使用資訊的示意圖。 圖9是根據一範例實施例所繪示之抹除實體抹除單元中的資料的示意圖。 圖10是根據一範例實施例所繪示之記憶體管理方法的流程圖。 圖11是根據另一範例實施例所繪示之記憶體管理方法的流程圖。
S1001‧‧‧接收指令的步驟
S1003‧‧‧讀取對應於可複寫式非揮發性記憶體模組的實體抹除單元的使用資訊的步驟
S1005‧‧‧將使用資訊寫入至可複寫式非揮發性記憶體模組的第一實體抹除單元中並為第一實體抹除單元標記辨識旗標的步驟
S1007‧‧‧抹除不具辨識旗標的實體抹除單元的步驟
S1009‧‧‧將來自於主機系統的韌體碼程式化至可複寫式非揮發性記憶體模組中的步驟
S1011‧‧‧根據寫入至第一實體抹除單元的使用資訊來建立記憶體管理表的步驟
Claims (32)
- 一種記憶體管理方法,用於一記憶體儲存裝置,其中該記憶體儲存裝置具有一可複寫式非揮發性記憶體模組,該可複寫式非揮發性記憶體模組具有多個實體抹除單元,該記憶體管理方法包括: 從一主機系統接收一指令; 根據該指令從該可複寫式非揮發性記憶體模組中讀取對應於該些實體抹除單元的一使用資訊; 將該使用資訊寫入至該些實體抹除單元之中的一第一實體抹除單元中,並為該第一實體抹除單元標記一辨識旗標; 根據該辨識旗標抹除該些實體抹除單元中除了該第一實體抹除單元以外的至少部份的實體抹除單元的資料;以及 根據儲存在該第一實體抹除單元中的該使用資訊建立一記憶體管理表,並根據該記憶體管理表來操作該記憶體儲存裝置。
- 如申請專利範圍第1項所述的記憶體管理方法,其中根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表的步驟是在抹除該些實體抹除單元中除了該第一實體抹除單元以外的該至少部份的實體抹除單元的資料的步驟之後執行。
- 如申請專利範圍第2項所述的記憶體管理方法,更包括: 在該些實體抹除單元中搜尋一未程式化資料的實體抹除單元以作為該第一實體抹除單元;以及 倘若該些實體抹除單元中不存在該未程式化資料的實體抹除單元,將該記憶體儲存裝置宣告為一寫入保護狀態。
- 如申請專利範圍第2項所述的記憶體管理方法,更包括: 將來自於該主機系統的一韌體碼寫入至該可複寫式非揮發性記憶體模組中。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該指令為一開卡指令,該開卡指令指示對該記憶體儲存裝置執行一開卡操作,其中根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表的步驟包括: 根據儲存在該第一實體抹除單元中的該使用資訊建立一邏輯位址-實體位址映射表以回應於該開卡指令。
- 如申請專利範圍第1項所述的記憶體管理方法,其中根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表的步驟包括: 倘若判斷要使用儲存在該第一實體抹除單元中的該使用資訊,根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表;以及 倘若判斷不使用儲存在該第一實體抹除單元中的該使用資訊,建立一新的記憶體管理表。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該使用資訊包括一壞區塊資訊,其中該記憶體管理方法更包括: 根據該壞區塊資訊建立一壞區塊管理表用以避免存取已損壞的實體抹除單元。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該使用資訊包括一抹除次數資訊,其中該記憶體管理方法更包括: 根據該抹除次數資訊計算該可複寫式非揮發性記憶體模組的一使用壽命並根據該使用壽命決定是否發出一警告訊息,或根據該抹除次數資訊執行該可複寫式非揮發性記憶體模組的一平均抹損操作。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該使用資訊包括一使用時間資訊,其中該記憶體管理方法更包括: 根據該使用時間資訊計算該可複寫式非揮發性記憶體模組的一使用壽命,或根據該使用時間資訊執行該可複寫式非揮發性記憶體模組的一資料更新操作。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該使用資訊包括一讀取次數資訊,其中該記憶體管理方法更包括: 根據該讀取次數資訊判斷至少一實體程式化單元的一被讀取次數,並且倘若該至少一實體程式化單元的該被讀取次數達到一讀取次數門檻值,對該至少一實體程式化單元所屬的一實體抹除單元執行一資料更新操作。
- 如申請專利範圍第1項所述的記憶體管理方法,其中該記憶體管理表包括一邏輯位址-實體位址映射表、一抹除次數管理表、一使用時間管理表及一讀取次數管理表,其中根據該記憶體管理表來操作該記憶體儲存裝置的步驟包括: 根據該邏輯位址-實體位址映射表存取該些實體抹除單元,並根據該抹除次數管理表及該使用時間管理表計算該可複寫式非揮發性記憶體模組的一使用壽命及執行該可複寫式非揮發性記憶體模組的一平均抹損操作,以及根據該使用時間管理表及該讀取次數管理表執行該可複寫式非揮發性記憶體模組的一資料更新操作。
- 一種記憶體儲存裝置,包括: 一連接介面單元,耦接至一主機系統; 一可複寫式非揮發性記憶體模組,具有多個實體抹除單元;以及 一記憶體控制電路單元,耦接至該連接介面單元與該可複寫式非揮發性記憶體模組,並從該主機系統接收一指令, 其中,該記憶體控制電路單元根據該指令從該可複寫式非揮發性記憶體模組中讀取對應於該些實體抹除單元的一使用資訊, 其中,該記憶體控制電路單元將該使用資訊寫入至該些實體抹除單元之中的一第一實體抹除單元中,並為該第一實體抹除單元標示一辨識旗標, 其中,該記憶體控制電路單元根據該辨識旗標抹除該些實體抹除單元中除了該第一實體抹除單元以外的至少部份的實體抹除單元的資料, 其中,該記憶體控制電路單元根據儲存在該第一實體抹除單元中的該使用資訊建立一記憶體管理表,並根據該記憶體管理表來操作該記憶體儲存裝置。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該記憶體控制電路單元是在抹除該些實體抹除單元中除了該第一實體抹除單元以外的該至少部份的實體抹除單元的資料之後,根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表。
- 如申請專利範圍第13項所述的記憶體儲存裝置,其中該記憶體控制電路單元更在該些實體抹除單元中搜尋一未程式化資料的實體抹除單元以作為該第一實體抹除單元, 其中,倘若該些實體抹除單元中不存在該未程式化資料的實體抹除單元,該記憶體控制電路單元將該記憶體儲存裝置宣告為一寫入保護狀態。
- 如申請專利範圍第13項所述的記憶體儲存裝置,其中該記憶體控制電路單元將來自於該主機系統的一韌體碼寫入至該可複寫式非揮發性記憶體模組中。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該指令為一開卡指令,該開卡指令指示對該記憶體儲存裝置執行一開卡操作, 其中,該記憶體控制電路單元根據儲存在該第一實體抹除單元中的該使用資訊建立一邏輯位址-實體位址映射表以回應於該開卡指令。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中倘若該記憶體控制電路單元判斷要使用儲存在該第一實體抹除單元中的該使用資訊,該記憶體控制電路單元根據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表, 其中倘若該記憶體控制電路單元判斷不使用儲存在該第一實體抹除單元中的該使用資訊,該記憶體控制電路單元建立一新的記憶體管理表。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該使用資訊包括一壞區塊資訊, 其中該記憶體控制電路單元根據該壞區塊資訊建立一壞區塊管理表。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該使用資訊包括一抹除次數資訊, 其中該記憶體控制電路單元根據該抹除次數資訊計算該可複寫式非揮發性記憶體模組的一使用壽命並根據該使用壽命決定是否發出一警告訊息,或根據該抹除次數資訊執行該可複寫式非揮發性記憶體模組的一平均抹損操作。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該使用資訊包括一使用時間資訊, 其中該記憶體控制電路單元根據該使用時間資訊計算該可複寫式非揮發性記憶體模組的一使用壽命,或根據該使用時間資訊執行該可複寫式非揮發性記憶體模組的一資料更新操作。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該使用資訊包括一讀取次數資訊, 其中該記憶體控制電路單元根據該讀取次數資訊判斷至少一實體程式化單元的一被讀取次數,並且倘若該至少一實體程式化單元的該被讀取次數達到一讀取次數門檻值,對該至少一實體程式化單元所屬的一實體抹除單元執行一資料更新操作。
- 如申請專利範圍第12項所述的記憶體儲存裝置,其中該記憶體管理表包括一邏輯位址-實體位址映射表、一抹除次數管理表、一使用時間管理表及一讀取次數管理表,其中該記憶體控制電路單元根據該邏輯位址-實體位址映射表存取該些實體抹除單元,並根據該抹除次數管理表及該使用時間管理表計算該可複寫式非揮發性記憶體模組的一使用壽命及執行該可複寫式非揮發性記憶體模組的一平均抹損操作,以及根據該使用時間管理表及該讀取次數管理表執行該可複寫式非揮發性記憶體模組的一資料更新操作。
- 一種記憶體管理系統,包括: 一主機系統,具有一記憶體管理單元; 一記憶體儲存裝置,包括: 一連接介面單元,耦接至該主機系統; 一可複寫式非揮發性記憶體模組,具有多個實體抹除單元;以及 一記憶體控制電路單元,耦接至該連接介面單元與該可複寫式非揮發性記憶體模組, 其中,該記憶體管理單元傳送一讀取指令至該記憶體儲存裝置,並且該記憶體控制電路單元根據該讀取指令從該可複寫式非揮發性記憶體模組中讀取對應於該些實體抹除單元的一使用資訊以回應於該讀取指令, 其中,該記憶體管理單元傳送一寫入指令至該記憶體儲存裝置,並且該記憶體控制電路單元更根據該寫入指令寫入該使用資訊至該些實體抹除單元中的一第一實體抹除單元中以及為該第一實體抹除單元標記一辨識旗標以回應於該寫入指令, 其中,該記憶體管理單元傳送一抹除指令至該記憶體儲存裝置,並且該記憶體控制電路單元根據該抹除指令依據該辨識旗標抹除該些實體抹除單元中除了該第一實體抹除單元以外的至少部份的實體抹除單元的資料, 其中,該記憶體管理單元傳送一建立表格指令至該記憶體儲存裝置,並且該記憶體控制電路單元根據該建立表格指令依據儲存在該第一實體抹除單元中的該使用資訊建立一記憶體管理表,並根據該記憶體管理表來操作該記憶體儲存裝置。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該記憶體管理單元是在該記憶體控制電路單元抹除該些實體抹除單元中除了該第一實體抹除單元以外的該至少部份的實體抹除單元的資料之後,傳送該建立表格指令至該記憶體儲存裝置。
- 如申請專利範圍第24項所述的記憶體管理系統,其中該記憶體控制電路單元更根據該寫入指令在該些實體抹除單元中搜尋一未程式化資料的實體抹除單元以作為該第一實體抹除單元, 其中,倘若該些實體抹除單元中不存在該未程式化資料的實體抹除單元,該記憶體控制電路單元回傳一第一錯誤訊息至該主機系統以回應於該寫入指令, 其中,該記憶體管理單元根據該第一錯誤訊息傳送一寫入保護指令至該記憶體儲存裝置,該記憶體控制電路單元根據該寫入保護指令將該記憶體儲存裝置宣告為一寫入保護狀態以回應於該寫入保護指令。
- 如申請專利範圍第24項所述的記憶體管理系統,其中該記憶體管理單元傳送一更新韌體碼指令至該記憶體儲存裝置,並且該記憶體控制電路單元根據該更新韌體碼指令將來自於該主機系統的一韌體碼寫入至該可複寫式非揮發性記憶體模組中。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該記憶體控制電路單元判斷從該主機系統接收的該建立表格指令是否指示要使用儲存在該第一實體抹除單元中的該使用資訊, 其中,倘若該記憶體控制電路單元判斷該建立表格指令指示使用儲存在該第一實體抹除單元中的該使用資訊,該記憶體控制電路單元依據儲存在該第一實體抹除單元中的該使用資訊建立該記憶體管理表, 其中,倘若該記憶體控制電路單元判斷該建立表格指令指示不使用儲存在該第一實體抹除單元中的該使用資訊,該記憶體控制電路單元建立一新的記憶體管理表。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該使用資訊包括一壞區塊資訊, 其中該記憶體控制電路單元根據該壞區塊資訊建立一壞區塊管理表。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該使用資訊包括一抹除次數資訊, 其中該記憶體控制電路單元根據該抹除次數資訊計算該可複寫式非揮發性記憶體模組的一使用壽命並根據該使用壽命決定是否發出一警告訊息,或根據該抹除次數資訊執行該可複寫式非揮發性記憶體模組的一平均抹損操作。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該使用資訊包括一使用時間資訊, 其中該記憶體控制電路單元根據該使用時間資訊計算該可複寫式非揮發性記憶體模組的一使用壽命,或根據該使用時間資訊執行該可複寫式非揮發性記憶體模組的一資料更新操作。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該使用資訊包括一讀取次數資訊, 其中該記憶體控制電路單元根據該讀取次數資訊判斷至少一實體程式化單元的一被讀取次數,並且倘若該至少一實體程式化單元的該被讀取次數達到一讀取次數門檻值,對該至少一實體程式化單元所屬的一實體抹除單元執行一資料更新操作。
- 如申請專利範圍第23項所述的記憶體管理系統,其中該記憶體管理表包括一邏輯位址-實體位址映射表、一抹除次數管理表、一使用時間管理表及一讀取次數管理表,其中該記憶體控制電路單元根據該邏輯位址-實體位址映射表存取該些實體抹除單元,並根據該抹除次數管理表及該使用時間管理表計算該可複寫式非揮發性記憶體模組的一使用壽命及執行該可複寫式非揮發性記憶體模組的一平均抹損操作,以及根據該使用時間管理表及該讀取次數管理表執行該可複寫式非揮發性記憶體模組的一資料更新操作。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW104138377A TWI551991B (zh) | 2015-11-20 | 2015-11-20 | 記憶體管理方法與系統及其記憶體儲存裝置 |
US15/000,021 US9940021B2 (en) | 2015-11-20 | 2016-01-18 | Method and system for memory management and memory storage device thereof |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW104138377A TWI551991B (zh) | 2015-11-20 | 2015-11-20 | 記憶體管理方法與系統及其記憶體儲存裝置 |
Publications (2)
Publication Number | Publication Date |
---|---|
TWI551991B true TWI551991B (zh) | 2016-10-01 |
TW201719412A TW201719412A (zh) | 2017-06-01 |
Family
ID=57848112
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW104138377A TWI551991B (zh) | 2015-11-20 | 2015-11-20 | 記憶體管理方法與系統及其記憶體儲存裝置 |
Country Status (2)
Country | Link |
---|---|
US (1) | US9940021B2 (zh) |
TW (1) | TWI551991B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI634561B (zh) * | 2017-03-24 | 2018-09-01 | 群聯電子股份有限公司 | 資料保護方法、記憶體儲存裝置及記憶體控制電路單元 |
TWI648628B (zh) * | 2017-03-09 | 2019-01-21 | 上海寶存信息科技有限公司 | 避免讀取擾動的資料搬移方法以及使用該方法的裝置 |
CN112306381A (zh) * | 2019-08-01 | 2021-02-02 | 旺宏电子股份有限公司 | 存储器装置以及存储器的数据存取方法 |
TWI737273B (zh) * | 2017-06-22 | 2021-08-21 | 美商美光科技公司 | 用於操作一記憶體之方法、記憶體設備、及電子記憶體設備 |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10445195B2 (en) * | 2017-08-07 | 2019-10-15 | Micron Technology, Inc. | Performing data restore operations in memory |
JP2019101446A (ja) * | 2017-11-28 | 2019-06-24 | ルネサスエレクトロニクス株式会社 | 半導体装置及びそれを備えた半導体システム |
US10552145B2 (en) * | 2017-12-12 | 2020-02-04 | Cypress Semiconductor Corporation | Memory devices, systems, and methods for updating firmware with single memory device |
TWI753761B (zh) * | 2021-01-27 | 2022-01-21 | 慧榮科技股份有限公司 | 記憶體裝置啟動資訊還原方法及其系統 |
CN114968066A (zh) * | 2021-02-19 | 2022-08-30 | 瑞昱半导体股份有限公司 | 用于快闪存储器中进行故障区块管理的方法与装置 |
JP2022144449A (ja) * | 2021-03-19 | 2022-10-03 | キオクシア株式会社 | メモリシステム、メモリシステムの制御方法及びホストデバイス |
CN114912156B (zh) * | 2022-06-02 | 2023-06-23 | 汇钜电科(东莞)实业有限公司 | 一种u盘使用情况和信息安全的智能管理设备 |
CN116880781B (zh) * | 2023-09-08 | 2023-12-26 | 合肥康芯威存储技术有限公司 | 一种存储设备及其控制方法 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5956473A (en) * | 1996-11-25 | 1999-09-21 | Macronix International Co., Ltd. | Method and system for managing a flash memory mass storage system |
US20090070654A1 (en) * | 2006-02-09 | 2009-03-12 | International Business Machines Corporation | Design Structure For A Processor System With Background Error Handling Feature |
US20130019142A1 (en) * | 2011-07-12 | 2013-01-17 | Phison Electronics Corp. | Memory storage device, memory controller thereof, and method for programming data thereof |
US20130111301A1 (en) * | 2011-11-02 | 2013-05-02 | Phison Electronics Corp. | Block management method, memory controller and memory storage device thereof |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7831778B2 (en) * | 2006-03-30 | 2010-11-09 | Silicon Image, Inc. | Shared nonvolatile memory architecture |
US20090313420A1 (en) * | 2008-06-13 | 2009-12-17 | Nimrod Wiesz | Method for saving an address map in a memory device |
US9547589B2 (en) * | 2008-06-18 | 2017-01-17 | Super Talent Technology, Corp. | Endurance translation layer (ETL) and diversion of temp files for reduced flash wear of a super-endurance solid-state drive |
US8612718B2 (en) * | 2009-08-19 | 2013-12-17 | Seagate Technology Llc | Mapping alignment |
US9311229B2 (en) * | 2011-03-29 | 2016-04-12 | Blackberry Limited | System and method for managing flash memory |
US8793429B1 (en) * | 2011-06-03 | 2014-07-29 | Western Digital Technologies, Inc. | Solid-state drive with reduced power up time |
US20150339195A1 (en) * | 2014-05-23 | 2015-11-26 | Sandisk Technologies Inc. | Method and system for secure system recovery |
US9652381B2 (en) * | 2014-06-19 | 2017-05-16 | Sandisk Technologies Llc | Sub-block garbage collection |
KR102365269B1 (ko) * | 2015-04-13 | 2022-02-22 | 삼성전자주식회사 | 데이터 스토리지 및 그것의 동작 방법 |
-
2015
- 2015-11-20 TW TW104138377A patent/TWI551991B/zh active
-
2016
- 2016-01-18 US US15/000,021 patent/US9940021B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5956473A (en) * | 1996-11-25 | 1999-09-21 | Macronix International Co., Ltd. | Method and system for managing a flash memory mass storage system |
US20090070654A1 (en) * | 2006-02-09 | 2009-03-12 | International Business Machines Corporation | Design Structure For A Processor System With Background Error Handling Feature |
US20130019142A1 (en) * | 2011-07-12 | 2013-01-17 | Phison Electronics Corp. | Memory storage device, memory controller thereof, and method for programming data thereof |
US20130111301A1 (en) * | 2011-11-02 | 2013-05-02 | Phison Electronics Corp. | Block management method, memory controller and memory storage device thereof |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI648628B (zh) * | 2017-03-09 | 2019-01-21 | 上海寶存信息科技有限公司 | 避免讀取擾動的資料搬移方法以及使用該方法的裝置 |
TWI634561B (zh) * | 2017-03-24 | 2018-09-01 | 群聯電子股份有限公司 | 資料保護方法、記憶體儲存裝置及記憶體控制電路單元 |
TWI737273B (zh) * | 2017-06-22 | 2021-08-21 | 美商美光科技公司 | 用於操作一記憶體之方法、記憶體設備、及電子記憶體設備 |
CN112306381A (zh) * | 2019-08-01 | 2021-02-02 | 旺宏电子股份有限公司 | 存储器装置以及存储器的数据存取方法 |
Also Published As
Publication number | Publication date |
---|---|
US9940021B2 (en) | 2018-04-10 |
TW201719412A (zh) | 2017-06-01 |
US20170147216A1 (en) | 2017-05-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI551991B (zh) | 記憶體管理方法與系統及其記憶體儲存裝置 | |
TWI592800B (zh) | 記憶體管理方法及使用所述方法的儲存控制器 | |
TWI483111B (zh) | 資料儲存方法、記憶體控制器與記憶體儲存裝置 | |
TWI587304B (zh) | 記憶體管理方法、記憶體控制電路單元與記憶體儲存裝置 | |
TWI480733B (zh) | 資料寫入方法、記憶體控制器與記憶體儲存裝置 | |
US10860247B2 (en) | Data writing method and storage controller | |
TWI592799B (zh) | 映射表更新方法、記憶體控制電路單元及記憶體儲存裝置 | |
TWI490871B (zh) | 防止讀取干擾的方法、記憶體控制電路單元與記憶體儲存裝置 | |
TWI591482B (zh) | 資料保護方法、記憶體控制電路單元及記憶體儲存裝置 | |
TWI489466B (zh) | 記憶體抹除方法、記憶體控制器與記憶體儲存裝置 | |
TWI582776B (zh) | 資料寫入方法、記憶體控制電路單元與記憶體儲存裝置 | |
TWI656531B (zh) | 平均磨損方法、記憶體控制電路單元與記憶體儲存裝置 | |
TWI607309B (zh) | 記憶體管理方法、記憶體控制電路單元與記憶體儲存裝置 | |
TWI486765B (zh) | 記憶體管理方法、記憶體控制器與記憶體儲存裝置 | |
TW201945927A (zh) | 資料寫入方法、記憶體控制電路單元以及記憶體儲存裝置 | |
TW201409230A (zh) | 系統資料儲存方法、記憶體控制器與記憶體儲存裝置 | |
TWI591640B (zh) | 記憶體管理方法、記憶體控制電路單元與記憶體儲存裝置 | |
CN111078146B (zh) | 存储器管理方法、存储器存储装置及存储器控制电路单元 | |
TWI509615B (zh) | 資料儲存方法、記憶體控制器與記憶體儲存裝置 | |
TWI616807B (zh) | 資料寫入方法以及儲存控制器 | |
CN107045890B (zh) | 数据保护方法、存储器控制电路单元及存储器存储装置 | |
CN106814968B (zh) | 存储器管理方法与系统及其存储器存储装置 | |
TWI651650B (zh) | 記憶體管理方法及使用所述方法的儲存控制器 | |
TW202008166A (zh) | 記憶體管理方法以及儲存控制器 | |
TWI550625B (zh) | 記憶體管理方法、記憶體儲存裝置及記憶體控制電路單元 |