闪存系统性能优化方向集锦?AC timing? Cache? 多路并发?
创始人
2024-06-03 07:25:00
0

1. 从Flash系统的性能提升说起

从消费级产品到数据中心企业级场景,NAND Flash凭借其高性能、大容量、低功耗以及低成本等特性大受欢迎,是目前应用最为广泛的半导体非易失存储介质。为了满足业务场景越来越严苛的性能要求,人们想了许多方法来提升基于NAND Flash的系统性能,具体可分为以下几类:

图一 Flash系统性能提升概览

  1. 优化AC Timing,提升总线频率

优化AC Timing 和提升总线频率是两个东西, 不是说优化AC Timing 会提升总线频率。优化AC Timing 是。优化总线频率可以减少数据在总线上的传输时间,频率越高,单位时间内传输的数据量越多。

1.1 优化AC Timing

在满足可靠传输的基础上,提升NAND Flash总线频率,尽可能使用较小的时序参数进行操作。特别是在Page Size越来越大(2K 4K 8K 16KB)的情况下,优化时序参数从而减小数据在总线上的传输时间显得尤为重要,这也是过去二十多年来人们一直在持续努力的方向。

优化NAND AC timing 是改善闪存的内因,AC timing 是性能的根本决定因素。我们都知道SLC NAND 比 MLC NAND 快, MLC NAND 比TLC NAND 快,其中就是他们的AC Timing 差异。姚明打篮球,可以轻松抢篮板,首先根本因素是他的身高优势,其他的训练技巧是锦上添花。

NAND 本身的AC timing,有些是NAND 控制的时间, 如tRead, tPROG 作为使用者是无法修改的, 这不是闪存系统优化考虑的事情,这种事情交给原厂下一个产品优化吧。有写AC timing 是系统上层控制的, 如tWC, tRC。 对于任何一款已量产NAND, 我们看它的data sheet, 它的AC Timing 都有 Min 值, Ave 值, Max 值。 之所以有一个min ~ max 范围, 主要是物理时序总会有一个差异性,正态分布,不可能是同一个值。闪存器件允许 host 的值有一定区间, 是为了兼容更多的闪存主机系统。

作为闪存系统或者闪存控制器, 为了提高性能, 最取巧的方式就是使用min的AC timing

优化NAND AC timing ,可给闪存带来显著的性能提升。

  • 这种优化方式是最简单的, 成本最小的,尤其是还没有做过此优化的闪存系统而言, 只需要改下闪存控制系统的记时、记数设定,可能就完成这个优化了

  • 可以显著减少总的闪存操作(如Read, Write)时间.

  • 为交叉操作(Interleave)优化打下了基础

当Page Size 从2KB, 4KB增大到 16KB ,越来越大的时候, 这个就更明显。

尤其时对于Read 操作特别明下, 因为Read 操作数据传输时间比Read Busy tR 更长。

下面看下AC timing 优化的实际效果, 以tWC 为例。

对于一款NAND, 原来tWC min 是20ns, 如果闪存主控的tWC 设置没有用 min 值, 用了更大的值, 会对性能影响多大呢? 通过对大量闪存主控实验可得出下面结果。

说明:

tWC 从 20ns增长25ns, 4KB data 传入到 NAND page 103ns,SLC program 总的耗时增加了 7%, TLC program 耗时增加了 2%。

tWC 从 20ns增长30ns, 4KB data 传入到 NAND page 123ns,SLC program 总的耗时增加了 14%, TLC program 耗时增加了 4%。这个实验做的次数最多, 用了 3 款主控做实验。

tWC 从 20ns增长45ns, 4KB data 传入到 NAND page 185ns,SLC program 总的耗时增加了 35%, TLC program 耗时增加了 10%。

很明显, tWC 变大,增加了数据从主控传入NAND 的时间, 继而导致Program总的时间增加。给我们的启发就是, 在超过tWC 的min 范围内, 主控尽量使用较小的 tWC。

对于其他AC Timing 也是这个道理。可能你会觉得有的值本来就很小, 觉得没必要优化, 其实不然,只要这个AC timing 在读写中经常出现, 就不应被忽略, 应优化尽优化。

雪崩的时候, 没有一片雪花是无辜的

1.2 优化总线频率

减小数据在总线上的传输时间还有一个方向是提高IO总线频率。频率就是带宽, 家里用上网对带宽感受特别明显,百兆带宽升级到千兆带宽,那滋味可美了不是吗?

对于闪存IO总线,比如总线接口速率为200Mbps (100MHz)时,完成4KB数据传输需要大约40us,但将总线接口速率提升到1600Mbps (800MHz)时,完成4KB数据传输仅需要大约5us。国产SSD 致钛7100 各项评测跑分都超过三星之流,得益于它的闪存 2400Mbps 频率。

2. 使用Cache Read/Program

一般情况下,LUN(Logic Unit Number)是NAND Flash最小的逻辑操作单元,读/写操作是串行执行的,即一个读/写命令完成后,才能进行下一个读/写操作。Cache Read/Program允许用户在NAND Flash Array Busy时,同时在总线上进行读/写数据传输,从而提高流水效率。

图 Cache Read 性能比较[6]

可提升33%的读性能。

图 Cache Program 性能比较[6]

可提升9%的写入性能。

3. 多路并发技术

正是因为有了多路并发技术,才使得基于NAND Flash的固态存储产品能达到GB级别的读/写性能。

3.1多平面(Multi Plane)操作

因为一个Die里有多个plane, 每个Plane 有独立的Cache 缓冲区和 Data 缓冲区,允许用户并发读/写Die内的不同Plane。

实现原理和细节参考:

[深入理解SSD系列 闪存实战2.1.6] NAND FLASH 多平面读(Multi Plane Read)时序及原理_闪存交错读时序(Interleave Read)_元存储的博客-CSDN博客

[深入理解SSD系列 闪存实战2.1.8] NAND FLASH Multi Plane Program(写)操作_multi plane 为何能提高闪存速度_元存储的博客-CSDN博客

3.2 通道内交错(Interleave)并发

允许用户在满足一定约束的情况下,在通道内的不同CE或CE内的不同Die之间进行交织操作

3.3多通道(channel)同时并发

允许用户在不同的通道上并发执行独立的命令和数据操作;

图. 双通道配置示例

两个通道可以同时传输数据和读写NAND, 速度是通道数目的倍数。一般在SSD 中有 2 channel、4 Channle、8 Channel,以4 Channle较常见。通道数目越多, 越可以达到 PCIE 总线的极限速度。

可见,以上优化覆盖了NAND Flash基础时序/指令优化到系统级的综合优化,在实际应用中可以根据系统要求组合选用。

参考

  1. 必看“芯”知识 | NAND Flash接口的演进史,https://www.unionmem.com/news_detail-107-56.html

  1. ONFI spec:http://www.onfi.org/specifications

  1. 2022, Phison, NAND Flash 101: Flash Device Interfaces:https://phisonblog.com/nand-flash-101-flash-device-interfaces-2/

  1. 2021, 移动NAND闪存存储的演进: https://phisonblog.com/the-evolution-of-mobile-nand-flash-memory-storage-2/

  1. 芯片中的数学——均衡器EQ和它在高速外部总线中的应用:https://zhuanlan.zhihu.com/p/48343011

  1. Micron, Optimizing NAND Flash Performance 2008, https://www.docin.com/p-232060088.html

相关内容

热门资讯

将安卓系统数据导入ios系统,... 你是不是也有过这样的经历:手机里存满了珍贵的照片、联系人、应用数据,突然有一天,你决定换一台iPho...
雷霆战机 安卓最低系统,系统要... 你有没有听说过这款超级酷炫的飞行游戏——雷霆战机?没错,就是那个让你一上手就停不下来的刺激游戏!今天...
电脑独立安装安卓系统,探索电脑... 电脑独立安装安卓系统:探索未来的可能性在当今这个数字化时代,电脑已经不仅仅是一个用来打字的工具,它更...
树莓派虚拟安卓系统,打造便携式... 你有没有想过,用树莓派来运行安卓系统?听起来是不是有点酷炫?想象一个迷你的小树莓派,竟然能变身成为一...
安卓系统如何安装tk,安卓系统... 你有没有想过,你的安卓手机里装个tk,生活是不是能变得更有趣呢?别急,别急,我来给你详细说说怎么操作...
安卓计步数系统,健康生活新伙伴 你有没有发现,每天手机里那个默默无闻的安卓计步数系统,竟然悄悄地记录了你走过的每一步?今天,就让我带...
安卓原生系统真的好吗,究竟是否... 你有没有想过,安卓原生系统到底是不是那个传说中的“好”?咱们今天就来聊聊这个话题,看看这个系统到底有...
安卓2.3系统开机画面,复古与... 亲爱的读者,你是否还记得那些充满怀旧情怀的安卓2.3系统开机画面?那个曾经陪伴我们度过无数时光的小图...
哪个安卓管理系统好,安卓管理系... 你有没有想过,手机里那么多应用,管理起来是不是有点头疼?别急,今天就来给你揭秘哪个安卓管理系统好,让...
安卓系统取消流量监控,告别流量... 你知道吗?最近安卓系统来了一次大动作,取消了对流量的监控!这可真是让人眼前一亮的消息呢。想象以前每次...
安卓导航如何备份系统,安卓导航... 你有没有想过,如果你的安卓导航系统突然崩溃了,你会怎么办?别急,今天就来给你支个招,教你如何轻松备份...
小米安卓4.0系统下载,深度解... 你有没有想过,你的小米手机是不是也能来个“大变身”?没错,就是升级到安卓4.0系统!想象你的手机瞬间...
自动鉴别平板安卓系统,自动鉴别... 你有没有想过,你的平板电脑里那些安卓系统,其实都是经过一番“智慧”的筛选和鉴别才来到你面前的呢?没错...
bose能连安卓系统,开启无线... 你有没有想过,家里的音响设备也能跟上科技潮流,和你的安卓手机无缝连接呢?没错,今天就要来聊聊这个神奇...
安卓x是什么系统,探索新一代智... 你有没有听说最近安卓界又出了个新花样——安卓X系统?没错,就是那个我们平时手机里常用的安卓系统,这次...
安卓系统怎么提升网速,五大技巧... 你是不是也和我一样,在使用安卓手机时,总是觉得网速不够快,有时候刷个网页都慢得让人抓狂?别急,今天就...
机车安卓系统重装,轻松恢复系统... 你那台机车安卓系统是不是突然间卡壳了,运行速度慢得像蜗牛爬?别急,今天就来给你详细说说怎么给机车安卓...
华为手机更改安卓系统,探索安卓... 你知道吗?最近华为手机界可是掀起了一阵不小的波澜呢!没错,就是那个我们熟悉的华为,竟然悄悄地更改了安...
安卓系统低版微信,揭秘微信新版... 你有没有发现,有时候手机里的微信版本有点儿“老气横秋”呢?别急,今天就来聊聊这个让人有点头疼的安卓系...
安卓系统安装apple pay... 你有没有想过,即使你的手机是安卓系统,也能享受到Apple Pay的便捷支付体验呢?没错,就是那个曾...