过去的 5~10 年里,本土半导体产业实现了飞速增长,其中尤以芯片设计产业发展最为快速,在模拟芯片和数字芯片等方面均实现了大范围的国产替代。时至今日,进口替代已进入深水区,尤其是高端芯片的深度替代需要有企业担起啃“硬骨头”的重任,向“深水区”甚至“无人区”发起挑战,互连技术便是其中需要攻克的难题之一,而传统互连芯片技术目前仍被国外巨头所垄断。
2022 年 10 月,在经过一年半的攻坚克难之后,井芯微电子技术(天津)有限公司继发布 240G 网络 DPU 芯片 SDI2820 后,再度向市场推出国产替代新产品—— PRB0400 型 PCIe 转 SRIO (Serial RapidIO) 桥接芯片。
今年 5 月,在“晶上联盟 SDI 论坛——RapidIO 自主生态与 SDI 应用创新大会”上,井芯微电子芯片研发部门王盼部长代表公司正式宣布,在完成了包括芯片功性能、系统兼容性、老化稳定性在内的多批次、多类型测试之后,PRB0400 开始进入 量产应用 阶段。
全正向自主设计
PRB0400 芯片自主立项于 2021 年 3 月,并于 2022 年 9 月完成流片,是一款兼容 PCIe Gen2 和 RapidIO Gen2 协议的高性能数据传输桥接芯片,主要用于满足高可靠低延时计算处理系统内部各组件之间的互连需求,实现 PCIe 协议网络和 RapidIO 协议网络之间数据互连互通。该芯片可以轻松实现 RapidIO 系统与 PCIe 系统的无缝连接,实现两个生态系统的融合。
众所周知,RapidIO 协议是全球主流的嵌入式系统互连国际标准(ISO/IEC18372),PCIe 则是一种高速串行计算机扩展总线标准。两种协议在信息基础设施中均有较为广泛的应用以及互连需求,在器件级、板卡级和系统级的设备中大规模地采用了 PCIe 协议和 RapidIO 协议。
作为成功研制出国内首款 RapidIO Gen2 交换芯片、首款 RapidIO Gen3 交换芯片,并提供自主开发配置管理工具的 RapidIO 自主生态构建者,井芯微电子始终以更高的代际、更高的性能和更强的互连 作为自身发展目标,努力将 SRIO 协议所支持的高可靠、低延时、高灵活特性拓展到其他协议领域。
“与竞品相比,我们之所以能在如此短的时间内实现产品的落地量产,主要得益于公司在软件定义互连 (Software Defined Interconnection,SDI) 技术上的深厚积累和丰富的芯片开发经验,能够将许多复杂问题简单化,从而加速了上市时间。”王盼表示。
作为互连技术的新方向,SDI 技术在 2009 年由中国工程院邬江兴院士团队所提出,其核心是打破现有网络的刚性体系结构,实现从物理层、数据链路层、网络层到业务层全维软件定义的网络体系,从而将刚性网络变为柔性网络,构建可定义、可重组、可重构、可重建的新一代软件定义体系架构。
井芯 PRB0400 支持芯片到芯片、板到板间的高效能数据通信,可用于连接 CPU、DSP、FPGA 等构成的密集型电子系统,用于解决 PCIe 网络与 RapidIO 网络的连接问题,同时内嵌消息引擎和 BDMA 引擎,可以在无需主控处理器过多参与的情况下实现大量数据的高效传输。
图2:井芯微 PRB0400 拥有 PCIe 接口、SRIO 接口、 消息引擎、映射引擎、BDMA 引擎五大主要功能
在井芯 PRB0400 芯片中,PCIe 接口实现与 PCIe 相关的所有物理层、数据链路层和传输层协议功能,SRIO 接口则实现与 SRIO 相关的物理层和传输层协议功能。消息引擎用作 RapidIO 逻辑层消息传递,接收和发送通道均支持 8 个独立的处理引擎。映射引擎则是用于 PCIe 和 RapidIO 之间的地址映射和转换,可根据需要进行分割和重组。BDMA 引擎支持 8 个独立的 DMA 通道,其中的每个 DMA 通道都可以根据描述符执行读或写操作。
除此之外,为了更好地帮助用户实现快速开发,井芯微还提供 完善的产品用户资料 (数据手册、用户手册、软件使用说明)、丰富的产品开发板卡 (功能评估子卡、OPT 功能评估板)、广泛应用场景的参考设计 (开发应用手册、设计兼容性手册、原理图设计手册、用户使用手册)和 丰富的软件工具 ( RapidIO 快速配置软件、SerDes 调节工具、芯片驱动软件),其中驱动软件支持麒麟、天脉 3、统信、FPGA 嵌入式等国内主流操作系统。
加速中国新基建市场建设
国内新基建产业的浪潮、东数西算工程建设以及本土服务器芯片厂商的崛起,使得市场对国产桥接芯片的需求非常强烈。市场调研数据显示,国内市场对 PCIe 转 RapidIO 协议芯片需求迫切,未来整体市场容量有望超过 40 亿元。
作为一款 PCIe 转 RapidIO 桥接芯片,井芯 PRB0400 广泛应用于各种处理器之间的点对点互连,或者处理器之间 RapidIO 数据交互等功能实现的场景,在基站传输、分布式计算、图像处理等应用领域都有着巨大的市场空间。
在视频和图像应用场景中,系统设计人员需要将大量的 DSP 或者 FPGA 用于执行编码/解码/转码,或者对大型数据阵列进行快速傅里叶变换,RapidIO 协议最适合这种 DSP/FPGA 集群要求。在这些应用中,系统的模拟前端通常是一个传感器,并端接在 FPGA 中(例如摄像头子系统),井芯PRB0400 可以帮助设计人员在 PCIe 网络和 RapidIO DSP/FPGA 集群之间搭建桥梁——CPU/GPU 等处理单元通过 PRB0400 接入 RapidIO 网络,并通过消息引擎进行点对点的数据通信。
在无线基站应用场景中,为了保证实时性,通信基站一般都会采用高速实时传输总线 RapidIO 协议和 PCIe 协议,在 RapidIO 网络的维护管理系统中,RapidIO 交换芯片和 PCIe 转 SRIO 桥接芯片用于各种处理器之间的点对点互连以及 RapidIO 数据交互等功能实现。对于处理器与 RapidIO 网络连接系统,PCIe 转 RapidIO 桥接芯片则用于解决系统连接的难题,并提升系统的运算效能。
在高性能处理应用中,井芯 PRB0400 实现将 CPU 处理器的 PCIe 总线连接到 RapidIO 背板总线,可为系统提供 CPU 处理器的高性能运算能力,以及 RapidIO 架构突出的点对点网络传输性能。
打造自主“易用好用愿用”生态
在系统设计上,井芯 PRB0400 可原位替代对标国际产品,并兼容其官方驱动。此外,井芯 PRB0400 兼容国内主流 CPU 和 DSP,并完成了对应的生态测试。目前已完成与飞腾、龙芯、x86、Zynq 等 PCIe RC 设备对应的生态测试,实现了对在国际厂商的相关产品在硬件和软件两个层面的原位替代。
易用、好用、愿用,是井芯微在兼容替代战略方面提出的三大愿景。
易用
所谓“易用”,更强调系统级替代。也就是说,不但硬件“封装一致、电压一致、上电顺序一致、功耗相近、即换即用”,软件层面也做到了无缝切换,用户可以在没有任何感知的情况下完成芯片替换,并确保功能性能全面兼容。
图3展示了 PRB0400 与国外某品牌产品在 X86、飞腾、龙芯三大平台上消息引擎吞吐量的比较。可以看出,PRB0400 不但全面胜出,而且,得益于支持不常用的常量地址和地址/长度不对齐模式,PRB0400 还可实现全场景功能替代。
图3:消息引擎吞吐量比较
好用
而“好用”则突出更好用的功能、更好用的软件和更宽工作温度。以可支持的业务类型为例,PRB0400 不仅实现了对标国际产品所支持的全部业务类型,还扩展增加了 NWRITE 以及 NWRITE+NWRITE_R 业务,这对于使用 FPGA做自研端点的用户来说非常有利,他们可以有更多的选择,自研端点仅需支持最少的业务类型,简化设计 ,提升兼容性。
“好用”还体现在更丰富的定位手段上——既包括硬件层面的计数统计、状态获取、异常记录、错误原因记录等,还包括软件层面上的诊断 API、一键式定位信息导出。这一做法带来的好处是显而易见的,首先它可以方便新方案的开局调试,其次对于工作过程中遇到的异常分析和定位也能起到极大的便利辅助作用。
在此基础上,设计人员对 PRB0400 的鲁棒性(异常报文过滤、错误描述符识别、异常恢复流程)和兼容性(高适应性 SerDes、速率调节与调度、优先级灵活设置)进行了强化,对驱动功能进行了重新优化、支持和适配,“映射引擎支持NWRITE 数据类型业务”、“BDMA 引擎支持 NWRITE/NWRITE+Last NWRITE_R 业务”、“支持端口收发统计、引擎各节点统计、异常统计等可维可测信息”、“支持一键式导出”等功能都成为了新的亮点。
愿用
但有了好的产品,如果得不到生态系统支持,也无异于“水中花、镜中月”。因此,如何让客户“愿用”,同样是不小的挑战。
为此,井芯微提出了广泛的兼容生态、一站式本地支持和用户试用好口碑的政策,与国产操作系统 、国产 CPU、自有 SRIO 芯片、国产 DSP/FPGA 厂商一道,构建起了广泛的国内自主兼容生态,加之涵盖从方案设计、器件选型支持,到硬件设计评审、驱动适配服务,再到开局调试支持、问题定位协助的全流程本地化支持,共同实现“开放利他,客户愿用”的目标。截至目前,已累计发放 200+ 样片,拥有 85 家试用单位和 99 个应用项目。
根据规划,在深度布局 SDI 技术的基础上,井芯微未来中远期将探索以“SDI 逼近神经网络、神经网络驱动智能”的技术与产业之路,通过 SDI“神经网络”集成 CPU、GPU、IPU、NPU、TPU、DSP 等各种类型“神经元”,携手共建连接绿色安全的智能世界。
审核编辑 :李倩
全部0条评论
快来发表一下你的评论吧 !