CN113703664B - 一种eMMC芯片随机写入速率优化实现方法 - Google Patents

一种eMMC芯片随机写入速率优化实现方法 Download PDF

Info

Publication number
CN113703664B
CN113703664B CN202110706011.1A CN202110706011A CN113703664B CN 113703664 B CN113703664 B CN 113703664B CN 202110706011 A CN202110706011 A CN 202110706011A CN 113703664 B CN113703664 B CN 113703664B
Authority
CN
China
Prior art keywords
writing
data
random
emmc chip
written
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
CN202110706011.1A
Other languages
English (en)
Other versions
CN113703664A (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.)
Hangzhou Dianzi University
Original Assignee
Hangzhou Dianzi University
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 Hangzhou Dianzi University filed Critical Hangzhou Dianzi University
Priority to CN202110706011.1A priority Critical patent/CN113703664B/zh
Publication of CN113703664A publication Critical patent/CN113703664A/zh
Application granted granted Critical
Publication of CN113703664B publication Critical patent/CN113703664B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • 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/061Improving I/O performance
    • 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/0629Configuration or reconfiguration of storage systems
    • G06F3/0631Configuration or reconfiguration of storage systems by allocating resources to storage systems
    • 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/0644Management of space entities, e.g. partitions, extents, pools
    • 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]

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)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Signal Processing For Digital Recording And Reproducing (AREA)

Abstract

本发明公开了一种eMMC芯片随机写入速率优化实现方法,包括以下步骤:S1,对eMMC芯片进行数据写入;S2,对写入方式进行判断;S3,如是随机写入,则写入额外配置区域;如是顺序写入,则写入用户区域;S4,根据映射关系表在数据前附加标签;S5,合并数据写入用户区域。本发明针对顺序写入占据大多数的数据传输方式,将随机写入合成顺序写入方式的做法能够有效地提高随机数据写入的速率。

Description

一种eMMC芯片随机写入速率优化实现方法
技术领域
本发明属于数据存储技术领域,涉及一种eMMC芯片随机写入速率优化实现方法。
背景技术
为了满足平板、手机等电子器件移动性的需求,在轻薄、低功耗的前置要求下,eMMC(Embedded Multi Media Card,嵌入式多媒体控制器)诞生了。所以eMMC接口是用IOpin来定义的,这样接口简单,功耗低;另外eMMC 对于苹果iPad、安卓平板电脑、手机的作用也是巨大的,平板和手机都比较小,所以eMMC是把控制器和NAND颗粒封装在一个package里面,这也造成 eMMC不能放很多NAND颗粒,容量比较低。
总结eMMC特点就是功耗低,容量小,随机读写性能相对较差;
作为芯片的其中一种数据交互方式,随机读写主要是相对于顺序读写提出来的,从字面意义上来理解,如果说顺序读写是在读写过程之中遵循先后顺序,每次存取数据请求的地址都是连续的。那么随机读写就是不遵循固定的先后顺序,在进行读写操作的时候,能够任意切换到某个位置上对数据进行读写操作。
以顺序写入的方式做类比来说明随机写入的问题。简单地讲,如果顺序写入的数据是按照从位置1、2、3、4这样顺序的一个个写下去的,那么,相连的数据之间地址上也会是连续的,并且eMMC的逻辑块地址DirectEBA与物理块地址PhyEBA是相等,具备较快的数据传输速率。然而随机写入的方式,数据写入的位置是不固定的。例如在写完第一个数据之后,下一个数据的位置可能是在第一个数据地址再间隔一段的位置,而再下一个数据的写入位置又可能会出现在前几个数据之间,造成的结果就是数据之间是十分割裂的,其DirectEBA与PhyEBA之间并不相等。也因为每次写入的地址跳跃等问题,数据写入速率十分缓慢,这也是随机写入的缺点,更加耗时。
发明内容
为解决上述问题,本发明提出了一种eMMC芯片随机写入速率优化实现方法,包括以下步骤:
S1,对eMMC芯片进行数据写入;
S2,对写入方式进行判断;
S3,如是随机写入,则写入额外配置区域;
如是顺序写入,则写入用户区域;
S4,根据映射关系表在数据前附加标签;
S5,合并数据写入用户区域。
优选地,所述对写入方式进行判断具体为当写入的数据扇区的数量等于或超过N时,判定为顺序写入;当写入的数据扇区的数量小于N时,判定为随机写入,其中N为32。
优选地,所述映射关系表中每4个字节的逻辑地址对应4个字节的物理地址。
优选地,所述eMMC芯片被分为M个区域,每个区域中用1bit数据表示顺序写入和随机写入。
优选地,所述每个区域中用1bit数据为0时表示顺序写入,为1时表示随机写入。
优选地,所述标签的大小为4KB。
优选地,所述标签的组成依次为逻辑地址、物理地址、数据扇区数量、标签数量、标签标记和总检验位。
优选地,所述额外配置区域的构成为依次设置的标签和随机数据,以此类推重复。
本发明有益效果至少包括:
1)为了能提升eMMC芯片在随机写入数据时的速率,本发明通过将原来相对割裂的随机数据,组合成顺序连续的数据进行写入,使得传输速率本来比较慢的随机写入方式能够像顺序写入一样具备比较高的传输速率;
2)随机数据之间相对位置关系,通过附加Tag的方式,提供了从logicalEBA 到PhyEBA的映射关系来保证最终写入到存储中的数据之间,不会因此出现错位关系;
3)针对顺序写入占据大多数的数据传输方式,这种将随机写入统合成顺序写入方式的做法能够有效地提高随机数据写入的速率。
附图说明
图1为本发明实施例的eMMC芯片随机写入速率优化实现方法的eMMC 的数据排列示意图;
图2为本发明实施例的eMMC芯片随机写入速率优化实现方法的步骤流程图;
图3为本发明实施例的eMMC芯片随机写入速率优化实现方法的顺序写入和随机写入示意图;
图4为本发明实施例的eMMC芯片随机写入速率优化实现方法的映射关系表示意图;
图5为本发明实施例的eMMC芯片随机写入速率优化实现方法的标签构成示意图;
图6为本发明实施例的eMMC芯片随机写入速率优化实现方法的随机写入对比图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
相反,本发明涵盖任何由权利要求定义的在本发明的精髓和范围上做的替代、修改、等效方法以及方案。进一步,为了使公众对本发明有更好的了解,在下文对本发明的细节描述中,详尽描述了一些特定的细节部分。对本领域技术人员来说没有这些细节部分的描述也可以完全理解本发明。
参见图1,从eMMC数据排列可以看出,eMMC中存在正常的用户区域 User Area以及固定的额外配置Fixed OP(over provisioning),一般而言,用户正常查看数据的位置是位于User Area处。
而本发明优化的思路则是,将需要进行随机写入的数据通过顺序写入的方式写到OP区域进行顺序化的组合到一起,最后让硬件在闲置情况下将这一部分数据合并到用户区域。
参见图2,为本发明的方法流程图,包括:S1,对eMMC芯片进行数据写入;
S2,对写入方式进行判断;
S3,如是随机写入,则写入额外配置区域;
如是顺序写入,则写入用户区域;
S4,根据映射关系表在数据前附加标签;
S5,合并数据写入用户区域。
参见图3,以通道0所连接的eMMC0举例说明:设置的顺序写入和随机写入的判断条件是,当需要写入的sector(数据扇区),大小为512个字节, sector数量等于或超过32个时,认为写入的数据是顺序的,当sector数量小于 32个时,认为数据是随机写入的,用来模拟顺序写入和随机写入的情况。LBA 英文全称为Logic Block Address,与DirectEBA同样是逻辑块地址,但是二者之间是有区别的。以图1为例,数据写入过程中,为了使数据写入能够均衡,使用多个通道写入不同的EMMC中,因此写入满一定块大小以后需要切换到不同channel(通道)进行。LBA针对是多通道下的数据的逻辑块地址,而 DirectEBA则是具体针对某一个通道,例如channel0中,数据写入的逻辑块首地址。
可以看到,图3中第一次写入位置为LBA为32的情况下,64k的sector 数据大小对应的sector计数数量为128,因为单个sector的大小为512个字节,这里的64k其实指代的是总的sector大小,1k的数据相当于两个sector计数,而我们用来判断是否有随机数据的依据,是sector的计数数量,也就是sector count是否大于32,所以这里的sector数量为128。另外,这里选择64k大小的 sector扇区大小只是为了举例说明,所设定的大于随机与顺序写入阈值关系的值,所以是顺序写入,直接将数据写入到User Area的对应LBA位置就行,这是因为顺序写入的时候DirectEBA和PhyEBA是相同的,而第二次,LBA为 34,但是因为sector数量为4,所以是随机写入,这种情况下,我们是将数据写入到OP区域,即额外配置区域。需要注意的是,因为LBA是34,针对同一个DirectEBA而言,还缺少前面的32和33的数据以及后面的一部分数据,所以需要从用户区域User Area位置将剩下的数据拷贝到OP区域,这样保证了 OP区域的数据才是最新的有效数据。第三次的写入与第二次类似,这次则是将数据追加在第二次写入数据的后面,保证了随机数据在OP区域内都是顺序的。
参见图4为映射关系表Mapping Table中DirectEBA与PhyEBA的映射关系示意图,要如何保证这些被组合成顺序方式的随机数据在回写到User Area 区域的顺序是正确的呢?故关于DirectEBA与PhyEBA之间是存在一张总的映射关系表Mapping Table来提供位置关系的。针对顺序写入,DirectEBA与 PhyEBA之间是相等的,而对于随机写入,二者则并不相等。
可以看到,关于地址的表示是需要4个bytes的,为了缩减映射表的大小。我们将整个eMMC分为了32个区域Region(这个容量依赖于所选择的eMMC 本身的容量而变化,以一个具备4个eMMC的256G的盘为例,单个eMMC 的容量为64G,所以切分为32个Region以后每个Region大小为2G),每个区域仅使用bit0来表示该区域是顺序写入的,bit1表示该区域是存在随机写入的,因此,对于那些顺序写入占大多数,随机写入表示少的情况,对于顺序写入的映射关系,利用顺序写入的DirectEBA和PhyEBA之间相等的特性,我们仅需用1bit的数据0替代原来的4bytes,而随机写入的映射关系,则是通过bit=1 的情况表明是随机写入以后,从而再去找Mapping Table(Mapping Table的组成就是像上述图4所描述的那样,每4个bytes的eMMC逻辑地址对应4个bytes 的eMMC物理地址,完整的映射表就是由这样的一系列映射关系组所组成的。保证了我们在写入数据的时候,通过eMMC逻辑地址,依靠映射表将数据写入正确的物理地址位置。)这张总表,通过这种方式可以有效提高查表的效率。
接下来,最为关键。就是需要给写在OP区域的随机数据提供必要的 DirectEBA信息了,如前述,对于随机写入而言,它的DirectEBA与PhyEBA 之间并不相等,所以需要有一个映射关系表,只有添加了这一部分信息才能保证掉电情况下也不会丢失随机写入数据的关于DirectEBA与PhyEBA的映射关系,从而保证随机数据能够正确回写到eMMC原来的逻辑块位置。
参见图5为随机写入数据的Tag及其构成。其中纵向额外配置区的构成,这4部分内容其实可以看成是两个部分,因为其系列构成都是一个大小为4KB 的random Write Tag加上一组随机数据,所以后面和一部分其实和前面是一样的概念,只不过后者Tag的具体内容与随机数据与前半部分并不一致而已。
然后,关于Random Write Tag,他的构成内容就是横向标签所展示出的这一部分。大小一共是4KB。构成上依次为:1)DirectEBA就是eMMC的逻辑地址、2)PhyEBA则是eMMC的物理地址、3)Sector Count如上面提示的,是对写入的SATA命令中sector计数的数量,也是证明后续跟随发送的数据包含随机数据(这个数量会大于32的阈值)、4)Tag Count是为了保证所顺序串接的随机数据之间的前后关系不会紊乱,因为是将随机数据串接成顺序的形式进行写入,后面的数据理应是追加而不是覆盖前方的数据,所以Tag的不同也能看出随机数据的先后关系、5)Tag Flag以及CheckSum这些是为了保证写入时候数据的正确性,因为任何数据写入的时候,各式各样的干扰都可能会造成写入数据出错的问题,数据错位或者是1写成0,0写成1,这些都会导致数据写入出错,检验和CheckSum便是为了能够在写入数据出错的时候提供校验而附加的校验位。
然后就是Data of Random Cmd,这部分便是需要顺序化串接写入的随机数据。
参见图5中的OP Area,需要在每次写入随机数据之前,给写入的数据添加一个Tag,Tag记录了关于随机写入的映射信息。这样一来就能够保证,虽然将需要随机写入的信息通过组合到一起顺序地写入,但是最终存储到User Area处的数据内容能够保证不会出现错位的情况。而且需要注意的是,在写之前,是需要对OP区域进行trim(擦除)的,优化之后的随机写入方式参见图 6。
以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内所作的任何修改、等同替换和改进等,均应包含在本发明的保护范围之内。

Claims (5)

1.一种eMMC芯片随机写入速率优化实现方法,其特征在于,包括以下步骤:
S1,对eMMC芯片进行数据写入;
S2,对写入方式进行判断;
S3,如是随机写入,则写入额外配置区域;
如是顺序写入,则写入用户区域;
S4,根据映射关系表在数据前附加标签;
S5,合并数据写入用户区域;
其中,
所述映射关系表中每4个字节的逻辑地址对应4个字节的物理地址;
所述标签的组成依次为逻辑地址、物理地址、数据扇区数量、标签数量、标签标记和总检验位;
所述额外配置区域的构成为依次设置的标签和随机数据,以此类推重复。
2.根据权利要求1所述的eMMC芯片随机写入速率优化实现方法,其特征在于,所述对写入方式进行判断具体为当写入的数据扇区的数量等于或超过N时,判定为顺序写入;当写入的数据扇区的数量小于N时,判定为随机写入,其中N为32。
3.根据权利要求1所述的eMMC芯片随机写入速率优化实现方法,其特征在于,所述eMMC芯片被分为M个区域,每个区域中用1bit数据表示顺序写入和随机写入。
4.根据权利要求3所述的eMMC芯片随机写入速率优化实现方法,其特征在于,所述每个区域中用1bit数据为0时表示顺序写入,为1时表示随机写入。
5.根据权利要求1所述的eMMC芯片随机写入速率优化实现方法,其特征在于,所述标签的大小为4KB。
CN202110706011.1A 2021-06-24 2021-06-24 一种eMMC芯片随机写入速率优化实现方法 Active CN113703664B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110706011.1A CN113703664B (zh) 2021-06-24 2021-06-24 一种eMMC芯片随机写入速率优化实现方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110706011.1A CN113703664B (zh) 2021-06-24 2021-06-24 一种eMMC芯片随机写入速率优化实现方法

Publications (2)

Publication Number Publication Date
CN113703664A CN113703664A (zh) 2021-11-26
CN113703664B true CN113703664B (zh) 2024-05-03

Family

ID=78648198

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110706011.1A Active CN113703664B (zh) 2021-06-24 2021-06-24 一种eMMC芯片随机写入速率优化实现方法

Country Status (1)

Country Link
CN (1) CN113703664B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117785071B (zh) * 2024-02-27 2024-05-24 合肥康芯威存储技术有限公司 一种存储器及其性能优化方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104461397A (zh) * 2014-12-19 2015-03-25 上海新储集成电路有限公司 一种固态硬盘及其读写方法
CN104503710A (zh) * 2015-01-23 2015-04-08 福州瑞芯微电子有限公司 一种提高闪存写入速度的方法和装置
CN104679437A (zh) * 2013-11-27 2015-06-03 群联电子股份有限公司 数据写入方法、存储器控制电路单元与存储器储存装置
CN109656486A (zh) * 2015-11-27 2019-04-19 华为技术有限公司 一种存储设备存储数据的方法及存储设备
CN110515789A (zh) * 2019-08-27 2019-11-29 江苏华存电子科技有限公司 一种提高eMMC写入效率及准确率的方法
CN110750214A (zh) * 2019-09-27 2020-02-04 广州妙存科技有限公司 一种兼顾eMMC存储器顺序读和随机读性能的方法

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9645924B2 (en) * 2013-12-16 2017-05-09 International Business Machines Corporation Garbage collection scaling
US9760281B2 (en) * 2015-03-27 2017-09-12 Intel Corporation Sequential write stream management

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104679437A (zh) * 2013-11-27 2015-06-03 群联电子股份有限公司 数据写入方法、存储器控制电路单元与存储器储存装置
CN104461397A (zh) * 2014-12-19 2015-03-25 上海新储集成电路有限公司 一种固态硬盘及其读写方法
CN104503710A (zh) * 2015-01-23 2015-04-08 福州瑞芯微电子有限公司 一种提高闪存写入速度的方法和装置
CN109656486A (zh) * 2015-11-27 2019-04-19 华为技术有限公司 一种存储设备存储数据的方法及存储设备
CN110515789A (zh) * 2019-08-27 2019-11-29 江苏华存电子科技有限公司 一种提高eMMC写入效率及准确率的方法
CN110750214A (zh) * 2019-09-27 2020-02-04 广州妙存科技有限公司 一种兼顾eMMC存储器顺序读和随机读性能的方法

Also Published As

Publication number Publication date
CN113703664A (zh) 2021-11-26

Similar Documents

Publication Publication Date Title
CN107844431B (zh) 映射表更新方法、存储器控制电路单元与存储器存储装置
US10007431B2 (en) Storage devices configured to generate linked lists
TW201426305A (zh) 虛擬記憶體設備驅動器、用於在主機上執行之虛擬記憶體設備驅動器、刷新快閃記憶體的方法、快閃記憶體刷新的方法、超級增強耐力設備硬碟固體狀態驅動機耐用轉換層之方法、超級增強耐力設備及耐力快閃記憶體檔案系統
CN104699413A (zh) 数据管理方法、存储器存储装置及存储器控制电路单元
CN103049224B (zh) 将数据导入物理磁带的方法、装置和系统
CN106201340B (zh) 一种存储数据的方法、存储设备、电子设备
CN105005450A (zh) 数据写入方法、存储器存储装置及存储器控制电路单元
CN103729149A (zh) 一种存储数据的方法
US9823844B2 (en) Memory management method, memory control circuit unit, and memory storage apparatus
US9384125B2 (en) Method for accessing flash memory having pages used for data backup and associated memory device
CN113703664B (zh) 一种eMMC芯片随机写入速率优化实现方法
CN113138720B (zh) 数据存储方法、存储器控制电路单元以及存储器存储装置
CN103389941A (zh) 存储器格式化方法、存储器控制器及存储器存储装置
CN102543184B (zh) 存储器储存装置、其存储器控制器与数据写入方法
CN104598169A (zh) 用于flash存储器的高可靠性数据读取方法
US11573908B1 (en) Mapping table management method, memory control circuit unit and memory storage device
US11972139B2 (en) Read voltage level correction method, memory storage device, and memory control circuit unit
CN102467459B (zh) 数据写入方法、存储器控制器与存储器储存装置
CN115525605A (zh) 一种文件系统的传输系统、方法
CN103064640B (zh) 应用于nandflash存储设备的快速读写方法
CN113504880A (zh) 存储器缓冲区管理方法、存储器控制电路单元与存储装置
CN102023934A (zh) 数据保护方法与系统、外接式存储装置及存储装置控制器
TW202145243A (zh) 資料儲存裝置與資料處理方法
KR20140101626A (ko) 솔리드 스테이트 드라이브의 데이터 처리 방법
US20100037004A1 (en) Storage system for backup data of flash memory and method for the same

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
GR01 Patent grant
GR01 Patent grant