news 2026/4/19 4:14:25

RDMA设计20:RoCE v2 发送及接收模块设计2

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
RDMA设计20:RoCE v2 发送及接收模块设计2

本博文主要交流设计思路,在本博客已给出相关博文约150篇,希望对初学者有用。注意这里只是抛砖引玉,切莫认为参考这就可以完成商用IP设计。

(1)RoCE v2 发送模块
RoCE v2 发送模块的具体工作为将发送队列及接收队列条目中的信息转换为
AXI-Stream 接口形式的网络帧,即 SEND 单元、READ 单元、WRITE 单元(后统称
为请求生成单元)将发送队列条目转换为 SEND、READ、WRITE 包;ACK 单元和
REP 单元(后称为应答生成单元)将接收队列条目转换为 ACK、REP 包。其中在发
送 WRITE 包或 REP 包时,需要与 DMA 控制器进行交互并读取内存中的数据。由于
请求生成单元和应答生成单元并不是所有时刻都需要与 DMA 控制器进行数据交互,
所以这里使用两个状态机分别控制请求生成和应答生成流程,以此来提高系统工作效
率、降低响应延迟。RoCE v2 发送模块由一个请求状态机、一个应答状态机、一个二
选一 MUX、五个生成单元和异常处理单元组成。

(a)请求状态机
当 RoCE v2 发送模块检测到发送队列非空时,则从发送队列中读取一个发送队
列条目,并判断请求类型。根据不同的请求类型和请求长度进入不同的包生成流程,
这一过程由请求状态机实现。请求状态机的状态转移图如图 1所示,对于各个状态
的详细说明如下。
IDLE:空闲状态,系统复位后请求状态机将进入 IDLE 状态。当检测到发送队列非空时,从发送队列中读取出一个发送队列条目并分析其请求类型,并根据不同的请求类型跳转到不同的后续状态。对于 SEND 指令,跳转至 SEND 状态;对于 READ指令,跳转至 READ 状态;对于 WRITE 指令,跳转至 WRITE_HEAD 状态。如果请求类型不合规,则保持在 IDLE 状态并返回错误信息。如果发送队列为空,则保持在IDLE 状态等待指令。
SEND:SEND 指令发送状态。在该状态下将调用 SEND 单元根据系统中提前预设好的信息发送 SEND 数据包,数据包内容包括本机 IP 地址、本机 MAC 地址、本机内存起始地址、本机内存大小和本机远程访问密钥。发送完毕后跳转至 DONE 状态。
READ:READ 指令发送状态。在该状态下状态机将调用 READ 单元根据用户指令中的请求远程地址、请求数据长度及远程主机访问密钥来组装 READ 包头部,READ 请求包中并不携带数据信息。发送完毕后跳转至 DONE 状态。
WRITE_HEAD:WRITE 指令头发送状态。在该状态下状态机将调用 WRITE 单元根据用户指令中的远程请求地址、请求数据长度及远程主机访问密钥来组装WRITE 包头部。同时将请求数据长度与以太网单数据帧最大长度进行比较,如果请求长度超过单数据帧最大程度,则 WRITE 包头部中的操作类型被置为 FIRST/MIDDLE/LAST;反之 WRITE 包头部中的操作类型被置 ONLY。同时将用户指令中
的本地数据起始地址和请求数据长度通知给 DMA 控制器,而后跳转至 WRITE_DATA状态。
WRITE_DATA:WRITE 指令数据发送状态。在该状态下将持续等待 DMA 控制器返回用户需要发送的数据,在数据到来后,将数据组装进 WRITE 数据包中,直到达到以太网单数据帧最大长度。而后对数据长度进行判断。如果数据已发送完毕,则跳转至 DONE 状态;如果仍有数据未发送完毕,则跳转回 WRITE_HEAD 状态,重复 WRITE 数据包发送流程。若请求数据超时,则返回 IDLE 状态并返回异常完成条目。
DONE:请求完成状态。该状态下将发送寄存器中剩余的最后一帧数据并生成指
令完成信号。在一个时钟周期后回到 IDLE 状态。

B站已给出相关性能的视频,如想进一步了解,请搜索B站用户:专注与守望

https://www.bilibili.com/video/BV1mPV5eCE8z/?spm_id_from=333.337.search-card.all.click&vd_source=c355545d27a44fe96188b7caefeda6e7

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 19:56:55

YashanDB数据库的实时数据处理能力分析

YashanDB 是一个相对较新的数据库解决方案,具备高性能和实时数据处理能力。以下是关于 YashanDB 数据库实时数据处理能力的分析:1. 设计架构YashanDB 采用了分布式架构,支持横向扩展。这种架构能够处理大规模数据的并发访问和高吞吐量&#x…

作者头像 李华
网站建设 2026/4/18 10:43:06

当你的论文卡在第三章:宏智树AI悄悄替你铺好了整条学术红毯

凌晨两点,咖啡见底,文档光标还在闪烁。 你不是不会写,是被开题折磨、被文献淹没、被数据整懵、被查重吓退。 大三、大四、研一、博一……甚至在职进修的你,可能正在经历这样一场“学术马拉松”——明明拼尽全力,却总差…

作者头像 李华
网站建设 2026/4/18 9:16:14

开发自测的常见误区:软件测试从业者视角的分析与建议

在软件开发过程中,开发自测是确保代码质量的第一道防线,它不仅能及早发现缺陷,还能降低后期测试成本和项目风险。然而,许多开发人员在进行自测时,常因经验不足、认知偏差或时间压力而陷入误区,导致潜在问题…

作者头像 李华
网站建设 2026/4/18 20:19:00

金融系统测试的特殊要求与实施策略

金融测试的独特地位 在数字化转型加速的2025年,金融系统作为社会经济运行的"心脏",其测试工作已超越传统软件测试的技术范畴,发展成为保障金融稳定、维护公众信心的关键环节。与普通应用系统相比,金融系统测试面临着更…

作者头像 李华
网站建设 2026/4/18 10:50:46

开发与生产环境的10条生存铁律

开发环境和生产环境的核心差异,以及你必须刻在脑子里的 10 条“生存守则”:1. 数据 开发:随便造,库炸了 rm -rf 一把梭就能重来。 生产:一条 UPDATE 不带 WHERE 可能让公司上热搜。2. 配置 开发:把密钥写…

作者头像 李华
网站建设 2026/4/19 1:22:49

图片img之间出现白色底边的问题

问题:公司的小程序商品详情页出现了图片之间出现白色间隙的问题 分析: 我们设置的图片是inline-block,因为还是有inline的成分,inline元素默认是baseline对齐的。当baseline对齐的时候 下方会有4px 的空隙。 解决: vertical-a…

作者头像 李华