LINUX NVME SSD 大容量存储设计

编程入门 行业动态 更新时间:2024-10-25 14:25:23

LINUX NVME SSD <a href=https://www.elefans.com/category/jswz/34/1719771.html style=大容量存储设计"/>

LINUX NVME SSD 大容量存储设计

前面有介绍过纯逻辑FPGA的NVME驱动,具体可参考链接
,纯逻辑方便在可移植性强,只要FPGA自带PCIE硬核即可,无需CPU参与,对硬件要求也不高,简化硬件设计。如果采用CPU方案,数据管理需要多组DDR做缓存

但是纯逻辑一般是不带文件系统,当然市面上也有直接用FPGA设计比如EXFAT这类的Ip,后面有精力本人也想尝试一下。如果没有文件系统,所有的读写都是针对BIT流的。
有些客户为了卸载方便还是希望可以带文件系统,可以直接通过PC卸载数据,我们知道linux操作系统本身就是支持NVME驱动的,所以我们可以考虑在原有的驱动的基础上进行修改,这样NVME部分的驱动基本上就是现成的
针对这部分老外有个链接
.html/
有现成的petalinux方案,可以按他的脚本直接将工程恢复出来,具体过程可以参考博客


恢复出来的工程如上图所示:
可以看到这种方案所有的数据都是通过CPU和SSD进行数据交互,

恢复完通过lspci指令可以看到nvme ssd link情况
通过
time dd if=/dev/zero of=/dev/nvme0n1p1 bs=20M count=100指令可以测试写速度

time dd if=/dev/nvme0n1p1 of=/dev/zero bs=2M count=1000测试读速度

PCIE2.0 4X的速度和纯逻辑读写速度差距实在是有点大,速度主要还是制约在CPU的处理速度上,一种方案是通过提升cpu的性能,主频提高,速度肯定是有提升的,但是通过这种方式提升的速度还是非常有限的,下一步还是将落盘的数据直接通过PL端写入SSD,如果是继续实现标准文件系统。可以通过将文件管理部分交由CPU处理,然后通过DMA将文件管理列表实时的下发给PL进行写入SSD,当然也可以自定义的文件系统,这种方式相对比较简单些。后期继续更新

更多推荐

LINUX NVME SSD 大容量存储设计

本文发布于:2023-06-30 16:32:19,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/963127.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:大容量   LINUX   NVME   SSD

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!