LINUX NVME SSD 大容量存储设计

9 篇文章 27 订阅

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

但是纯逻辑一般是不带文件系统,当然市面上也有直接用FPGA设计比如EXFAT这类的Ip,后面有精力本人也想尝试一下。如果没有文件系统,所有的读写都是针对BIT流的。
有些客户为了卸载方便还是希望可以带文件系统,可以直接通过PC卸载数据,我们知道linux操作系统本身就是支持NVME驱动的,所以我们可以考虑在原有的驱动的基础上进行修改,这样NVME部分的驱动基本上就是现成的
针对这部分老外有个链接
https://www.fpgadeveloper.com/2016/04/connecting-an-ssd-to-an-fpga-running-petalinux.html/
有现成的petalinux方案,可以按他的脚本直接将工程恢复出来,具体过程可以参考博客
https://blog.csdn.net/wangjie36/article/details/108146022
在这里插入图片描述
恢复出来的工程如上图所示:
可以看到这种方案所有的数据都是通过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,当然也可以自定义的文件系统,这种方式相对比较简单些。后期继续更新

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值