0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

SSD主控芯片还有哪些用途?

VIBT_dputech 来源:大普微 作者:大普微 2021-04-26 17:45 次阅读

DPU600是DapuStor(大普微)在业内首创的智能存储SoC,基于最新的12nm FinFET工艺,可作为SSD主控提供业界领先的性能,还集成了可计算存储平台,用于ASIC加速的机器学习架构等。

上期讲到得益于DPU600内置的应用处理器平台,可以将DPU600作为存算一体化固态硬盘(PIS-SSD),并讨论了相关架构和实现技术。本期小编将进一步讨论计算存储的功能,这是小编又付出N个鸡腿后,从研发小伙伴们手里“炸”出来的干货。

同样地,小编需要先重复一下背景:

在大数据应用的背景下,海量的数据传输占用了各类总线、网络带宽,与此同时,固态硬盘(SSD)本身含有的CPU的算力也越来越强。为了减少大数据量的传输,从而衍生出各类对存储计算一体化(PIS-Processing In Storage)的需求,即在数据端固态硬盘内进行计算处理,也经常称之为“近存储计算”,仅传输结果和部分数据,从而减少海量数据传输,减轻总线和网络负载(Offloading)。

读者或许想说:这些上次说过了?

小编……,打Patch:虽然DPU600内置了PIS模块,但是需求永远是在变化和前进的(研发小伙伴最头痛的需求的快速变化),那么DPU600 如何应对?特别是特定计算要求的情况下,如何快速而灵活地满足需求?

首先说说现有的技术,如图1,是一种计算靠近存储的最通用方法:专用加速卡(计算模块)和存储都放置在PCIe总线,Host控制数据流在PCIe总线流动。显然,此种方式对IO(PCIe,RAM)的占用是非常的高。

a90df70a-a66d-11eb-aece-12bb97331649.png

图1

有瓶颈就有新的方案产生,业界有团队开始研发新的方案,如图2,即P2P Connection方案(此P2P不是坑各位钱的网络金融,类似各位下载用过的P2P,Peer2Peer),通过PCIe Bus,加速卡和存储器之间直接传输数据,以此Off Loading CPU和RAM的负载。

af2b2c84-a66d-11eb-aece-12bb97331649.png

图2

说到这里,大家想到了DPU600肯定有什么东东,可以在此类应用需求上发挥作用?没错,DapuStor正在探索在DPU600上实现一种存储计算一体的固态硬盘(SSD)。

af5f5f4a-a66d-11eb-aece-12bb97331649.png

图3

先看一下,我们的设计基于如图3,相对于图1,2,其思路是:将所有运算放置在固态硬盘(SSD),其中为了弥补控制器本身计算能力扩展性有限的弱点,引入了加速器设计,并集成到一个PCB内。这样,可以进一步减轻负载(Offloading)到存储器(固态硬盘)内,相对于P2P方案,将计算加速器放置在SSD内(主机视角),从而不走主机上PCIe Bus。

为何如此设计?

1. 由于DPU600具有双PCIe模块,可以同时满足和主机通信(PCIe/NVMe),以及和加速器通信(PCIe/DPU-LINK),即满足数据的存储和计算两种通路需求,一个接口用于数据存储,另一个接口用于数据计算。其中运用DPU600中专门设计的DPU-LINK技术,减低传输延时,提升性能。

2. 由于DapuStor在存储计算深耕多年,形成了诸多存储计算的IP,可以应用到加速器(FPGA)里面。根据各自不同特性系统的需求,可以配置不同算法模块。

如图4,是我们设计的框架图:上半部分和普通的固态硬盘基本一致,下半部分是加速器的部分,目前是以FPGA为主体,其中由于计算的需求,可单独设置DRAM。但对主机而言保持一个接口,当然为了兼容性考虑,也备份了加速器的PCIe接口,便于扩展主机和加速器之间的通信。

af7daaa4-a66d-11eb-aece-12bb97331649.png

图4

大家可能比较兴趣的技术点: DPU600和FPGA的内部设计。受限于小编手里鸡腿有限,只能“炸”到基本模块框架图,如图5。上图是DPU600内部相关模块构成,下图是FPGA相关模块构成。

afe23b5e-a66d-11eb-aece-12bb97331649.png

图5

小编根据模块框图,这里把关键模块进行探讨一下:

1. DPU600存储系统,包括

PCIe Controller/PHY和NVMe Controller,应用于前端模块(FE)和主机通信协议栈,命令数据收发的硬件处理。

NAND Flash Controller/PHY,应用于后端模块(BE)闪存数据读写和相关闪存命令的硬件处理;

DDR Controller/PHY外连DRAM设备,应用于数据缓存。

CPU系统,包含MMU,CCI等典型应用处理器的功能模块,用于运行固件和Linux 操作系统

其中和计算相关模块:

LSTM,是基于神经网络算法的计算模块,可以用于预测IO趋势,优化SSD性能。

DPU-LINK,是基于PCIe特性的硬件Buffer传输管理模块,用于优化PCIe数据传输管理,减少数据传输延时。

2.FPGA加速器计算系统,包括:

ADA(数据分析处理),用硬件实现数据的预分析和处理,包括但不限于:

ASCII数据转换(dconv)功能

正则匹配字符串查找(grep)功能

预排序处理(sort)功能

LSTM,是基于神经网络算法的计算模块,是DPU600内LSTM的强化版本。

PU, 是数据计算处理专用单元,优化数据处理进程。

其他通用计算模块,包括但不限于:

压缩(Compresssion)和解压(Decompression),

另外引入客户IP接口,相关处理包括但不限于数据搜索(Search),数据比较(Compare),数据标签(Tag),数据索引(Index)。

小编在这里Copy过来:一种计算应用场景,在DPU600+Accelerator的加持下,下面所述的计算需求更容易Offloading到计算存储系统内。

SQL Query一种典型的数据库应用,传统的所有步骤步骤均是在主机计算完成。在引入存算一体化存储器之后,可以把大部分查询计算移入到存取器内(加速器内),如图6,可以大大减少IO传输,是一种典型的 “近存储计算”应用。

原文标题:SSD主控芯片, 除了做SSD还能干点啥?- III

文章出处:【微信公众号:大普微】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    447

    文章

    47769

    浏览量

    409071
  • SSD
    SSD
    +关注

    关注

    20

    文章

    2688

    浏览量

    115475
收藏 人收藏

    评论

    相关推荐

    便携储能中的万能“管家”——主控芯片

    的、内置锂离子电池的小型储能设备。它具备大容量、大功率、安全便携的特点,可提供稳定交流/直流电压输出,至于功率管理、电池管理则主要依托于内部的主控芯片。   便携储能的主控芯片  
    的头像 发表于 01-25 00:20 6529次阅读
    便携储能中的万能“管家”——<b class='flag-5'>主控</b><b class='flag-5'>芯片</b>

    LLC的的主控芯片怎么选

    LLC(Low-Level Control)主控芯片选择的过程是电子产品设计中的一个关键环节。LLC主控芯片在电子产品中的作用是负责系统的低级控制和协调。它通常是产品的大脑,负责处理数
    的头像 发表于 01-16 10:55 507次阅读

    DOIT传媒对话平头哥:突破SSD主控芯片,触发新一轮市场冲击波

    转载自DOIT传媒 在2023云栖大会上,阿里巴巴旗下平头哥半导体发布首颗SSD主控芯片-镇岳510。在11月29日举行的2023中国数据与存储峰会上,平头哥半导体产品总监周冠锋在题为 “做智能化
    的头像 发表于 12-14 16:20 198次阅读
    DOIT传媒对话平头哥:突破<b class='flag-5'>SSD</b><b class='flag-5'>主控</b><b class='flag-5'>芯片</b>,触发新一轮市场冲击波

    谈谈SSD主控芯片

    SSD主控芯片SSD controller)好比固态硬盘的大脑。
    的头像 发表于 11-29 12:16 1100次阅读
    谈谈<b class='flag-5'>SSD</b><b class='flag-5'>主控</b><b class='flag-5'>芯片</b>

    平头哥SSD主控芯片镇岳510性能分析

    镇岳510芯片还针对云计算场景进行了深度优化,芯片与云存储软件系统紧密融合协作,有效降低数据读写的延时,为系统带来了更高的性能。例如,镇岳510在支持NVMe的队列级调度机制的同时,额外实现了更精细、更灵活的IO级调度机制,结合云存储系统,能更好地满足延迟敏感型IO场景的
    发表于 11-22 11:36 320次阅读
    平头哥<b class='flag-5'>SSD</b><b class='flag-5'>主控</b><b class='flag-5'>芯片</b>镇岳510性能分析

    悄然席卷企业级SSD市场的RISC-V主控

    在一些细分市场,RISC-V也已经开始崭露头角,比如服务器领域的CPU芯片,以及企业级SSD主控。   平头哥   在2023云栖大会上,阿里巴巴平头哥发布了旗下首颗SSD
    的头像 发表于 11-16 00:22 1371次阅读
    悄然席卷企业级<b class='flag-5'>SSD</b>市场的RISC-V<b class='flag-5'>主控</b>

    2023云栖大会亮点:平头哥首颗SSD主控芯片RISC-V架构的镇岳510亮相

    2023云栖大会亮点:平头哥首颗SSD主控芯片镇岳510亮相 2023云栖大会昨天开幕,阿里巴巴集团董事会主席蔡崇信在开幕式上致辞;2023年的云栖大会为期三天,设有两场主论坛与500多场分论坛
    的头像 发表于 11-01 17:20 630次阅读
    2023云栖大会亮点:平头哥首颗<b class='flag-5'>SSD</b><b class='flag-5'>主控</b><b class='flag-5'>芯片</b>RISC-V架构的镇岳510亮相

    平头哥首颗SSD主控芯片镇岳510问世,将率先在阿里云数据中心部署

    11月1日,在2023云栖大会上,阿里巴巴平头哥发布旗下首颗SSD主控芯片镇岳510,该芯片为云计算场景深度定制,实现4μs超低时延,比业界主流降低30%以上,误码率低至10^-18,
    的头像 发表于 11-01 16:50 226次阅读

    慧荣科技打造企业级SSD主控芯片,为企业数据中心保驾护航

    也对存储企业提出了更苛刻的要求。慧荣科技作为行业最大的NAND Flash控制芯片供应商,旗下主控芯片产品及解决方案广泛应用在服务器、PC及其他消费性电子产品,其推出的MonTitan™开发平台和SM8366PCIe Gen5企
    的头像 发表于 10-19 10:18 569次阅读
    慧荣科技打造企业级<b class='flag-5'>SSD</b><b class='flag-5'>主控</b><b class='flag-5'>芯片</b>,为企业数据中心保驾护航

    加密主控和加密芯片之间的关系是什么?

    加密主控和加密芯片之间的关系是?
    发表于 10-08 06:31

    蔚来宣布首款自研芯片——激光雷达主控芯片“杨戬”

    蔚来汽车在蔚来创新科技日上宣布了首款自研激光雷达主控芯片——激光雷达主控芯片“杨戬”,型号为NX6031。该芯片具有集成度高、能耗低、性能强
    的头像 发表于 09-21 16:25 1592次阅读

    慧荣科技于FMS 2023展出企业级和即将上市的消费级PCIe Gen5 SSD主控,以及全球首款支持SR-IOV的车用级SSD主控

    )的车用级PCIe Gen4 SSD主控芯片,也发布了即将上市的消费级PCIe Gen5 SSD主控芯片
    发表于 08-09 17:36 376次阅读
    慧荣科技于FMS 2023展出企业级和即将上市的消费级PCIe Gen5 <b class='flag-5'>SSD</b><b class='flag-5'>主控</b>,以及全球首款支持SR-IOV的车用级<b class='flag-5'>SSD</b><b class='flag-5'>主控</b>

    拆一个天猫魔盒机顶盒,看看内部什么结构和采用哪些主控芯片

    主控芯片
    学习电子知识
    发布于 :2023年07月17日 00:26:37

    存储主控芯片是什么 主控芯片和存储芯片怎么选

    存储主控芯片是一种集成电路芯片,用于控制和管理存储设备。它负责管理多个存储单元(如内存、固态硬盘、闪存卡等)之间的数据传输和存取操作。存储主控芯片
    发表于 07-10 15:50 3140次阅读

    芯盛智能发布基于RISC-V开源架构主控芯片PCIe SSD

    5月,芯盛智能发布基于RISC-V开源架构主控芯片的高性能PCIe SSD——EP2000Pro、MP2000Pro及EP3000,全面兼容3D TLC和QLC颗粒,并与国内主流CPU、OS、整机厂商适配兼容,以开源架构助力自研
    发表于 05-16 11:54 429次阅读