CN107015764A - Nand flash的数据处理方法、装置和一种Nand flash - Google Patents
Nand flash的数据处理方法、装置和一种Nand flash Download PDFInfo
- Publication number
- CN107015764A CN107015764A CN201710159938.1A CN201710159938A CN107015764A CN 107015764 A CN107015764 A CN 107015764A CN 201710159938 A CN201710159938 A CN 201710159938A CN 107015764 A CN107015764 A CN 107015764A
- Authority
- CN
- China
- Prior art keywords
- nand flash
- packet
- mapping table
- flash blocks
- data bag
- 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
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/061—Improving I/O performance
- G06F3/0611—Improving I/O performance in relation to response time
-
- 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/0614—Improving the reliability of storage systems
- G06F3/0616—Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
-
- 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
-
- 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]
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)
Abstract
本发明实施例公开了Nand flash的数据处理方法、装置和一种Nand flash,用于解决现有Nand flash在存储少量数据时容易增加额外的存储负担,降低存取处理速度的问题。本发明实施例方法包括:获取待写入数据;若待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nand flash块的最新数据包,最新数据包索引号为当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;获取最新数据包中的映射表,映射表记录有当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;建立新的映射关系;将建立的映射关系添加至映射表中,生成新的映射表;根据新的映射表和待写入数据生成新的数据包;将新的数据包写入最新可用物理号对应的物理页内。
Description
技术领域
本发明涉及存储介质技术领域,尤其涉及Nand flash的数据处理方法、装置和一种Nand flash。
背景技术
现有Nand flash(Nand型闪存)存储针对Nand flash特性采用了FTL(FlashTranslation Layer,闪存转换层)方法,其一般包括以下处理机制:
1)建立坏Nand flash块表;
2)建立Nand flash块映射表;
3)建立Nand flash页映射表;
4)采用平衡磨损算法提高整体使用寿命;
5)垃圾回收机制;
6)重读机制。
通过上述系列复杂的算法保证整体使用寿命和快速使用存储数据。
然而,当Nand flash用来存储一些数据量少(例如少于Nand flash的一个物理页)且又不经常写的数据时,采用上述复杂的处理机制不仅增加额外的存储负担,降低了数据的存取处理速度,而且减少了Nand flash的使用寿命。
发明内容
本发明实施例提供了Nand flash的数据处理方法、装置和一种Nand flash,能够快速完成Nand flash对少量数据的存取处理操作,大大减轻Nand flash处理少量数据时的存储负担,延长Nand flash的使用寿命。
第一方面,提供了一种Nand flash的数据处理方法,应用于在所述Nand flash中指定的Nand flash块;
所述Nand flash的数据处理方法包括:
获取待写入数据;
若所述待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
建立分配给所述待写入数据的逻辑号与最新可用物理号之间的映射关系,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
将建立的所述映射关系添加至所述映射表中,生成新的映射表;
根据所述新的映射表和所述待写入数据生成新的数据包;
将所述新的数据包写入所述最新可用物理号对应的物理页内。
第二方面,提供了一种Nand flash的数据处理方法,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待读取数据包的读取指令;
根据所述读取指令确定所述待读取数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
读取确定的所述物理号对应物理页中的数据包。
第三方面,提供了一种Nand flash的数据处理方法,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待修改数据包的修改指令以及待修改的数据;
根据所述修改指令确定所述待修改数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
读取确定的所述物理号对应物理页中的数据包;
将所述映射表中所述逻辑号对应的物理号更新为最新可用物理号,得到新的映射表,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
采用所述待修改的数据修改读取的所述数据包中的数据;
根据修改后的数据和所述新的映射表生成新的数据包;
将所述新的数据包写入所述最新可用物理号对应的物理页内。
第四方面,提供了一种Nand flash的数据处理方法,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待删除数据包的删除指令;
根据所述删除指令确定所述待删除数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
根据所述新的映射表生成新的数据包;
将所述新的数据包写入最新可用物理号对应的物理页内,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号。
第五方面,提供了一种基于上述的Nand flash的数据处理方法的Nand flash块处理方法,所述Nand flash中设有由两个以上指定的Nand flash块组成的块循环池;
在根据最新数据包索引号读取当前Nand flash块的最新数据包之前,所述Nandflash块处理方法还包括:
判断所述当前Nand flash块是否已满;
若所述当前Nand flash块未满,则执行根据最新数据包索引号读取当前Nandflash块的最新数据包的步骤;
若所述当前Nand flash块已满,则执行换块操作,然后执行根据最新数据包索引号读取当前Nand flash块的最新数据包的步骤;
所述换块操作具体包括以下步骤:
擦除所述块循环池中的下一个Nand flash块;
根据最新数据包索引号读取所述当前Nand flash块的最新数据包;
获取所述最新数据包中的映射表;
初始化第一逻辑号的值;
通过调整所述第一逻辑号的值依据所述映射表依次读取所述当前Nand flash块中的各个数据包,并将读取到的所述各个数据包依次写入所述下一个Nand flash块,直到所述当前Nand flash块中的各个数据包均写入至所述下一个Nand flash块;
将所述下一个Nand flash块确定为当前Nand flash块。
第六方面,提供了一种Nand flash的数据处理装置,应用于在所述Nand flash中指定的Nand flash块;
所述Nand flash的数据处理装置包括:
写入数据获取模块,用于获取待写入数据;
第一最新数据包读取模块,用于若所述待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第一映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
映射关系建立模块,用于建立分配给所述待写入数据的逻辑号与最新可用物理号之间的映射关系,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
第一新映射表生成模块,用于将建立的所述映射关系添加至所述映射表中,生成新的映射表;
第一新数据包生成模块,用于根据所述新的映射表和所述待写入数据生成新的数据包;
第一写入模块,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
第七方面,提供了一种Nand flash的数据处理装置,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
读取指令获取模块,用于获取待读取数据包的读取指令;
第一包号确定模块,用于根据所述读取指令确定所述待读取数据包的逻辑号;
第二最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第二映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第一物理号确定模块,用于根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
第一数据包读取单元,用于读取确定的所述物理号对应物理页中的数据包。
第八方面,提供了一种Nand flash的数据处理装置,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
修改指令获取模块,用于获取待修改数据包的修改指令以及待修改的数据;
第二包号确定模块,用于根据所述修改指令确定所述待修改数据包的逻辑号;
第三最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第三映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第二物理号确定模块,用于根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
第二数据包读取单元,用于读取确定的所述物理号对应物理页中的数据包;
第二新映射表生成模块,用于将所述映射表中所述逻辑号对应的物理号更新为最新可用物理号,得到新的映射表,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
数据修改模块,用于采用所述待修改的数据修改读取的所述数据包中的数据;
第二新数据包生成模块,用于根据修改后的数据和所述新的映射表生成新的数据包;
第二写入模块,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
第九方面,提供了一种Nand flash的数据处理装置,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
删除指令获取模块,用于获取待删除数据包的删除指令;
第三包号确定模块,用于根据所述删除指令确定所述待删除数据包的逻辑号;
第四最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第四映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第三新映射表生成模块,用于从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
第三新数据包生成模块,用于根据所述新的映射表生成新的数据包;
第三写入模块,用于将所述新的数据包写入最新可用物理号对应的物理页内,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号。
第十方面,提供了一种Nand flash,包括上述的Nand flash的数据处理装置。
从以上技术方案可以看出,本发明实施例具有以下优点:
本发明实施例中,通过将少量的数据打包成预设的数据包格式,并在数据包中建立逻辑号与物理号之间的映射关系,可以快速完成Nand flash对少量数据的存取处理操作,大大减轻了Nand flash处理少量数据时的存储负担,延长Nand flash的使用寿命。
附图说明
图1为本发明实施例中数据包的数据结构示意图;
图2为本发明实施例中最新数据包索引号获取过程的流程图;
图3为本发明实施例中数据包的写入过程的流程图;
图4为本发明实施例中换块操作过程的流程图;
图5为本发明实施例中数据包的读取过程的流程图;
图6为本发明实施例中数据包的修改过程的流程图;
图7为本发明实施例中数据包的删除过程的流程图;
图8为本发明实施例中Nand flash的数据处理装置实施例二的结构图;
图9为本发明实施例中Nand flash的数据处理装置实施例三的结构图;
图10为本发明实施例中Nand flash的数据处理装置实施例四的结构图;
图11为本发明实施例中Nand flash的数据处理装置实施例五的结构图;
图12为本发明实施例中Nand flash块处理装置实施例六的结构图。
具体实施方式
本发明实施例提供了Nand flash的数据处理方法、装置和一种Nand flash,用于解决现有Nand flash在存储少量数据时容易增加额外的存储负担,降低存取处理速度的问题。
为使得本发明的发明目的、特征、优点能够更加的明显和易懂,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,下面所描述的实施例仅仅是本发明一部分实施例,而非全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。
实施例一:
本实施例提供了一种Nand flash的数据处理方法是针对Nand flash特性的一种简易存储方法。该方法主要采用逻辑号和物理号的一级映射法,是一种以数据包为单元进行Nand flash页读、Nand flash页写、Nand flash页编辑以及整个Nand flash块擦除的简易存储方法。
首先,在实施例一中,为便于描述,使用如下述语进行描述:
Nand flash:一种非易失的存储器件;
KBYTE:1024字节;
Nand flash页:Nand flash的一种存储单位,一个Nand flash页的大小可以是4KBYTE、8KBYTE、16KBYTE,等等;
Nand flash块:Nand flash的一种存储单位,包含有几十个Nand flash页到几百个Nand flash页不等;
少量数据:指少于一个Nand flash页的数据;
预设格式的数据包:如图1所示,由包头和少量数据组成,如果数据包少于一个物理页的数据,可以为数据包填充随机数。所述包头可以由包标识码、逻辑号到物理号的映射表、包信息、用户信息组成。其中,对于本实施例中的数据包来说,映射表是必须的,而少量数据、包信息、用户信息等可以根据实际使用需要选择性加入;
逻辑号:数据包存取的编号。当上位机需要读Nand flash中的数据包时,上位机下发的读指令中包括有该数据包对应的逻辑号;
物理号:实际存储数据包的物理页的序号,即Nand flash物理页在Nand flash块内的序号;
最新数据包索引号:指的是存储最新写入的数据包的物理页的物理号;
不经常写的数据:在写入后很少修改的数据;
最大物理号:不超过Nand flash块内的物理页总数的设定数;
FTL:Nand flash转换层;
包标识码:具有一定规则的一串数据,用以获取最新数据包索引号。该包标识码主要用于判别Nand flash页是否已经被使用,进而确定最新数据包索引号。关于上述的逻辑号到物理号的映射法,该逻辑号和物理号都是从0开始顺序编排的自然数序列,建立逻辑号映射到物理号的映射关系,则可以生成对应的映射表,即逻辑号到物理号的映射表。这种映射方法是一种一级映射方法,映射表的更新就是指逻辑号对物理号的映射关系的更新。
在本实施例中,Nand flash的写是以页为单位的,每个Nand flash页具有几KBYTE至十几KBYTE的存储空间,在存储少量数据时,完全可以做到一次性存取。针对这个特点,本实施例提供的Nand flash数据处理方法具有以下特点:
1)建立数据包;
2)采用两个以上的Nand flash块建立块循环池,在必要时进行数据包的换块操作;
3)最新写入的数据包记录有最新的映射表;
4)在存取数据操作前,通过判断是否有包标识码以获取最新数据包索引号,继而根据最新数据包索引号获取最新的映射表,根据逻辑号在获取的最新的映射表中找到其对应的物理号,最后通过物理号可以实现数据包的存取;
5)在一个Nand flash块用于存储至最大物理号所对应的物理页已被使用后,则使用块循环块池中的下一个Nand flash块;
6)映射表的更新发生在数据包的写、修改和删除等操作。
下面将对本实施例提供的Nand flash的数据处理方法中关于数据包的写、读、修改、删除等操作进行详细描述。
需要说明的是,为便于描述,在下述内容中,Package_index表示最新数据包索引号,Max_phy_number表示最大物理号,Phy_num表示物理号,LN_ind表示逻辑号,TB_size表示映射表的大小。
最新数据包索引号的获取:
由于在对数据包进行写、读、修改、删除等操作时,大多需要获取当前的Nandflash块中的最新数据包索引号,因此本实施例先介绍该“最新数据包索引号”的获取过程,如图2所示,可以包括以下步骤:
201、初始化最新数据包索引号的值,Package_index=Max_phy_number,Phy_num=0;
202、判断Phy_num是否小于Max_phy_number,若是,则执行步骤203,若否,则结束;
203、读取Phy_num物理页下的数据包;
204、判断读取的数据包中是否具有包标识码,若是,则执行步骤205,若否,则执行步骤206;
205、Phy_num=Phy_num+1,并返回执行步骤202;
206、若Phy_num大于0,则Package_index=Phy_num-1;若Phy_num不大于0,则Package_index=0;然后结束。
对于上述步骤201~206,通过对当前Nand flash块中物理号从0开始遍历,直到物理号对应读取到的数据包不具有包标识码,则表明当前物理号的物理页中未写入数据包。从而可知前一个物理号(Phy_num-1)则为最新写入数据包的物理号,也即得到了最新写入数据包的索引号Package_index。特别地,当Phy_num=0时,读取的数据包也不具有包标识码,则表明当前的Nand flash块为一个“新”块,因此确定Package_index=0。
数据包的写操作:
当需要写入数据时,首先需要判断该数据是否属于少量数据,也即是否适合采用本实施例提供的Nand flash的数据处理方法,若是,则进行数据包的写操作。如图3所示,数据包的写入过程可以包括如下步骤:
301、获取需要写入Nand flash的待写入数据;
302、判断所述待写入数据的数据量是否小于预设阈值,若是,则执行步骤303,若否,则采用一般存储方法对待写入数据进行写入操作;
303、根据Package_index读取当前Nand flash块的最新数据包;
304、获取读取的最新数据包中的映射表;
305、判断是否Package_index=0且读取的最新数据包中不具有包标识码,若是,则执行步骤306,若否,则执行步骤307;
306、将所述Package_index确定为新的数据包的物理号,并将分配的逻辑号与所述新的数据包的物理号的映射关系添加至所述映射表的表尾,生成新的映射表,然后执行步骤308;
307、将Package_index+1确定为新的数据包的物理号,并将分配的逻辑号与所述新的数据包的物理号的映射关系添加至所述映射表的表尾,生成新的映射表;
308、根据所述待写入数据、所述新的映射表、包信息、用户信息生成所述新的数据包;
309、将所述新的数据包写入至其物理号对应的物理页内,数据包写入完成。
对于上述步骤302,上述的“预设阈值”可以是1个Nandflash页的数据,一个Nandflash页的大小可以是4KBYTE、8KBYTE、16KBYTE等。可以理解的是,本实施例提供的Nandflash的数据处理方法更适合用于处理少量数据。因此,当待写入数据不小于预设阈值时,可以认为当前待写入数据并非少量数据,从而可以采用一般存储方法进行写入处理。这里说的一般存储方法是指现有技术中的关于Nand flash的数据存储方法,例如FTL方法。
对于步骤303,Package_index的获取方法在上述内容中已经进行了详细描述,此处不再赘述。
对于步骤305,可以理解的是,当Package_index=0且读取的最新数据包中不具有包标识码时,表明当前的Nand flash块为新块,未存在写入的数据包,因此在创建数据包时执行步骤306。
对于步骤306,Package_index对应的物理页不具有包标识码,说明该物理页是空的,因此,该Package_index即为最新可用物理号,直接将该Package_index确定为新的数据包的物理号,建立该新的数据包的物理号与分配的逻辑号之间的映射关系,将该映射关系记录到映射表中。可以理解的是,若无映射表,则可以创建一个新的映射表。
对于步骤306,需要说明的是,所述分配的逻辑号可以由Nand flash为该新的数据包自动分配,也可以通过要求写入所述待写入数据的指令或请求进行确定、分配,本实施例对此不作限定。
对于步骤307,当当前的Nand flash块并非新块时,由于Package_index对应的物理页已被数据占用,因此为新的数据包分配物理页时,应该选取Package_index+1位置的物理页,即Package_index+1为最新可用物理号。
对于步骤308,本实施例中,该包信息和用户信息可以根据待写入数据的来源确定,也可以由获取到的所述最新数据包中的包信息和用户信息更新得来,或者可以采用默认的方式写入这两个信息,对此,本实施例不作限定。
对于步骤309,在将新的数据包写入至其物理号对应的物理页之后,为便于下一次的处理操作,还可以设置Package_index=Package_index+1。
需要说明的是,在步骤303之前,还可以判断当前Nand flash块的Package_index是否等于Max_phy_number,若是,则表明当前Nand flash块已满,需要执行换块操作,将块循环池中的下一个Nand flash块确定为当前Nand flash块,然后继续执行步骤303;若否,则执行步骤303。
为便于理解,下面将对换块操作进行详细描述。本实施例中,在Nand flash块的使用过程中,会产生无效的物理页,例如将原先存储有数据包的物理页中的数据包删除,而这些无效的物理页会占用Nand flash块的存储空间,因此,无效的物理页会越来越多,直到Nand flash块已满(即Package_index=Max_phy_number),此时,则进行块循环池的换块操作,将当前Nand flash块的所有数据搬移至下一个Nand flash块。如图4所示,换块操作的过程可以包括以下步骤:
401、擦除块循环池中的下一个Nand flash块,所述下一个Nand flash块的Phy_num=0;
402、根据Package_index读取当前Nand flash块的最新数据包,并获取所述最新数据包的映射表;
403、初始化逻辑号LN_ind的值;
404、判断LN_ind是否小于TB_size,若是,则执行步骤405,若否,则执行步骤408;
405、根据所述映射表获取LN_ind对应的物理号,并根据获取到的物理号读取数据包;
406、将读取到的数据包的映射表中所述LN_ind对应的物理号更换为所述下一个Nand flash块的Phy_num;
407、将读取到的所述数据包写入Phy_num对应的物理页内,Phy_num=Phy_num+1,LN_ind=LN_ind+1,然后返回步骤404;
408、Package_index=Phy_num,确定所述下一个Nand flash块为当前Nand flash块,换块操作完成,结束。
对于上述步骤401~408,先将下一个Nand flash块的数据擦除,从而可以清除该下一个Nand flash块中原有的无效物理页,使得其成为一个新块。然后将根据最新数据包的映射表将当前Nand flash块中的所有有效数据包逐一写入至下一个Nand flash块中,并分别修改各个数据包的映射关系。完成数据的搬迁之后,则可以将下一个Nand flash块确定为当前Nand flash块,完成本次换块操作。
数据包的读操作:
本实施例中,对于已写入Nand flash块中的数据包,可以根据上位机下发的读指令进行读取,如图5所示,具体包括以下步骤:
501、获取待读取数据包的读取指令;
502、根据所述读取指令确定所述待读取数据包的逻辑号;
503、根据Package_index读取当前Nand flash块中的最新数据包,并获取所述最新数据包中的映射表;
504、根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
505、读取确定的所述物理号对应物理页中的数据包。
对于上述步骤501,该读取指令可以由与Nand flash连接的上位机发出。
对于步骤502,可以理解的是,该读取指令中可以包含有该逻辑号,也可以包含有用于确定该逻辑号的数据包信息,然后根据数据包信息确定该逻辑号,对此不作限定。
对于步骤504,根据映射表中的映射关系,可以确定与该逻辑号对应的该待读取数据包的物理号。可以理解的是,由于本实施例中数据包的写入机制,最新数据包中的映射表包含有当前Nand flash块中所有数据包的逻辑号和物理号的映射关系。
对于步骤505,在确定出物理号之后,可以直接根据该物理号读取到所需的数据包,也即该待读取数据包。然后可以将该数据包发送至发出该读取指令的上位机或者其它设备上。
数据包的修改操作:
当需要修改数据包中的数据时,上位机或其它设备可以通过下发修改指令使得当前Nand flash块执行修改操作。如图6所示,数据包的修改过程可以包括以下步骤:
601、获取待修改数据包的修改指令以及待修改的数据;
602、根据所述修改指令确定所述待修改数据包的逻辑号;
603、根据Package_index读取当前Nand flash块中的最新数据包,并获取所述最新数据包中的映射表;
604、根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
605、读取确定的所述物理号对应物理页中的数据包;
606、将Package_index+1更新为所述映射表中所述逻辑号对应的物理号,得到新的映射表;
607、采用所述待修改的数据修改读取的所述数据包中的数据;
608、根据修改后的数据、所述新的映射表、包信息以及用户信息生成新的数据包;
609、将所述新的数据包写入至其物理号对应的物理页内,数据包修改完成。
对于步骤601,该修改指令可以由与Nand flash连接的上位机发出。并且,在获取修改指令的同时,可以获取到数据包待修改的数据,也即需要更新的数据。
对于步骤602,可以理解的是,该修改指令中可以包含有该逻辑号,也可以包含有用于确定该逻辑号的数据包信息,然后根据数据包信息确定该逻辑号,对此不作限定。
对于步骤604,根据映射表中的映射关系,可以确定与该逻辑号对应的该待修改数据包的物理号。可以理解的是,由于本实施例中数据包的写入机制,最新数据包中的映射表包含有当前Nand flash块中所有数据包的逻辑号和物理号的映射关系。
对于步骤605,在确定出物理号之后,可以直接根据该物理号读取到所需的数据包,也即该待修改数据包。
对于步骤606,在本实施例中,在修改数据包时,并非在原物理页上直接进行数据的修改,而是将更新后的数据以写入的方式写入至空的物理页中。因此,将Package_index+1作为该数据包的物理号,相当于为修改后的数据包分配最新的物理页。
对于步骤607,在读取待修改的数据包之后,使用待修改的数据修改该数据包中的数据,实现数据的更新。
对于步骤608,根据修改后的数据和新的映射表,以及包信息、用户信息生成新的数据包。其中,该包信息和用户信息可以根据修改指令来确定,也可以由读取到的待修改数据包中的包信息和用户信息更新得来,或者可以采用默认的方式写入这两个信息,对此,本实施例不作限定。
对于步骤609,在生成新的数据包,也即修改后的数据包之后,可以将所述新的数据包写入至其物理号对应的物理页内,也即Package_index+1对应的物理页内,数据包修改完成。
需要说明的是,在步骤603之前,还可以判断当前Nand flash块的Package_index是否等于Max_phy_number,若是,则表明当前Nand flash块已满,需要执行换块操作,将块循环池中的下一个Nand flash块确定为当前Nand flash块,然后再执行步骤603;若否,则执行步骤603。
由上述步骤601~609可知,对数据包进行修改之后,由于修改前的数据包占用的物理页被“放弃”,修改后的数据包重新写入最新的物理页中,从而会导致当前的Nandflash块增加一个无效页(即被“放弃”的物理页)。
数据包的删除操作:
当需要删除数据包时,上位机或其它设备可以通过下发删除指令使得当前Nandflash块执行删除操作。如图7所示,数据包的删除过程可以包括以下步骤:
701、获取待删除数据包的删除指令;
702、根据所述删除指令确定所述待删除数据包的逻辑号;
703、根据Package_index读取当前Nand flash块中的最新数据包,并获取所述最新数据包中的映射表;
704、从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
705、根据所述新的映射表和包信息生成新的数据包;
706、将所述新的数据包写入至Package_index+1对应的物理页内,数据包删除完成。
对于步骤701,该删除指令可以由与Nand flash连接的上位机发出。
对于步骤702,可以理解的是,该删除指令中可以包含有该逻辑号,也可以包含有用于确定该逻辑号的数据包信息,然后根据数据包信息确定该逻辑号,对此不作限定。
对于步骤704,可以理解的是,在删除Nand flash块中的数据包时,只需要删除该数据包的逻辑号与物理号之间的映射关系即可,因为当映射关系删除后,对于Nand flash以外的设备来说,已删除的数据包是不可知的。而由于当前Nand flash块中所有数据包的确定均通过最新数据包中的映射表来查询,因此需要删除了该映射关系后,生成新的映射表并执行步骤705,生成一个新的数据包。
对于步骤705,可知,生成的新的数据包里面不具有可用的有效数据,其作用在于记录新的映射表,并让该新的映射表在需要时可被读取到。
对于步骤706,在生成新的数据包之后,将该新的数据包写入到最新的物理页中,也即Package_index+1对应的物理页内,数据包删除操作完成。
需要说明的是,在步骤703之前,还可以判断当前Nand flash块的Package_index是否等于Max_phy_number,若是,则表明当前Nand flash块已满,需要执行换块操作,将块循环池中的下一个Nand flash块确定为当前Nand flash块,然后再执行步骤703;若否,则执行步骤703。
由上述步骤701~706可知,对数据包进行删除之后,由于删除前的数据包占用的物理页被“放弃”,删除后生成的记录新的映射表的数据包写入最新的物理页中,从而会导致当前的Nand flash块增加一个无效页(即被“放弃”的物理页)。
可见,本实施例中,随着对数据包的修改操作和删除操作的增多,当前Nand flash块中的无效页会越来越多,最后导致Nand flash块已满,从而需要执行换块操作。而由于换块操作时将下一个Nand flash块进行擦除处理,因此,即便将当前Nand flash块的所有有效数据包搬移至下一个Nand flash块中,该换块操作也是有意义的,相当于把下一个Nandflash块中的无效页清理掉。
需要说明的是,在本实施例中,可以在Nand flash上执行上述的写、读、修改、删除、换块等操作,可以只单独执行其中的某一个或多个操作,例如对某个Nand flash执行写操作,再执行修改操作、删除操作。应当可以理解的是,在Nand flash上可以执行上述写、读、修改、删除、换块等操作的任意组合,以及这些操作之间的执行次序均没有限定。
实施例二:
本实施例还提供一种Nand flash的数据处理装置,其应用于在所述Nand flash中指定的Nand flash块,主要进行Nand flash块的数据写入处理。如图8所示,所述Nandflash的数据处理装置包括:
写入数据获取模块801,用于获取待写入数据;
第一最新数据包读取模块802,用于若所述待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第一映射表获取模块803,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
映射关系建立模块804,用于建立分配给所述待写入数据的逻辑号与最新可用物理号之间的映射关系,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
第一新映射表生成模块805,用于将建立的所述映射关系添加至所述映射表中,生成新的映射表;
第一新数据包生成模块806,用于根据所述新的映射表和所述待写入数据生成新的数据包;
第一写入模块807,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
实施例三:
本实施例还提供一种Nand flash的数据处理装置,其应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包。该Nand flash的数据处理装置主要进行Nand flash块的数据读取处理。如图9所示,所述Nand flash的数据处理装置包括:
读取指令获取模块901,用于获取待读取数据包的读取指令;
第一包号确定模块902,用于根据所述读取指令确定所述待读取数据包的逻辑号;
第二最新数据包读取模块903,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第二映射表获取模块904,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第一物理号确定模块905,用于根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
第一数据包读取单元906,用于读取确定的所述物理号对应物理页中的数据包。
实施例四:
本实施例还提供一种Nand flash的数据处理装置,其应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包。该Nand flash的数据处理装置主要进行Nand flash块的数据修改处理。如图10所示,所述Nand flash的数据处理装置包括:
修改指令获取模块1001,用于获取待修改数据包的修改指令以及待修改的数据;
第二包号确定模块1002,用于根据所述修改指令确定所述待修改数据包的逻辑号;
第三最新数据包读取模块1003,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第三映射表获取模块1004,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第二物理号确定模块1005,用于根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
第二数据包读取单元1006,用于读取确定的所述物理号对应物理页中的数据包;
第二新映射表生成模块1007,用于将所述映射表中所述逻辑号对应的物理号更新为最新可用物理号,得到新的映射表,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
数据修改模块1008,用于采用所述待修改的数据修改读取的所述数据包中的数据;
第二新数据包生成模块1009,用于根据修改后的数据和所述新的映射表生成新的数据包;
第二写入模块1010,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
实施例五:
本实施例还提供一种Nand flash的数据处理装置,其应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包。该Nand flash的数据处理装置主要进行Nand flash块的数据读取处理。如图11所示,所述Nand flash的数据处理装置包括:
删除指令获取模块111,用于获取待删除数据包的删除指令;
第三包号确定模块112,用于根据所述删除指令确定所述待删除数据包的逻辑号;
第四最新数据包读取模块113,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第四映射表获取模块114,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第三新映射表生成模块115,用于从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
第三新数据包生成模块116,用于根据所述新的映射表生成新的数据包;
第三写入模块117,用于将所述新的数据包写入最新可用物理号对应的物理页内,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号。
实施例六:
本实施例还提供一种在上述图8、图10或图11对应实施例中描述的任意一种Nandflash的数据处理装置的基础上进一步改进的Nand flash块处理装置。在实施例六描述的Nand flash块处理装置中,所述Nand flash中设有由两个以上指定的Nand flash块组成的块循环池。如图12所示,该Nand flash块处理装置还包括:
满载判断模块121,用于判断所述当前Nand flash块是否已满;
第一触发模块122,用于若所述满载判断模块121的判断结果为否,则触发上述的第一最新数据包读取模块802、第三最新数据包读取模块1003或第四最新数据包读取模块113;
第二触发模块123,用于若所述满载判断模块121的判断结果为是,则触发换块模块124,然后触发上述的第一最新数据包读取模块802、第三最新数据包读取模块1003或第四最新数据包读取模块113;
所述换块模块124具体可以包括以下单元:
块擦除单元1241,用于擦除所述块循环池中的下一个Nand flash块;
最新数据包读取单元1242,用于根据最新数据包索引号读取所述当前Nand flash块的最新数据包;
映射表获取单元1243,用于获取所述最新数据包中的映射表;
初始化单元1244,用于初始化第一逻辑号的值;
数据包搬移单元1245,用于通过调整所述第一逻辑号的值依据所述映射表依次读取所述当前Nand flash块中的各个数据包,并将读取到的所述各个数据包依次写入所述下一个Nand flash块,直到所述当前Nand flash块中的各个数据包均写入至所述下一个Nandflash块;
当前块确定单元1246,用于将所述下一个Nand flash块确定为当前Nand flash块。
实施例七:
本实施例还提供一种Nand flash,其包括图8至图11对应实施例中描述的任意一种Nand flash的数据处理装置,和/或,包括图12对应实施例中描述的任意一种Nand flash块处理装置。特别地,该Nand flash也可以包括上述图8至图12对应实施例中描述的所有形式的Nand flash的数据处理装置和Nand flash块处理装置。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
Claims (10)
1.一种Nand flash的数据处理方法,其特征在于,应用于在所述Nand flash中指定的Nand flash块;
所述Nand flash的数据处理方法包括:
获取待写入数据;
若所述待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nandflash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
建立分配给所述待写入数据的逻辑号与最新可用物理号之间的映射关系,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
将建立的所述映射关系添加至所述映射表中,生成新的映射表;
根据所述新的映射表和所述待写入数据生成新的数据包;
将所述新的数据包写入所述最新可用物理号对应的物理页内。
2.一种Nand flash的数据处理方法,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待读取数据包的读取指令;
根据所述读取指令确定所述待读取数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
读取确定的所述物理号对应物理页中的数据包。
3.一种Nand flash的数据处理方法,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待修改数据包的修改指令以及待修改的数据;
根据所述修改指令确定所述待修改数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
读取确定的所述物理号对应物理页中的数据包;
将所述映射表中所述逻辑号对应的物理号更新为最新可用物理号,得到新的映射表,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
采用所述待修改的数据修改读取的所述数据包中的数据;
根据修改后的数据和所述新的映射表生成新的数据包;
将所述新的数据包写入所述最新可用物理号对应的物理页内。
4.一种Nand flash的数据处理方法,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理方法包括:
获取待删除数据包的删除指令;
根据所述删除指令确定所述待删除数据包的逻辑号;
根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
根据所述新的映射表生成新的数据包;
将所述新的数据包写入最新可用物理号对应的物理页内,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号。
5.一种基于如权利要求1、3或4所述的Nand flash的数据处理方法的Nand flash块处理方法,所述Nand flash中设有由两个以上指定的Nand flash块组成的块循环池;
在根据最新数据包索引号读取当前Nand flash块的最新数据包之前,所述Nand flash块处理方法包括:
判断所述当前Nand flash块是否已满;
若所述当前Nand flash块未满,则执行根据最新数据包索引号读取当前Nand flash块的最新数据包的步骤;
若所述当前Nand flash块已满,则执行换块操作,然后执行根据最新数据包索引号读取当前Nand flash块的最新数据包的步骤;
所述换块操作具体包括以下步骤:
擦除所述块循环池中的下一个Nand flash块;
根据最新数据包索引号读取所述当前Nand flash块的最新数据包;
获取所述最新数据包中的映射表;
初始化第一逻辑号的值;
通过调整所述第一逻辑号的值依据所述映射表依次读取所述当前Nand flash块中的各个数据包,并将读取到的所述各个数据包依次写入所述下一个Nand flash块,直到所述当前Nand flash块中的各个数据包均写入至所述下一个Nand flash块;
将所述下一个Nand flash块确定为当前Nand flash块。
6.一种Nand flash的数据处理装置,其特征在于,应用于在所述Nand flash中指定的Nand flash块;
所述Nand flash的数据处理装置包括:
写入数据获取模块,用于获取待写入数据;
第一最新数据包读取模块,用于若所述待写入数据的数据量小于预设阈值,则根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第一映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
映射关系建立模块,用于建立分配给所述待写入数据的逻辑号与最新可用物理号之间的映射关系,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
第一新映射表生成模块,用于将建立的所述映射关系添加至所述映射表中,生成新的映射表;
第一新数据包生成模块,用于根据所述新的映射表和所述待写入数据生成新的数据包;
第一写入模块,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
7.一种Nand flash的数据处理装置,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
读取指令获取模块,用于获取待读取数据包的读取指令;
第一包号确定模块,用于根据所述读取指令确定所述待读取数据包的逻辑号;
第二最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第二映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第一物理号确定模块,用于根据所述逻辑号和所述映射表确定所述待读取数据包的物理号;
第一数据包读取单元,用于读取确定的所述物理号对应物理页中的数据包。
8.一种Nand flash的数据处理装置,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
修改指令获取模块,用于获取待修改数据包的修改指令以及待修改的数据;
第二包号确定模块,用于根据所述修改指令确定所述待修改数据包的逻辑号;
第三最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第三映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第二物理号确定模块,用于根据所述逻辑号和所述映射表确定所述待修改数据包的物理号;
第二数据包读取单元,用于读取确定的所述物理号对应物理页中的数据包;
第二新映射表生成模块,用于将所述映射表中所述逻辑号对应的物理号更新为最新可用物理号,得到新的映射表,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号;
数据修改模块,用于采用所述待修改的数据修改读取的所述数据包中的数据;
第二新数据包生成模块,用于根据修改后的数据和所述新的映射表生成新的数据包;
第二写入模块,用于将所述新的数据包写入所述最新可用物理号对应的物理页内。
9.一种Nand flash的数据处理装置,其特征在于,应用于在所述Nand flash中指定的Nand flash块,所述Nand flash块中存储有预设格式的数据包;
所述Nand flash的数据处理装置包括:
删除指令获取模块,用于获取待删除数据包的删除指令;
第三包号确定模块,用于根据所述删除指令确定所述待删除数据包的逻辑号;
第四最新数据包读取模块,用于根据最新数据包索引号读取当前Nand flash块的最新数据包,所述最新数据包索引号为所述当前Nand flash块中存储最新写入的数据包的物理页对应的物理号;
第四映射表获取模块,用于获取所述最新数据包中的映射表,所述映射表记录有所述当前Nand flash块中存储的各个数据包的逻辑号与物理号之间的映射关系;
第三新映射表生成模块,用于从所述映射表中删除所述逻辑号与对应的物理号之间的映射关系,得到新的映射表;
第三新数据包生成模块,用于根据所述新的映射表生成新的数据包;
第三写入模块,用于将所述新的数据包写入最新可用物理号对应的物理页内,所述最新可用物理号为所述当前Nand flash块中最新的可用物理页对应的物理号。
10.一种Nand flash,其特征在于,包括如权利要求6至9中任意一项所述的Nand flash的数据处理装置。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710159938.1A CN107015764B (zh) | 2017-03-17 | 2017-03-17 | Nand flash的数据处理方法、装置和一种Nand flash |
PCT/CN2017/116828 WO2018166258A1 (zh) | 2017-03-17 | 2017-12-18 | Nand flash的数据处理方法、装置和一种Nand flash |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710159938.1A CN107015764B (zh) | 2017-03-17 | 2017-03-17 | Nand flash的数据处理方法、装置和一种Nand flash |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107015764A true CN107015764A (zh) | 2017-08-04 |
CN107015764B CN107015764B (zh) | 2020-03-27 |
Family
ID=59440336
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710159938.1A Active CN107015764B (zh) | 2017-03-17 | 2017-03-17 | Nand flash的数据处理方法、装置和一种Nand flash |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN107015764B (zh) |
WO (1) | WO2018166258A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018166258A1 (zh) * | 2017-03-17 | 2018-09-20 | 深圳市江波龙电子有限公司 | Nand flash的数据处理方法、装置和一种Nand flash |
WO2020102998A1 (zh) * | 2018-11-20 | 2020-05-28 | 华为技术有限公司 | 一种删除内存中索引项的方法、装置 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1937080A (zh) * | 2006-10-19 | 2007-03-28 | 骆建军 | 一种nand flash存储器件 |
CN101075211A (zh) * | 2007-06-08 | 2007-11-21 | 马彩艳 | 基于sector访问的flash存储器的存储管理 |
CN101278267A (zh) * | 2005-08-03 | 2008-10-01 | 桑迪士克股份有限公司 | 具有经调度回收操作的非易失性存储器 |
CN101676882A (zh) * | 2008-09-16 | 2010-03-24 | 美光科技公司 | 存储器装置的内嵌映射信息 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101453313B1 (ko) * | 2013-03-25 | 2014-10-22 | 아주대학교산학협력단 | 플래시 메모리 기반의 페이지 주소 사상 방법 및 시스템 |
CN103955432B (zh) * | 2014-04-22 | 2017-09-19 | 深圳市硅格半导体有限公司 | 数据存储的方法及装置 |
CN104778127B (zh) * | 2015-03-25 | 2018-04-13 | 合肥格易集成电路有限公司 | 一种nand flash写数据的方法和装置 |
CN107015764B (zh) * | 2017-03-17 | 2020-03-27 | 深圳市江波龙电子股份有限公司 | Nand flash的数据处理方法、装置和一种Nand flash |
-
2017
- 2017-03-17 CN CN201710159938.1A patent/CN107015764B/zh active Active
- 2017-12-18 WO PCT/CN2017/116828 patent/WO2018166258A1/zh active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101278267A (zh) * | 2005-08-03 | 2008-10-01 | 桑迪士克股份有限公司 | 具有经调度回收操作的非易失性存储器 |
CN1937080A (zh) * | 2006-10-19 | 2007-03-28 | 骆建军 | 一种nand flash存储器件 |
CN101075211A (zh) * | 2007-06-08 | 2007-11-21 | 马彩艳 | 基于sector访问的flash存储器的存储管理 |
CN101676882A (zh) * | 2008-09-16 | 2010-03-24 | 美光科技公司 | 存储器装置的内嵌映射信息 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2018166258A1 (zh) * | 2017-03-17 | 2018-09-20 | 深圳市江波龙电子有限公司 | Nand flash的数据处理方法、装置和一种Nand flash |
WO2020102998A1 (zh) * | 2018-11-20 | 2020-05-28 | 华为技术有限公司 | 一种删除内存中索引项的方法、装置 |
Also Published As
Publication number | Publication date |
---|---|
CN107015764B (zh) | 2020-03-27 |
WO2018166258A1 (zh) | 2018-09-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104102585B (zh) | 映射信息记录方法、存储器控制器与存储器储存装置 | |
CN104798063B (zh) | 存储设备和主机设备 | |
CN106406756B (zh) | 一种文件系统的空间分配方法及装置 | |
CN109725847A (zh) | 存储器系统及控制方法 | |
CN105760113B (zh) | 基于nand闪存的高速存储设备及文件管理方法 | |
CN102779096B (zh) | 一种基于页块面三维的闪存地址映射方法 | |
CN104866429B (zh) | 存储器管理方法、存储器控制电路单元与存储器存储装置 | |
CN106469122B (zh) | 有效数据合并方法、存储器控制器与存储器储存装置 | |
CN104765568B (zh) | 数据存储方法、存储器控制电路单元与存储器存储装置 | |
CN106708425A (zh) | 分布式多模存储管理 | |
CN104571954B (zh) | 一种数据存储方法及装置 | |
WO2005029311A1 (ja) | 半導体メモリカード、半導体メモリ制御装置及び半導体メモリ制御方法 | |
CN106776376A (zh) | 缓冲存储器管理方法、存储器控制电路单元及存储装置 | |
CN106557432B (zh) | 缓冲存储器管理方法、存储器控制电路单元及存储装置 | |
CN104220991A (zh) | 用于允许数据在nand闪存上的有效存储的架构 | |
CN106802867A (zh) | 固态储存装置及其数据编程方法 | |
US20150052292A1 (en) | Method for erasing data entity in memory module | |
CN107203330B (zh) | 一种面向读写数据流的闪存数据分布方法 | |
CN108415663A (zh) | 数据存储装置的操作方法 | |
CN107015764A (zh) | Nand flash的数据处理方法、装置和一种Nand flash | |
CN109558333A (zh) | 具有可变额外存储空间(op)的固态存储设备命名空间 | |
CN108733577A (zh) | 存储器管理方法、存储器控制电路单元及存储器存储装置 | |
CN105224238B (zh) | 存储器管理方法、存储器存储装置及存储器控制电路单元 | |
CN103914391B (zh) | 数据读取方法、存储器控制器与存储器存储装置 | |
CN107678686A (zh) | 基于硬件实现闪存的ftl功能的方法及其数据存储装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
CB02 | Change of applicant information |
Address after: 518000 A, B, C, D, E, F1, 8 Building, Financial Services Technology Innovation Base, No. 8 Kefa Road, Nanshan District, Shenzhen City, Guangdong Province Applicant after: Shenzhen jiangbolong electronic Limited by Share Ltd Address before: 518057 8 building, 1 finance base, 8 KFA Road, Nanshan District, Shenzhen, Guangdong. Applicant before: Shenzhen jiangbolong Electronic Co., Ltd. |
|
CB02 | Change of applicant information | ||
GR01 | Patent grant | ||
GR01 | Patent grant |