CN103823766B - Flash存储器的高效率存储方法 - Google Patents

Flash存储器的高效率存储方法 Download PDF

Info

Publication number
CN103823766B
CN103823766B CN201410074366.3A CN201410074366A CN103823766B CN 103823766 B CN103823766 B CN 103823766B CN 201410074366 A CN201410074366 A CN 201410074366A CN 103823766 B CN103823766 B CN 103823766B
Authority
CN
China
Prior art keywords
data
page
buffering
buffer
block
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.)
Active
Application number
CN201410074366.3A
Other languages
English (en)
Other versions
CN103823766A (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.)
Kotel Aerospace Defense Technology Co Ltd Shanxi
Original Assignee
Kotel Aerospace Defense Technology Co Ltd Shanxi
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 Kotel Aerospace Defense Technology Co Ltd Shanxi filed Critical Kotel Aerospace Defense Technology Co Ltd Shanxi
Priority to CN201410074366.3A priority Critical patent/CN103823766B/zh
Publication of CN103823766A publication Critical patent/CN103823766A/zh
Application granted granted Critical
Publication of CN103823766B publication Critical patent/CN103823766B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明Flash存储器的高效率存储方法,属于Flash存储器的数据存储方法的技术领域;解决的技术问题为:提供一种在数据量小和数据存储次数较频繁的情况下,能够使存储器的存储效率较高的Flash存储器的高效率存储方法;采用的技术方案为:Flash存储器的高效率存储方法,以块为单位将Flash存储器划分为不同的数据存储区域,再将每个数据存储区域均划分为多个缓冲块和多个数据块,其中,每个缓冲块又分为多个缓冲页,每个数据块又分为多个数据页,当接收到数据后,先将数据写入相应的数据存储区域中缓冲块的缓冲页中,当缓冲页写满后再将本页的数据存储至数据块的数据页中;适用于消防数据存储领域。

Description

Flash存储器的高效率存储方法
技术领域
本发明Flash存储器的高效率存储方法,属于Flash存储器的数据存储方法的技术领域。
背景技术
现今,Flash存储器作为主流存储器,无论是在民用、工业还是军工领域,都得到了大量的应用,目前Flash存储器进行数据存储的方式主要有两种,一种是数据以文件系统存储的方式,另一种是数据按物理块和页存储的方式,文件系统的存储是以簇为最小单位进行数据的存储,按物理块和页是以页为最小单位进行数据的存储;
在数据量较小和数据存储次数较频繁的情况下,每写一次数据(如几个字节),至少要占用一个簇(最小为4KB)或一页(最小为512个字节),使得Flash存储器的利用率大大减小,降低了Flash存储器的存储效率和使用寿命;此外,Flash存储器按照传统的存储方法存储数据时,想将数据写入内存页,直到将一页内存页写满后,才会全部一起存储至存储记录器,如果发生意外断电的情况,那么最新的数据将不会被及时保存,造成数据缺失,尤其对于消防领域来说,消防数据的缺失将造成消防现场的无法还原,给企事业单位和警务部门带来极大的不便和损失。
发明内容
本发明克服现有技术存在的不足,所要解决的技术问题为:提供一种在数据量小和数据存储次数较频繁的情况下,能够使存储器的存储效率较高的Flash存储器的高效率存储方法。
为了解决上述技术问题,本发明采用的技术方案为:Flash存储器的高效率存储方法,以块为单位将Flash存储器划分为不同的数据存储区域,再将每个数据存储区域均划分为多个缓冲块和多个数据块,其中,每个缓冲块又分为多个缓冲页,每个数据块又分为多个数据页,当接收到数据后,先将数据写入相应的数据存储区域中缓冲块的缓冲页中,当缓冲页写满后再将本页的数据存储至数据块的数据页中,具体包括以下步骤:
(1.1)接收数据;
(1.2)将数据写入缓冲块的缓冲页;
(1.3)判断缓冲块的当前缓冲页是否写满;
(1.4)如已写满,则进入步骤(1.5),否则,进入步骤(1.8);
(1.5)将缓冲块的前一缓冲页数据追加新数据后存至数据块的其中一页数据页;
(1.6)擦除整个缓冲块的内容;
(1.7)缓冲块地址+1,缓冲页地址置0,数据页地址+1,然后返回步骤(1.1);
(1.8)将缓冲块的前一缓冲页数据追加新数据后存至当前缓冲页,缓冲页地址+1,最后返回步骤(1.1)。
步骤(1.8)中,将缓冲块的前一缓冲页数据追加新数据后存至当前缓冲页、缓冲页地址+1之后,先判断当前缓冲页是否是缓冲块的最后一页,若是,则备份最后一个缓冲页的内容,并且擦除整个缓冲块的内容,然后将备份数据保存至新的缓冲块的第一页,缓冲页地址置0,最后才返回步骤(1.1),否则,直接返回步骤(1.1)。步骤(1.7)中,缓冲块地址+1、缓冲页地址置0、数据页地址+1之后,先判断数据块的每个数据页是否写满,如已写满,则将数据块地址+1后才返回步骤(1.1),否则,直接返回步骤(1.1)。
本发明与现有技术相比具有以下有益效果:
本发明中的存储方法采用了对数据进行及时存储的方式,先以块为单位将存储器划分为不同的数据存储区域,不同的数据存储区域中存储不同类型的数据,再将各个数据存储区域中的块分为两种类型:数据块和缓冲块,又将各个块划分为页,即数据块包括多个数据页、缓冲块包括多个缓冲页,当接收到数据后,先将数据写入相应的数据存储区域中缓冲块的缓冲页,如果缓冲页内已经保存有数据、且该缓冲页未写满,则将最新的数据连同之前的数据一起写入一个新的缓冲页中,若该缓冲页已写满,则将最新的数据连同之前的数据一起保存至数据块的数据页中,这种情况下,Flash存储器的利用率和存储效率大大提高,即使意外断电,最新的不满一页的全部数据也可以在最新的页中找到,既保证了数据的完整性、安全性,也提高了存储器的使用寿命。
附图说明
下面结合附图对本发明做进一步详细的说明。
图1为本发明的方法流程图。
具体实施方式
Flash存储器的高效率存储方法,以块为单位将Flash存储器划分为不同的数据存储区域,再将每个数据存储区域均划分为多个缓冲块和多个数据块,其中,每个缓冲块又分为多个缓冲页,每个数据块又分为多个数据页,当接收到数据后,先将数据写入相应的数据存储区域中缓冲块的缓冲页中,当缓冲页写满后再将本页的数据存储至数据块的数据页中,如图1所示,具体包括以下步骤:
(1.1)接收数据;
(1.2)将数据写入缓冲块的缓冲页;
(1.3)判断缓冲块的当前缓冲页是否写满;
(1.4)如已写满,则进入步骤(1.5),否则,进入步骤(1.8);
(1.5)将缓冲块的前一缓冲页数据追加新数据后存至数据块的其中一页数据页;
(1.6)擦除整个缓冲块的内容;
(1.7)缓冲块地址+1,缓冲页地址置0,数据页地址+1,判断数据块的每个数据页是否写满,如已写满,则将数据块地址+1后才返回步骤(1.1),否则,直接返回步骤(1.1);
(1.8)将缓冲块的前一缓冲页数据追加新数据后存至当前缓冲页,缓冲页地址+1,判断当前缓冲页是否是缓冲块的最后一页,若是,则备份最后一个缓冲页的内容,并且擦除整个缓冲块的内容,然后将备份数据保存至新的缓冲块的第一页,缓冲页地址置0,最后才返回步骤(1.1),否则,直接返回步骤(1.1)。
一个数据存储区域中,一个数据块的逻辑地址的前一逻辑地址和后一逻辑地址均为不同缓冲块的逻辑地址,一个缓冲块的逻辑地址的前一逻辑地址和后一逻辑地址均为不同数据块的逻辑地址,即每一数据块的逻辑地址和每一缓冲块的逻辑地址总是相邻的,假如当前存储区域的最后一块为数据块,那么当前存储区域的第一块为缓冲块,假如当前存储区域的第一块为数据块,那么当前存储区域的第二块为缓冲块。
一般地,存储模块的使用率(R)=有效的存储空间/实际的占用空间,当数据量较小和数据存储次数较频繁时,将传统的文件系统存储方式和本发明中存储方法的及时存储技术进行对比,以一页32KB为例,每次存储32个字节的信息,连续存储1500次,可以得到下列表1:
表1
从表1中不难看出,在数据量小和数据存储次数较频繁的情况下,本发明中存储方法的及时存储技术在存储模块使用率上大大优于文件系统的存储方式。
而存储模块有效使用寿命=(存储区域内总块数×存储区域内总页数)/(2×存储模块有效使用次数),可知,存储模块的有效使用寿命与存储模块的有效使用次数成反比,当存储模块大小一定时,使用本发明中存储方法的存储块动态分配技术以后,有效降低了存储模块的使用次数,延长了存储模块的有效使用寿命,达到了提高存储器使用效率的目的。
本发明Flash存储器的高效率存储方法,经过测试,验证了其具有延长存储模块的使用寿命、提高存储模块的存储效率的效果,具有突出的实质性特点和显著的进步;上面结合附图对本发明作了详细说明,但是本发明并不限于上述实施例,应当指出,在本领域普通技术人员所具备的知识范围内,还可以在不脱离本发明宗旨的前提下作出各种变化。

Claims (2)

1.Flash存储器的高效率存储方法,其特征在于:以块为单位将Flash存储器划分为不同的数据存储区域,再将每个数据存储区域均划分为多个缓冲块和多个数据块,其中,每个缓冲块又分为多个缓冲页,每个数据块又分为多个数据页,当接收到数据后,先将数据写入相应的数据存储区域中缓冲块的缓冲页中,当缓冲页写满后再将本页的数据存储至数据块的数据页中,具体包括以下步骤:
(1.1)接收数据;
(1.2)将数据写入缓冲块的缓冲页;
(1.3)判断缓冲块的当前缓冲页是否写满;
(1.4)如已写满,则进入步骤(1.5),否则,进入步骤(1.8);
(1.5)将缓冲块的前一缓冲页数据追加新数据后存至数据块的其中一页数据页;
(1.6)擦除整个缓冲块的内容;
(1.7)缓冲块地址+1,缓冲页地址置0,数据页地址+1,然后返回步骤(1.1);
(1.8)将缓冲块的前一缓冲页数据追加新数据后存至当前缓冲页,缓冲页地址+1,最后返回步骤(1.1);
步骤(1.8)中,将缓冲块的前一缓冲页数据追加新数据后存至当前缓冲页、缓冲页地址+1之后,先判断当前缓冲页是否是缓冲块的最后一页,若是,则备份最后一个缓冲页的内容,并且擦除整个缓冲块的内容,然后将备份数据保存至新的缓冲块的第一页,缓冲页地址置0,最后才返回步骤(1.1),否则,直接返回步骤(1.1)。
2.根据权利要求1所述的Flash存储器的高效率存储方法,其特征在于:步骤(1.7)中,缓冲块地址+1、缓冲页地址置0、数据页地址+1之后,先判断数据块的每个数据页是否写满,如已写满,则将数据块地址+1后才返回步骤(1.1),否则,直接返回步骤(1.1)。
CN201410074366.3A 2014-03-03 2014-03-03 Flash存储器的高效率存储方法 Active CN103823766B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410074366.3A CN103823766B (zh) 2014-03-03 2014-03-03 Flash存储器的高效率存储方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410074366.3A CN103823766B (zh) 2014-03-03 2014-03-03 Flash存储器的高效率存储方法

Publications (2)

Publication Number Publication Date
CN103823766A CN103823766A (zh) 2014-05-28
CN103823766B true CN103823766B (zh) 2017-03-22

Family

ID=50758845

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410074366.3A Active CN103823766B (zh) 2014-03-03 2014-03-03 Flash存储器的高效率存储方法

Country Status (1)

Country Link
CN (1) CN103823766B (zh)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106354669B (zh) * 2015-07-13 2021-03-26 国民技术股份有限公司 一种具有分级结构的存储器
CN108628752B (zh) * 2017-03-17 2021-10-01 北京兆易创新科技股份有限公司 一种数据存储方法和装置
CN113377296B (zh) * 2021-08-16 2021-11-16 深圳市有为信息技术发展有限公司 车载终端NAND Flash的存储管理方法和系统、车载终端、车辆
CN115909544A (zh) * 2022-12-13 2023-04-04 江苏都万电子科技有限公司 一种存储器及存储方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101464834A (zh) * 2007-12-19 2009-06-24 群联电子股份有限公司 闪存数据写入方法及使用此方法的控制器
CN102306124A (zh) * 2011-08-01 2012-01-04 深圳市文鼎创数据科技有限公司 Nand Flash芯片硬件驱动层的实现方法
CN103246615A (zh) * 2013-04-24 2013-08-14 深圳市江波龙电子有限公司 一种闪存存储设备中数据管理的方法及装置
CN103488583A (zh) * 2013-09-09 2014-01-01 华中科技大学 一种高性能高可靠的固态盘实现方法
CN103823640A (zh) * 2014-03-03 2014-05-28 山西科泰微技术有限公司 一种Flash存储器的高效率存储方法

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101464834A (zh) * 2007-12-19 2009-06-24 群联电子股份有限公司 闪存数据写入方法及使用此方法的控制器
CN102306124A (zh) * 2011-08-01 2012-01-04 深圳市文鼎创数据科技有限公司 Nand Flash芯片硬件驱动层的实现方法
CN103246615A (zh) * 2013-04-24 2013-08-14 深圳市江波龙电子有限公司 一种闪存存储设备中数据管理的方法及装置
CN103488583A (zh) * 2013-09-09 2014-01-01 华中科技大学 一种高性能高可靠的固态盘实现方法
CN103823640A (zh) * 2014-03-03 2014-05-28 山西科泰微技术有限公司 一种Flash存储器的高效率存储方法

Also Published As

Publication number Publication date
CN103823766A (zh) 2014-05-28

Similar Documents

Publication Publication Date Title
CN103823640B (zh) 一种Flash存储器的高效率存储方法
CN102843396B (zh) 一种分布式缓存系统中的数据写入及读取方法及装置
CN103823766B (zh) Flash存储器的高效率存储方法
US9798472B1 (en) Extent level cache destaging
CN103678169B (zh) 一种高效利用固态盘缓存的方法和系统
CN103473150B (zh) 一种用于数据去重系统中的碎片重写方法
CN103092927B (zh) 一种分布式环境下的文件快速读写方法
CN102521269A (zh) 一种基于索引的计算机连续数据保护方法
CN102360342A (zh) 海量影像数据快速存储显示固态硬盘
CN105389376B (zh) 基于连续块的无碎片化多媒体数据存储方法及系统
CN110196818A (zh) 缓存数据的方法、缓存设备和存储系统
CN105393228A (zh) 读写闪存中数据的方法、装置及用户设备
CN104375944B (zh) 一种数据存储方法和装置
CN102999441A (zh) 一种细粒度内存访问的方法
CN102541755B (zh) 闪存存储器及其接收数据的方法
CN105005510A (zh) 应用于固态硬盘阻变存储器缓存的纠错保护架构及方法
CN104811646B (zh) 基于连续存储模型的多视频流数据并发调制及缓冲的存储方法
CN106951182A (zh) 一种块设备缓存方法和装置
CN102779098B (zh) 混合缓存的协同式自适应预取方法、装置和系统
CN101594201B (zh) 链式队列管理结构整合错误数据过滤的方法
CN106980469A (zh) 一种提高固态硬盘顺序写缓存效率的方法
CN102629235A (zh) 一种提高ddr存储器读写速率的方法
CN102130939A (zh) 一种远程复制方法及装置
CN102521157B (zh) 一种在fpga上实现板载存储资源管理的系统和方法
CN105446895A (zh) 一种存储系统非同源数据运行时io去重的方法及系统

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
CB02 Change of applicant information

Address after: 030006 Taiyuan province high tech Zone, digital road, No. 3, No.

Applicant after: KOTEL SPACEFLIGHT DEFENSE TECHNOLOGY Co.,Ltd. SHANXI

Address before: 030006 No. 3, digital road, hi tech Development Zone, Shanxi, Taiyuan, China

Applicant before: Kotel Micro Technique Co.,Ltd. Shanxi

COR Change of bibliographic data
C14 Grant of patent or utility model
GR01 Patent grant
PE01 Entry into force of the registration of the contract for pledge of patent right
PE01 Entry into force of the registration of the contract for pledge of patent right

Denomination of invention: High-efficiency storage method of Flash storage

Effective date of registration: 20170928

Granted publication date: 20170322

Pledgee: Datong bank Limited by Share Ltd.

Pledgor: KOTEL SPACEFLIGHT DEFENSE TECHNOLOGY Co.,Ltd. SHANXI

Registration number: 2017140000018

PC01 Cancellation of the registration of the contract for pledge of patent right
PC01 Cancellation of the registration of the contract for pledge of patent right

Date of cancellation: 20231213

Granted publication date: 20170322

Pledgee: Datong bank Limited by Share Ltd.

Pledgor: KOTEL SPACEFLIGHT DEFENSE TECHNOLOGY Co.,Ltd. SHANXI

Registration number: 2017140000018

PE01 Entry into force of the registration of the contract for pledge of patent right
PE01 Entry into force of the registration of the contract for pledge of patent right

Denomination of invention: Efficient storage methods for Flash memory

Effective date of registration: 20231215

Granted publication date: 20170322

Pledgee: Shanxi Bank Co.,Ltd. Datong Branch

Pledgor: KOTEL SPACEFLIGHT DEFENSE TECHNOLOGY Co.,Ltd. SHANXI

Registration number: Y2023140000068