CN113094369A - 一种flash存储器数据管理方法 - Google Patents

一种flash存储器数据管理方法 Download PDF

Info

Publication number
CN113094369A
CN113094369A CN202110396488.4A CN202110396488A CN113094369A CN 113094369 A CN113094369 A CN 113094369A CN 202110396488 A CN202110396488 A CN 202110396488A CN 113094369 A CN113094369 A CN 113094369A
Authority
CN
China
Prior art keywords
data
area
index information
flash memory
copying
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.)
Pending
Application number
CN202110396488.4A
Other languages
English (en)
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.)
Shenzhen Moyoung Technology Co ltd
Original Assignee
Shenzhen Moyoung Technology Co ltd
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 Shenzhen Moyoung Technology Co ltd filed Critical Shenzhen Moyoung Technology Co ltd
Priority to CN202110396488.4A priority Critical patent/CN113094369A/zh
Publication of CN113094369A publication Critical patent/CN113094369A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2282Tablespace storage structures; Management thereof

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)

Abstract

本发明公开了一种flash存储器数据管理方法,将flash划分为多个区域,其中包括表头区、数据区;写入数据,将数据存储在数据区并将数据信息存储在表头区;将表头区数据拷贝到RAM中;读取数据,系统读取RAM中的数据信息;解决了系统对flash存储器内数据内容检索复杂与慢的问题,通过将数据信息拷贝在RAM中,在系统读取数据时,通过直接在RAM中的链表中检索数据地址与长度,达到快速定位数据地址的目的提高了系统的稳定性,同时在flash存储器操作过程中,每个扇区存满之后,再擦除本扇区或者使用下一块扇区,达到提高了flash存储器的利用率以及减少了flash存储器擦写次数,延长了flash存储器的使用寿命。

Description

一种flash存储器数据管理方法
技术领域
本发明涉及数据存储领域,特别涉及一种flash存储器数据管理方法。
背景技术
随着科学技术的发展,flash存储器的应用越来越广泛,在存储资源较少的嵌入式平台,无法植入文件系统,重要数据需要掉电保存,并不能存储在RAM当中,对这类数据读取和更新过程中会降低系统效率、影响系统稳定性并且容易发生操作错误。
发明内容
为解决上述问题,本发明提供一种flash存储器数据管理方法,解决了在数据读取的过程中,系统对flash存储器内数据内容检索复杂与慢的问题。
为实现上述的目的,本发明采用的技术方案为:一种flash存储器数据管理方法,包括步骤:
A、将flash划分为多个区域,其中包括表头区、数据区;
B、写入数据,将数据存储在所述数据区并将数据信息存储在所述表头区;
C、将所述表头区数据拷贝到RAM中;
D、读取数据,系统读取所述RAM中的所述数据信息。
进一步地,A步骤中,对所述表头区包括以下步骤:
a1、在所述表头区建立数据索引信息节点,所述数据索引信息节点包括是否为有效数据、数据ID、数据地址、数据长度、表头区索引信息节点地址。
进一步地,B步骤中,对写入数据包括以下步骤:
b1、判断所述数据索引信息节点中是否有写入相同的所述数据ID;
b2、若是,将相同所述数据ID的所述数据索引信息节点中有效数据标志位改写为无效数据标志写入数据,并保留所述数据ID在空白的所述数据索引信息节点存储所述数据信息;
b3、若否,所述数据索引信息节点存储所述数据信息。
进一步地,C步骤中,对所述数据索引信息节点拷贝到RAM包括以下步骤:
c1、检测所述表头区为有效数据的所述数据索引信息节点;
c2、将是有效数据的所述数据索引信息节点以链表的形式拷贝到RAM中。
进一步地,D步骤中,对RAM数据读取包括以下步骤:
d1、RAM查询链表中所述数据ID以及对应所述数据索引信息节点;
d2、查询所述数据索引信息节点中所述数据地址、数据长度,并读取数据。
进一步地,其中还包括E步骤:
e1、将flash划分为多个区域,还包括备份区,检测所述表头区或所述数据区数据是否满载;
e2、若所述表头区满载,将满载的所述表头区的数据拷贝至所述备份区,擦除满载的所述表头区形成空白所述表头区,将备份区数据拷贝至空白所述表头区,擦除所述备份区数据:
e3、若所述数据区满载,将满载的所述数据区的数据备份至所述备份区,擦除满载的所述数据区形成空白所述数据区,将备份区数据拷贝至空白所述数据区,擦除所述备份区数据。
进一步地,e2步骤中,还包括以下步骤:
e21、检测所述表头区数据中有效的所述数据索引信息节点;
e22、将所述数据索引信息节点拷贝至所述备份区,擦除满载的所述表头区;
e23.形成空白所述表头区将备份区数据拷贝至空白所述表头区,擦除所述备份区数据;
e24、更新所述数据索引信息节点中所述表头区索引信息节点地址。
进一步地,e3步骤中,还包括以下步骤:
e31、将所述数据区数据中拷贝至所述备份区,擦除满载的所述数据区;
e32、形成空白所述数据区将备份区数据拷贝至空白所述数据区,擦除所述备份区数据;
e33、更新表头区索引信息节点地址中数据ID相对应的所述数据地址。
本发明的有益效果:本发明提供了一种flash存储器数据管理方法,解决了系统对flash存储器内数据内容检索复杂与慢的问题,通过将数据信息拷贝在RAM中,在系统读取数据时,通过直接在RAM中的链表中检索数据地址与长度,达到快速定位数据地址的目的提高了系统的稳定性,同时在flash存储器操作过程中,每个扇区存满之后,再擦除本扇区或者使用下一块扇区,达到提高了flash存储器的利用率以及减少了flash存储器擦写次数,延长了flash存储器的使用寿命。
附图说明
图1是本发明提供的一种flash存储器数据管理方法的数据读取的流程图;
图2是本发明提供的一种flash存储器数据管理方法的数据擦除的流程图。
具体实施方式
为使本发明的目的、技术方案及效果更加清楚、明确,以下参照附图并举实施例对本发明进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
请参阅图1,本发明提供的一种flash存储器数据管理方法,包括步骤:
A、将flash划分为多个区域,其中包括表头区、数据区;
B、写入数据,将数据存储在所述数据区并将数据信息存储在所述表头区;
C、将所述表头区数据拷贝到RAM中;
D、读取数据,系统读取所述RAM中的所述数据信息。
下面通过具体的实施例对本发明作进一步说明;
A步骤中,将flash划分为多个区域,包括表头区、数据区,其中划分出表头区可以是4kb,8kb等,可以被4kb整除的区域,在表头区建立数据索引信息节点,数据索引信息节点包括是否为有效数据、数据ID、数据地址、数据长度、表头区索引信息节点地址等。
B步骤中,对写入数据检测数据ID,判断数据索引信息节点中是否有写入相同的数据ID;若是有相同数据ID,根据数据索引信息节点中对应的数据ID对应的有效数据标志位改写为无效数据标志位,并在表头区中找出未被写过的区域将新的数据信息写入;若否没有相同数据ID,将数据信息存储在空白的数据索引信息节点中。
C步骤中,检测表头区内数据信息,其中数据索引信息节点中为有效数据的数据索引信息节点标记,将是有效数据的数据索引信息节点以链表形式拷贝到RAM中,其中需要注意,在拷贝到RAM的数据在设备断电后会擦除,通电后需要重新将数据信息拷贝至RAM。
D步骤中,在系统对RAM数据读取过程中,系统需要读取数据ID信息,通过在RAM查询链表中数据ID找到对应数据索引信息节点,并在查询数据索引信息节点中数据地址、数据长度,并读取数据,可以实现快速读取所需数据。
其中还包括E步骤,请参阅图2,将flash划分为多个区域,还包括备份区,检测表头区或数据区数据是否满载;若表头区满载,将满载的表头区的数据拷贝至备份区,擦除满载的表头区形成空白表头区,将备份区数据拷贝至空白表头区,擦除备份区数据;若数据区满载,将满载的数据区的数据拷贝至备份区,擦除满载的数据区形成空白数据区,将备份区数据拷贝至空白数据区,擦除备份区数据。通过该步骤可以减少flash存储器非必要的擦除,同时也增加擦写次数,延长flash存储器的使用寿命,增加flash存储器使用效率;
若是表头区满载,还包括以下:检测表头区数据中有效的数据索引信息节点,将数据索引信息节点拷贝至备份区,擦除原满载的表头区形成空白表头区,将备份区的数据索引信息节点在拷贝至空白表头区,擦除备份区内的数据索引信息节点;同时在更新数据索引信息节点中数据ID对应数据的表头区索引信息节点地址;
若是表头区满载,还包括以下:将数据区数据中拷贝至备份区,擦除满载的数据区形成空白数据区,将备份区的数据拷贝至空白数据区,擦除备份区数据;更新表头区内数据索引信息节点中数据ID相对应的数据地址。
应当理解的是,本发明的应用不限于上述的举例,对本领域普通技术人员来说,可以根据上述说明加以改进或变换,所有这些改进和变换都应属于本发明所附权利要求的保护范围。

Claims (8)

1.一种flash存储器数据管理方法,其特征在于,包括步骤:
A、将flash划分为多个区域,其中包括表头区、数据区;
B、写入数据,将数据存储在所述数据区并将数据信息存储在所述表头区;
C、将所述表头区数据拷贝到RAM中;
D、读取数据,系统读取所述RAM中的所述数据信息。
2.根据权利要求1所述的一种flash存储器数据管理方法,其特征在于,A步骤中,对所述表头区包括以下步骤:
a1、在所述表头区建立数据索引信息节点,所述数据索引信息节点包括是否为有效数据、数据ID、数据地址、数据长度、表头区索引信息节点地址。
3.根据权利要求2所述的一种flash存储器数据管理方法,其特征在于,B步骤中,对写入数据包括以下步骤:
b1、判断所述数据索引信息节点中是否有写入相同的所述数据ID;
b2、若是,将相同所述数据ID的所述数据索引信息节点中有效数据标志位改写为无效数据标志写入数据,并保留所述数据ID在空白的所述数据索引信息节点存储所述数据信息;
b3、若否,所述数据索引信息节点存储所述数据信息。
4.根据权利要求2所述的一种flash存储器数据管理方法,其特征在于,C步骤中,对所述数据索引信息节点拷贝到RAM包括以下步骤:
c1、检测所述表头区为有效数据的所述数据索引信息节点;
c2、将是有效数据的所述数据索引信息节点以链表的形式拷贝到RAM中。
5.根据权利要求4所述的一种flash存储器数据管理方法,其特征在于,D步骤中,对RAM数据读取包括以下步骤:
d1、RAM查询链表中所述数据ID以及对应所述数据索引信息节点;
d2、查询所述数据索引信息节点中所述数据地址、数据长度,并读取数据。
6.根据权利要求2所述的一种flash存储器数据管理方法,其特征在于,其中还包括E步骤:
e1、将flash划分为多个区域,还包括备份区,检测所述表头区或所述数据区数据是否满载;
e2、若所述表头区满载,将满载的所述表头区的数据拷贝至所述备份区,擦除满载的所述表头区形成空白所述表头区,将备份区数据拷贝至空白所述表头区,擦除所述备份区数据:
e3、若所述数据区满载,将满载的所述数据区的数据拷贝至所述备份区,擦除满载的所述数据区形成空白所述数据区,将备份区数据拷贝至空白所述数据区,擦除所述备份区数据。
7.根据权利要求6所述的一种flash存储器数据管理方法,其特征在于,e2步骤中,还包括以下步骤:
e21、检测所述表头区数据中有效的所述数据索引信息节点;
e22、将所述数据索引信息节点拷贝至所述备份区,擦除满载的所述表头区;
e23.形成空白所述表头区将备份区数据拷贝至空白所述表头区,擦除所述备份区数据;
e24、更新所述数据索引信息节点中所述表头区索引信息节点地址。
8.根据权利要求6所述的一种flash存储器数据管理方法,其特征在于,e3步骤中,还包括以下步骤:
e31、将所述数据区数据中拷贝至所述备份区,擦除满载的所述数据区;
e32、形成空白所述数据区将备份区数据拷贝至空白所述数据区,擦除所述备份区数据;
e33、更新表头区索引信息节点地址中数据ID相对应的所述数据地址。
CN202110396488.4A 2021-04-13 2021-04-13 一种flash存储器数据管理方法 Pending CN113094369A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110396488.4A CN113094369A (zh) 2021-04-13 2021-04-13 一种flash存储器数据管理方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110396488.4A CN113094369A (zh) 2021-04-13 2021-04-13 一种flash存储器数据管理方法

Publications (1)

Publication Number Publication Date
CN113094369A true CN113094369A (zh) 2021-07-09

Family

ID=76676903

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110396488.4A Pending CN113094369A (zh) 2021-04-13 2021-04-13 一种flash存储器数据管理方法

Country Status (1)

Country Link
CN (1) CN113094369A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110968268A (zh) * 2019-11-15 2020-04-07 成都智邦科技有限公司 一种基于spiflash的存储管理方法及存储结构

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101634957A (zh) * 2008-07-23 2010-01-27 佛山市顺德区顺达电脑厂有限公司 flash存储器的数据管理方法及其系统
CN102572330A (zh) * 2010-12-29 2012-07-11 厦门华侨电子股份有限公司 一种液晶电视机Flash芯片的数据读取、写入和擦除的方法
CN103268294A (zh) * 2013-04-19 2013-08-28 深圳创维数字技术股份有限公司 一种存取数据的操作方法和数据处理设备
CN103914407A (zh) * 2012-12-30 2014-07-09 航天信息股份有限公司 一种sd卡掉电保护、恢复方法以及带有掉电保护的sd卡
US20170010833A1 (en) * 2013-12-24 2017-01-12 Feitian Technologies Co., Ltd. Data writing and reading methods for flash
CN106662985A (zh) * 2014-09-26 2017-05-10 英特尔公司 主机管理的非易失性存储器
CN106844226A (zh) * 2016-12-31 2017-06-13 昊宏广泰(北京)科技有限公司 基于norflash的宽带载波从节点控制方法
CN109271100A (zh) * 2018-08-28 2019-01-25 深圳智芯数据服务有限公司 一种Flash存储器数据存储方法和读取方法
CN112463020A (zh) * 2019-09-09 2021-03-09 杭州海康威视数字技术股份有限公司 基于Flash的数据存取方法、装置及设备

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101634957A (zh) * 2008-07-23 2010-01-27 佛山市顺德区顺达电脑厂有限公司 flash存储器的数据管理方法及其系统
CN102572330A (zh) * 2010-12-29 2012-07-11 厦门华侨电子股份有限公司 一种液晶电视机Flash芯片的数据读取、写入和擦除的方法
CN103914407A (zh) * 2012-12-30 2014-07-09 航天信息股份有限公司 一种sd卡掉电保护、恢复方法以及带有掉电保护的sd卡
CN103268294A (zh) * 2013-04-19 2013-08-28 深圳创维数字技术股份有限公司 一种存取数据的操作方法和数据处理设备
US20170010833A1 (en) * 2013-12-24 2017-01-12 Feitian Technologies Co., Ltd. Data writing and reading methods for flash
CN106662985A (zh) * 2014-09-26 2017-05-10 英特尔公司 主机管理的非易失性存储器
CN106844226A (zh) * 2016-12-31 2017-06-13 昊宏广泰(北京)科技有限公司 基于norflash的宽带载波从节点控制方法
CN109271100A (zh) * 2018-08-28 2019-01-25 深圳智芯数据服务有限公司 一种Flash存储器数据存储方法和读取方法
CN112463020A (zh) * 2019-09-09 2021-03-09 杭州海康威视数字技术股份有限公司 基于Flash的数据存取方法、装置及设备

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110968268A (zh) * 2019-11-15 2020-04-07 成都智邦科技有限公司 一种基于spiflash的存储管理方法及存储结构
CN110968268B (zh) * 2019-11-15 2023-03-17 成都智邦科技有限公司 一种基于spiflash的存储管理方法及存储结构

Similar Documents

Publication Publication Date Title
US6675281B1 (en) Distributed mapping scheme for mass storage system
CN101493794B (zh) 一种闪存数据处理方法及装置
CN100424655C (zh) 快闪存储器管理方法
US8041884B2 (en) Controller for non-volatile memories and methods of operating the memory controller
US8312204B2 (en) System and method for wear leveling in a data storage device
US7554855B2 (en) Hybrid solid-state memory system having volatile and non-volatile memory
CN112395212B (zh) 减少键值分离存储系统的垃圾回收和写放大的方法及系统
CN102737715B (zh) 用于nor闪存的数据掉电保护方法
US8296503B2 (en) Data updating and recovering methods for a non-volatile memory array
CN112612418B (zh) 一种用于大容量NandFlash坏块管理的方法及系统
JPWO2006067923A1 (ja) メモリコントローラ、不揮発性記憶装置、不揮発性記憶システム及びメモリ制御方法
US6839798B1 (en) Flash memory capable of storing frequently rewritten data
CN109669889B (zh) 一种轻量型Nor Flash闪存控制方法和装置
WO2019160727A1 (en) Append only streams for storing data on a solid state device
CN113190180A (zh) 一种基于混合介质的存储装置及分布式存储系统
CN113641629A (zh) 一种flash存储器的文件写入和读取方法
CN115878033A (zh) 一种固态硬盘及其映射表管理方法
CN113094369A (zh) 一种flash存储器数据管理方法
CN116540950B (zh) 一种存储器件及其写入数据的控制方法
CN111913890B (zh) 一种基于安全模组的非易失存储器随机化读写方法
WO2019136969A1 (zh) 一种实体位置映到逻辑映像位置的高效能方法
CN108376121B (zh) 一种Flash存储器的数据存储方法
CN105677244A (zh) 一种降低tlc闪存的固态硬盘写放大的方法
CN111949212B (zh) 基于自定义开放通道ssd的文件系统及文件管理方法
CN110633056B (zh) 在操作系统层面的Flash芯片的页面管理方法及存储设备

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

Country or region after: China

Address after: 518000 1st, 2nd, 4th, 5th and 6th floors of Qiufen (10A) Building, Taihua wutong Industrial Park, Sanwei Community, Hangcheng Street, Bao'an District, Shenzhen, Guangdong

Applicant after: Shenzhen Moyang Technology Co.,Ltd.

Address before: 518000 3 storey of 6B, Wutong Industrial Park, Guangdong, Baoan District, Shenzhen. In Hangcheng street, Hangkong Road, 3 / F, building B, Fengze building, Nanchang Huafeng Second Industrial Park, there is a business place engaged in production and business activities

Applicant before: SHENZHEN MOYOUNG TECHNOLOGY CO.,LTD.

Country or region before: China

CB02 Change of applicant information