CN104699417A - 数据储存装置以及其数据存取方法 - Google Patents

数据储存装置以及其数据存取方法 Download PDF

Info

Publication number
CN104699417A
CN104699417A CN201410041097.0A CN201410041097A CN104699417A CN 104699417 A CN104699417 A CN 104699417A CN 201410041097 A CN201410041097 A CN 201410041097A CN 104699417 A CN104699417 A CN 104699417A
Authority
CN
China
Prior art keywords
mentioned
page
subpage frame
data
spare blocks
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201410041097.0A
Other languages
English (en)
Other versions
CN104699417B (zh
Inventor
萧力硕
郑张铠
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Silicon Motion Inc
Original Assignee
Silicon Motion Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Silicon Motion Inc filed Critical Silicon Motion Inc
Publication of CN104699417A publication Critical patent/CN104699417A/zh
Application granted granted Critical
Publication of CN104699417B publication Critical patent/CN104699417B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding 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/1068Adding 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 sector programmable memories, e.g. flash disk
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding 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/1012Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices using codes or arrangements adapted for a specific type of error
    • G06F11/1016Error in accessing a memory location, i.e. addressing error
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1016Performance improvement
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1041Resource optimization
    • G06F2212/1044Space efficiency improvement
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/72Details relating to flash memory management
    • G06F2212/7201Logical to physical mapping or translation of blocks or pages
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/72Details relating to flash memory management
    • G06F2212/7202Allocation control and policies
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/72Details relating to flash memory management
    • G06F2212/7207Details relating to flash memory management management of metadata or control data

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)
  • Computer Security & Cryptography (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明提供一种数据储存装置以及其数据存取方法。该数据储存装置包括一快闪存储器以及一控制器。快闪存储器包括多个区块,并且每一区块包括多个页面,其中每一页面具有多个子页面以及多个备用区块,每一备用区块用以储存一保留信息,保留信息分别相应于每一子页面。控制器用以根据保留信息对子页面进行存取。

Description

数据储存装置以及其数据存取方法
技术领域
本发明是关于一种数据储存装置,特别是关于可对页面进行存取的数据储存装置。
背景技术
快闪存储器为一种可以被电抹除并且重新写入的非易失性存储器,并且主要是应用在存储卡、USB随身碟、eMMC以及固态硬盘(Solid-State Disk)中,借以作为一般的储存与电脑装置和数字产品间的数据的转运。
快闪存储器包括众多的存储区块(block),并且每一存储区块具有多个用以储存数据的储存页面(page)。快闪存储器是以存储区块为单元进行抹除,而以储存页面为单位进行写入。当快闪存储器接收到将区块全部抹除的命令时,快闪存储器会逐一对每一区块中的每一页面进行抹除的动作。当快闪存储器需要更新页面中的部分数据时,快闪存储器需要将原本页面中的数据读出,并将更新的数据以及原页面不需更新的数据整合后,写入另一个实体页面中。
发明内容
本发明提供一种数据储存装置。数据储存装置包括一快闪存储器以及一控制器。快闪存储器包括多个区块,并且每一区块包括多个页面,其中每一页面具有多个子页面以及多个备用区块,每一备用区块用以储存一保留信息(SpareData),保留信息分别相应于每一子页面。控制器用以根据保留信息对子页面进行存取。保留信息包括所相应的子页面的一元数据(Meta Data),用以记录所相应的子页面的数据。在另一实施例中,保留信息更包括所相应的元数据的一错误检查码(ECC Parity)。另外,每一子页面包括一数据区块。在另一实施例中,每一子页面更包括相应于数据区块的一错误检查码。另外,备用区块以及子页面是交错排列于页面中、页面中的一个的所有备用区块排列于页面的前端,或者页面中的一个的所有备用区块排列于页面的后端。在一实施例中,快闪存储器更包括至少一既定页面,用以储存一页面大小参数,并且页面大小参数用以代表每一页面的一页面大小。
本发明另提供一种数据存取方法,适用于一数据储存装置,其中数据储存装置包括一快闪存储器,快闪存储器包括多个区块,每一区块包括多个页面,每一页面具有多个子页面。数据存取方法包括:接收相应于对子页面中的一第一子页面进行存取的一存取命令,其中每一页面更包括多个备用区块,每一备用区块用以储存一保留信息(Spare Data),保留信息分别相应于每一子页面;以及根据相应于第一子页面的保留信息,对第一子页面进行存取,其中保留信息包括所相应的子页面的一元数据(Meta Data),用以记录所相应的子页面的数据。保留信息更包括所相应的元数据的一错误检查码(ECC Parity),并且对第一子页面进行存取的步骤更包括根据错误检查码修正元数据的至少一错误比特。每一子页面包括一数据区块以及相应于数据区块的一错误检查码,并且对第一子页面进行存取的步骤更包括根据错误检查码修正子页面的至少一错误比特。在一实施例中,快闪存储器更包括至少一既定页面,用以储存一页面大小参数,并且页面大小参数用以代表每一页面的一页面大小。
附图说明
图1为本发明所提供的一电子系统的一种实施例的方块图。
图2A为本发明所提供的页面的一种实施例的示意图。
图2B为本发明所提供的页面的另一种实施例的示意图。
图2C为本发明所提供的页面的另一种实施例的示意图。
图2D为本发明所提供的页面的另一种实施例的示意图。
图3为本发明所提供的一数据存取方法的一种实施例的流程图。
【附图标记说明】
100  电子系统;
120  主机;
140  数据储存装置;
160  控制器;
162  运算单元;
164  永久存储器;
180  快闪存储器;
SP1-SP2    备用区块;
SPG1-SPG2  页面;
S300-S402  步骤。
具体实施方式
以下将详细讨论本发明各种实施例的装置及使用方法。然而值得注意的是,本发明所提供的许多可行的发明概念可实施在各种特定范围中。这些特定实施例仅用于举例说明本发明的装置及使用方法,但非用于限定本发明的范围。
图1为本发明所提供的一电子系统的一种实施例的方块图。电子系统100包括一主机120以及一数据储存装置140。数据储存装置140包括一快闪存储器180以及一控制器160,且可根据主机110所下达的命令操作。控制器160包括一运算单元162以及一永久存储器(如,只读存储器ROM)164。永久存储器164与所载的程序码、数据组成固件(firmware),由运算单元162执行,使控制器160基于该固件控制该快闪存储器180。快闪存储器180包括多个区块,并且每一区块包括多个页面。另外,每一页面具有多个子页面以及多个备用区块(Spare Area)。每一子页面包括一数据区块。在另一实施例中,每一子页面更包括相应于数据区块的一错误检查码。每一备用区块用以储存一保留信息(Spare Data),保留信息分别相应于每一子页面。在一实施例中,保留信息包括所相应的子页面的一元数据(Meta Data),用以记录所相应的子页面的数据。举例而言,元数据可包括各区块、各页面以及各子页面的数据属性,例如从实体子页面到逻辑子页面的反转信息等等,本发明不限于此。在另一实施例中,保留信息更包括所相应的元数据的一错误检查码(ECC Parity)。因此,控制器160可根据保留信息对页面中的子页面进行存取。当每一页面仅包括一备用区块时,控制器160仅可对整个页面进行存取,其中当控制器160所接收的存取命令仅指示对一第一页面中的一第一扇区(sector)进行写入时,控制器160需将第一页面的第一扇区外的其他扇区的数据读出,并与存取命令所指示需要写入的数据整合,再将整合后的数据写入另一页面中。当页面中具有多个子页面以及所相应的多个备用区块时,控制器160可直接对小于页面的子页面进行写入,其中当控制器160所接收的存取命令仅指示对一第一页面中的一第一扇区进行写入,并且第一扇区构成一子页面时,控制器160可直接将存取命令所指示需要写入的数据写入子页面中。
值得注意的是,在快闪存储器180具有至少一既定页面,用以储存一页面大小参数,并且页面大小参数用以代表每一页面的一页面大小。举例而言,在数据储存装置140被格式化后,快闪存储器180中的每一页面具有一固定的页面大小,并且相应于页面大小的页面大小参数会被储存于快闪存储器180的至少一既定页面中,但本发明不限于此。在其他实施例中,页面大小参数亦可储存于电子系统100中的其他存储器中,并且既定页面亦可包括其他数据,例如相应于区块大小的参数、相应于子页面大小的参数等等,本发明不限于此。另外,页面大小可为4K、8K、16K等等,本发明不限于此。子页面的大小可为1K、2K、4K、8K等等,本发明不限于此。当数据储存装置140上电时,控制器160读取既定页面中的数据,并借以获得区块、页面、子页面的大小,以根据不同存取模式对快闪存储器180进行存取。
举例而言,每一区块中的每一页面的每一子页面分别具有一逻辑地址以及一实体地址,并且数据储存装置140更包括至少一映射表,用以储存每一区块中每一子页面的逻辑地址以及实体地址的对应关系。举例而言,映射表可储存于永久存储器164或者快闪存储器180中,本发明不限于此。另外,映射表可包括至少一区块映射表、多个页面映射表及/或多个子页面映射表。举例而言,控制器160可借由逻辑地址计算出逻辑地址所相应的逻辑区块以及逻辑子页面,并且根据区块映射表,获得相应于逻辑区块的实体区块。接着,根据相应于逻辑区块的子页面映射表,获得相应的子逻辑页面,再根据子逻辑页面定位至实体子页面,但本发明不限于此。可借由查表找出相应于逻辑地址的子页面的实体地址皆为本发明的范畴。
图2A为本发明所提供的页面的一种实施例的示意图。在本实施例中,页面200A的页面大小为8K。页面200A具有两个子页面SPG1-SPG2,子页面SPG1-SPG2的子页面大小分别为4K,但本发明不限于此。页面200A亦可包括子页面大小为2K的4个子页面或者子页面大小为1K的8个子页面。页面200A的页面大亦不限于此。在本实施例中,页面200A中的备用区块SP1-SP2是排列于页面200A的前端,子页面SPG1-SPG2是排列于页面200A的后端,其中备用区块SP1相应于子页面SPG1,备用区块SP2相应于子页面SPG2。
图2B为本发明所提供的页面的另一种实施例的示意图。在本实施例中,页面200B的页面大小为8K。页面200B具有两个子页面SPG1-SPG2,子页面SPG1-SPG2的子页面大小分别为4K,但本发明不限于此。页面200B亦可包括子页面大小为2K的4个子页面或者子页面大小为1K的8个子页面。页面200B的页面大亦不限于此。在本实施例中,页面200B中所有备用区块SP1-SP2排列于页面200B的后端,子页面SPG1-SPG2是排列于页面200B的前端,其中备用区块SP1相应于子页面SPG1,备用区块SP2相应于子页面SPG2。
图2C为本发明所提供的页面的另一种实施例的示意图。在本实施例中,页面200C的页面大小为8K。页面200C具有两个子页面SPG1-SPG2,子页面SPG1-SPG2的子页面大小分别为4K,但本发明不限于此。页面200C亦可包括子页面大小为2K的4个子页面或者子页面大小为1K的8个子页面。页面200C的页面大亦不限于此。在本实施例中,页面200C中的备用区块SP1-SP2是分别排列于页面200C的前端以及尾端,子页面SPG1-SPG2是排列于页面200B的中间,其中备用区块SP1相应于子页面SPG1,备用区块SP2相应于子页面SPG2。
图2D为本发明所提供的页面的另一种实施例的示意图。在本实施例中,页面200C的页面大小为8K。页面200D具有两个子页面SPG1-SPG2,子页面SPG1-SPG2的子页面大小分别为4K,但本发明不限于此。页面200D亦可包括子页面大小为2K的4个子页面或者子页面大小为1K的8个子页面。页面200D的页面大亦不限于此。在本实施例中,页面200D中的备用区块SP1-SP2与子页面SPG1-SPG2是交错排列于页面200D的中间,其中备用区块SP1相应于子页面SPG1,备用区块SP2相应于子页面SPG2。值得注意的是,在本实施例中,备用区块SP1-SP2是分别排列于子页面SPG1-SPG2前面。在另一实施例中,备用区块SP1-SP2亦可分别排列于子页面SPG1-SPG2后面,本发明不限于此。其他备用区块以及子页面的排列方式亦为本发明的范畴。
图3为本发明所提供的一数据存取方法的一种实施例的流程图。数据存取方法适用于图1所示的电子系统100。流程开始于步骤S300。
在步骤S300中,控制器160自主机120接收相应于对子页面中的一第一子页面进行存取的一存取命令。
接着,在步骤S302中,控制器160根据相应于第一子页面的保留信息,对第一子页面进行存取,其中对第一子页面进行存取的步骤更包括根据错误检查码修正子页面的至少一错误比特,以及根据错误检查码修正元数据的至少一错误比特。举例而言,元数据可包括各区块、各页面以及各子页面的数据属性,例如从实体子页面到逻辑子页面的反转信息等等,本发明不限于此。在另一实施例中,保留信息更包括所相应的元数据的一错误检查码(ECC Parity)。因此,控制器160可根据保留信息对页面中的子页面进行存取。当每一页面仅包括一备用区块时,控制器160仅可对整个页面进行存取,其中当控制器160所接收的存取命令仅指示对一第一页面中的一第一扇区(sector)进行写入时,控制器160需将第一页面的第一扇区外的其他扇区的数据读出,并与存取命令所指示需要写入的数据整合,再将整合后的数据写入另一页面中。当页面中具有多个子页面以及所相应的多个备用区块时,控制器160可直接对小于页面的子页面进行写入,其中当控制器160所接收的存取命令仅指示对一第一页面中的一第一扇区进行写入,并且第一扇区构成一子页面时,控制器160可直接将存取命令所指示需要写入的数据写入子页面中。
举例而言,每一区块中的每一页面的每一子页面分别具有一逻辑地址以及一实体地址,并且数据储存装置140更包括至少一映射表,用以储存每一区块中每一子页面的逻辑地址以及实体地址的对应关系。举例而言,映射表可储存于永久存储器164或者快闪存储器180中,本发明不限于此。另外,映射表可包括至少一区块映射表、多个页面映射表及/或多个子页面映射表。举例而言,控制器160可借由逻辑地址计算出逻辑地址所相应的逻辑区块以及逻辑子页面,并且根据区块映射表,获得相应于逻辑区块的实体区块。接着,根据相应于逻辑区块的子页面映射表,获得相应的子逻辑页面,再根据子逻辑页面定位至实体子页面,但本发明不限于此。可借由查表找出相应于逻辑地址的子页面的实体地址皆为本发明的范畴。
本发明所提供的数据储存装置140以及数据存取方法,可对比页面更小的单位进行反查。
本发明的方法,或特定型态或其部分,可以以程序码的型态存在。程序码可储存于实体媒体,如软碟、光碟片、硬盘、或是任何其他机器可读取(如电脑可读取)储存媒体,亦或不限于外在形式的电脑程序产品,其中,当程序码被机器,如电脑载入且执行时,此机器变成用以参与本发明的装置。程序码也可通过一些传送媒体,如电线或电缆、光纤、或是任何传输型态进行传送,其中,当程序码被机器,如电脑接收、载入且执行时,此机器变成用以参与本发明的装置。当在一般用途处理单元实作时,程序码结合处理单元提供一操作类似于应用特定逻辑电路的独特装置。
惟以上所述者,仅为本发明的较佳实施例而已,当不能以此限定本发明实施的范围,即大凡依本发明权利要求及发明说明内容所作的简单的等效变化与修饰,皆仍属本发明专利涵盖的范围内。另外本发明的任一实施例或权利要求不须达成本发明所揭露的全部目的或优点或特点。此外,摘要部分和标题仅是用来辅助专利文件搜寻之用,并非用来限制本发明的权利范围。

Claims (15)

1.一种数据储存装置,包括:
一快闪存储器,包括多个区块,并且每一上述区块包括多个页面,其中每一上述页面具有多个子页面以及多个备用区块,上述每一备用区块用以储存一保留信息,上述保留信息分别相应于每一上述子页面;以及
一控制器,用以根据上述保留信息对上述子页面进行存取。
2.如权利要求1所述的数据储存装置,其特征在于,上述保留信息包括所相应的上述子页面的一元数据,用以记录所相应的上述子页面的数据。
3.如权利要求2所述的数据储存装置,其特征在于,上述保留信息更包括所相应的上述元数据的一错误检查码。
4.如权利要求1所述的数据储存装置,其特征在于,每一上述子页面包括一数据区块。
5.如权利要求4所述的数据储存装置,其特征在于,每一上述子页面更包括相应于上述数据区块的一错误检查码。
6.如权利要求1所述的数据储存装置,其特征在于,上述快闪存储器更包括至少一既定页面,用以储存一页面大小参数,并且上述页面大小参数用以代表每一上述页面的一页面大小。
7.如权利要求1所述的数据储存装置,其特征在于,上述备用区块以及上述子页面是交错排列于上述页面中。
8.如权利要求1所述的数据储存装置,其特征在于,上述页面中的一个的所有上述备用区块排列于上述页面的前端,或者上述页面中的一个的所有上述备用区块排列于上述页面的后端。
9.一种数据存取方法,适用于一数据储存装置,其中上述数据储存装置包括一快闪存储器,上述快闪存储器包括多个区块,每一上述区块包括多个页面,每一上述页面具有多个子页面,并且上述数据存取方法包括:
接收相应于对上述子页面中的一第一子页面进行存取的一存取命令,其中每一上述页面更包括多个备用区块,上述每一备用区块用以储存一保留信息,上述保留信息分别相应于每一上述子页面;以及
根据相应于上述第一子页面的上述保留信息,对上述第一子页面进行存取。
10.如权利要求9所述的数据存取方法,其特征在于,上述保留信息包括所相应的上述子页面的一元数据,用以记录所相应的上述子页面的数据。
11.如权利要求10所述的数据存取方法,其特征在于,上述保留信息更包括所相应的上述元数据的一错误检查码,并且对上述第一子页面进行存取的步骤更包括根据上述错误检查码修正上述元数据的至少一错误比特。
12.如权利要求9所述的数据存取方法,其特征在于,每一上述子页面包括一数据区块以及相应于上述数据区块的一错误检查码,并且对上述第一子页面进行存取的步骤更包括根据上述错误检查码修正上述子页面的至少一错误比特。
13.如权利要求9所述的数据存取方法,其特征在于,上述快闪存储器更包括至少一既定页面,用以储存一页面大小参数,并且上述页面大小参数用以代表每一上述页面的一页面大小。
14.如权利要求9所述的数据存取方法,其特征在于,上述备用区块以及上述子页面是交错排列于上述页面中。
15.如权利要求9所述的数据存取方法,其特征在于,上述页面中的一个的所有上述备用区块排列于上述页面的前端,或者上述页面中的一个的所有上述备用区块排列于上述页面的后端。
CN201410041097.0A 2013-12-04 2014-01-27 数据储存装置以及其数据存取方法 Active CN104699417B (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
TW102144357 2013-12-04
TW102144357A TWI603194B (zh) 2013-12-04 2013-12-04 資料儲存裝置以及其資料存取方法

Publications (2)

Publication Number Publication Date
CN104699417A true CN104699417A (zh) 2015-06-10
CN104699417B CN104699417B (zh) 2018-05-04

Family

ID=53265411

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410041097.0A Active CN104699417B (zh) 2013-12-04 2014-01-27 数据储存装置以及其数据存取方法

Country Status (3)

Country Link
US (2) US9766974B2 (zh)
CN (1) CN104699417B (zh)
TW (1) TWI603194B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106569735A (zh) * 2015-10-07 2017-04-19 慧荣科技股份有限公司 数据储存装置及数据维护方法
CN107577554A (zh) * 2016-07-05 2018-01-12 慧荣科技股份有限公司 检测使用中逻辑页面的数据储存装置与数据储存方法
CN108389600A (zh) * 2017-02-02 2018-08-10 慧荣科技股份有限公司 数据储存装置以及参数改写方法
CN109426581A (zh) * 2017-08-28 2019-03-05 慧荣科技股份有限公司 用以检测数据储存装置的数据储存方法及其数据储存装置
CN110908924A (zh) * 2018-09-17 2020-03-24 北京兆易创新科技股份有限公司 一种写入检测方法、装置、终端及存储介质

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10853168B2 (en) 2018-03-28 2020-12-01 Samsung Electronics Co., Ltd. Apparatus to insert error-correcting coding (ECC) information as data within dynamic random access memory (DRAM)
JP2020046761A (ja) * 2018-09-14 2020-03-26 株式会社東芝 管理装置、情報処理装置およびメモリ制御方法
KR20200031924A (ko) 2018-09-17 2020-03-25 삼성전자주식회사 메모리 컨트롤러, 메모리 컨트롤러의 동작 방법 및 메모리 컨트롤러를 포함하는 스토리지 장치
KR20200076431A (ko) 2018-12-19 2020-06-29 삼성전자주식회사 메모리 컨트롤러 및 메모리 시스템의 동작 방법, 및 메모리 시스템
TWI688965B (zh) * 2019-08-14 2020-03-21 群聯電子股份有限公司 資料寫入方法、記憶體控制電路單元及記憶體儲存裝置
CN112416240B (zh) * 2019-08-22 2022-10-21 群联电子股份有限公司 数据写入方法、存储器控制电路单元及存储器存储装置
US11972140B2 (en) 2021-04-26 2024-04-30 Apple Inc. Hashing with soft memory folding
US11693585B2 (en) * 2021-04-26 2023-07-04 Apple Inc. Address hashing in a multiple memory controller system
US12019513B2 (en) 2022-04-27 2024-06-25 Micron Technology, Inc. Apparatuses, systems, and methods for per row error scrub information
US12014797B2 (en) 2022-04-27 2024-06-18 Micron Technology, Inc. Apparatuses, systems, and methods for managing metadata storage at a memory
WO2024107504A1 (en) * 2022-11-15 2024-05-23 Micron Technology, Inc. Apparatuses and methods for single-pass access of ecc information, metadata information or combinations thereof

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100313097A1 (en) * 2009-06-04 2010-12-09 Lsi Corporation Flash Memory Organization
US20120215962A1 (en) * 2011-02-18 2012-08-23 Synopsys Inc. Partitioning pages of an electronic memory

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7877542B2 (en) * 2000-01-06 2011-01-25 Super Talent Electronics, Inc. High integration of intelligent non-volatile memory device
US20080046630A1 (en) * 2006-08-21 2008-02-21 Sandisk Il Ltd. NAND flash memory controller exporting a logical sector-based interface
KR101554159B1 (ko) 2008-10-08 2015-09-21 삼성전자주식회사 데이터 저장 장치 및 이를 포함하는 데이터 저장 시스템
US8909851B2 (en) * 2011-02-08 2014-12-09 SMART Storage Systems, Inc. Storage control system with change logging mechanism and method of operation thereof
TWI459197B (zh) 2011-04-21 2014-11-01 Phison Electronics Corp 資料寫入方法、記憶體控制器與記憶體儲存裝置
TWI436212B (zh) 2011-07-21 2014-05-01 Phison Electronics Corp 資料寫入方法、記憶體控制器與記憶體儲存裝置
KR101826051B1 (ko) * 2012-02-27 2018-02-07 삼성전자주식회사 비휘발성 메모리 장치의 제어 방법 및 비휘발성 메모리 시스템

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100313097A1 (en) * 2009-06-04 2010-12-09 Lsi Corporation Flash Memory Organization
US20120215962A1 (en) * 2011-02-18 2012-08-23 Synopsys Inc. Partitioning pages of an electronic memory

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106569735A (zh) * 2015-10-07 2017-04-19 慧荣科技股份有限公司 数据储存装置及数据维护方法
CN106569735B (zh) * 2015-10-07 2019-10-25 慧荣科技股份有限公司 数据储存装置及数据维护方法
CN107577554A (zh) * 2016-07-05 2018-01-12 慧荣科技股份有限公司 检测使用中逻辑页面的数据储存装置与数据储存方法
CN107577554B (zh) * 2016-07-05 2020-12-01 慧荣科技股份有限公司 检测使用中逻辑页面的数据储存装置与数据储存方法
CN108389600A (zh) * 2017-02-02 2018-08-10 慧荣科技股份有限公司 数据储存装置以及参数改写方法
CN108389600B (zh) * 2017-02-02 2021-02-26 慧荣科技股份有限公司 数据储存装置以及参数改写方法
CN109426581A (zh) * 2017-08-28 2019-03-05 慧荣科技股份有限公司 用以检测数据储存装置的数据储存方法及其数据储存装置
CN109426581B (zh) * 2017-08-28 2022-02-11 慧荣科技股份有限公司 用以检测数据储存装置的数据储存方法及其数据储存装置
CN110908924A (zh) * 2018-09-17 2020-03-24 北京兆易创新科技股份有限公司 一种写入检测方法、装置、终端及存储介质

Also Published As

Publication number Publication date
TWI603194B (zh) 2017-10-21
US20170344423A1 (en) 2017-11-30
CN104699417B (zh) 2018-05-04
US9766974B2 (en) 2017-09-19
US20150154071A1 (en) 2015-06-04
US10120752B2 (en) 2018-11-06
TW201523253A (zh) 2015-06-16

Similar Documents

Publication Publication Date Title
CN104699417A (zh) 数据储存装置以及其数据存取方法
US9043536B2 (en) Method of recording mapping information, and memory controller and memory storage apparatus using the same
US9880742B2 (en) Valid data merging method, memory controller and memory storage apparatus
US9176865B2 (en) Data writing method, memory controller, and memory storage device
US8510502B2 (en) Data writing method, and memory controller and memory storage apparatus using the same
US9141530B2 (en) Data writing method, memory controller and memory storage device
US20120198131A1 (en) Data writing method for rewritable non-volatile memory, and memory controller and memory storage apparatus using the same
US9619380B2 (en) Data writing method, memory control circuit unit and memory storage apparatus
US9032135B2 (en) Data protecting method, memory controller and memory storage device using the same
CN104699622A (zh) 数据储存装置以及其数据抹除方法
US9389998B2 (en) Memory formatting method, memory controller, and memory storage apparatus
US9304907B2 (en) Data management method, memory control circuit unit and memory storage apparatus
US8819387B2 (en) Memory storage device, memory controller, and method for identifying valid data
US9235501B2 (en) Memory storage device, memory controller thereof, and method for programming data thereof
US20220138096A1 (en) Memory system
US20100262892A1 (en) Data access method for flash meory and storage system and controller thereof
US20130159604A1 (en) Memory storage device and memory controller and data writing method thereof
US8762685B2 (en) Data writing method, memory controller and memory storage apparatus
US20140089566A1 (en) Data storing method, and memory controller and memory storage apparatus using the same
US9146861B2 (en) Memory address management method, memory controller and memory storage device
US10289334B2 (en) Valid data merging method, memory controller and memory storage apparatus
US8738847B2 (en) Data writing method, and memory controller and memory storage apparatus using the same
US20190278703A1 (en) Memory system, operating method thereof and electronic device
US9009389B2 (en) Memory management table processing method, memory controller, and memory storage apparatus
US20130246687A1 (en) Data writing method, memory controller and memory storage apparatus

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant