news 2026/6/10 20:51:28

CQ(完成队列)和 UAR(用户访问寄存器)页之间的关系,以及 CQE(完成队列条目)的位置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CQ(完成队列)和 UAR(用户访问寄存器)页之间的关系,以及 CQE(完成队列条目)的位置

好的,我们来澄清一下 CQ(完成队列)和 UAR(用户访问寄存器)页之间的关系,以及 CQE(完成队列条目)的位置:

核心概念:

  1. CQE 的位置:您说得完全正确。CQE 本身确实存放在主机内存中的 CQ(完成队列)里。这是软件(应用程序或驱动程序)为 CQ 分配的内存区域,HCA(主机通道适配器)会将完成的 WQE(工作队列条目)的状态信息(成功、错误码、字节数等)写入这个内存区域。

  2. UAR 页的作用(对于 CQ):UAR 页在这里扮演的角色不是用来存储 CQE 的。它的作用是为了通知报告给软件(用户进程)一个关键信息:有新的 CQE 已经产生并写入到内存中的 CQ 了!

具体解释:

  • 硬件通知需求:当一个 WQE 被 HCA 处理完成(发送完成、接收完成、或发生错误),HCA 会生成一个 CQE 并写入到内存中对应的 CQ 里。但仅仅写入内存是不够的,软件需要知道“有新的完成事件发生了”,这样才能去读取 CQ 并处理这些 CQE。
  • 通知机制:
    • 传统方式(中断):一种方式是 HCA 触发一个中断给 CPU。CPU 收到中断后,执行中断处理程序,通知上层软件有事件发生。这种方式简单,但中断处理本身有开销(上下文切换),在高性能场景下可能成为瓶颈。
    • RDMA 优化方式(轮询 + 门铃):RDMA 通常采用轮询(Polling)的方式检查 CQ 是否有新事件。但盲目轮询所有 CQ 效率低下。为了高效地通知软件哪个特定的 CQ有新事件发生,RDMA 使用了CQ Doorbell机制。
  • CQ Doorbell 和 UAR:
    • 当 HCA 完成一个 WQE 并生成 CQE 后,它不会直接中断 CPU(或仅在特定配置下使用)。
    • 相反,HCA 会通过硬件内部逻辑,在UAR 页上对应的CQ Doorbell 位置更新一个值(通常是增加一个计数器)。这相当于 HCA “按下了” 这个 CQ 的门铃。
    • 软件(用户进程)通过映射的 UAR 页轮询这个特定的 CQ Doorbell 地址。当软件看到这个值发生了变化(增加了),就知道对应的 CQ 里有新的 CQE 需要处理了
    • 软件随后去读取内存中该 CQ 的 CQE 条目进行处理。
  • UAR 页的本质:UAR 页是 HCA 上一小块特殊的寄存器空间,通过 PCIe BAR 映射到用户进程的虚拟地址空间。写入 UAR 页是通知 HCA(例如,发送 WQE 时用的 SQ Doorbell),读取 UAR 页(主要是读取 CQ Doorbell 位置)是让软件感知 HCA 的状态(例如,有新的完成事件)。

总结:

  • CQE:存放在主机内存的 CQ 数据结构中。
  • UAR 页 (对于 CQ):提供了一种低开销的通知机制。HCA 通过更新 UAR 页上特定位置(CQ Doorbell)的值,来通知软件内存中的哪个 CQ有新的 CQE 产生了。软件通过轮询 UAR 页上的这个值来高效地获知事件发生。
  • 类比:想象 UAR 页上的 CQ Doorbell 就像一个指示灯或一个计数器。当指示灯亮起或计数器增加时(HCA 设置),你就知道仓库(内存 CQ)里新到了一批货(CQE),你需要去仓库里取货(读取 CQE 处理)。UAR 页本身不是仓库(不存货物/CQE),它只是那个告诉你“仓库有货了”的信号灯。

所以,UAR 页对于 CQ 的作用是事件通知,而不是存储CQE。CQE 的存储始终在软件管理的主机内存中。

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

Python - 诊断和修复内存泄漏

内存泄漏是指程序错误地管理内存分配,导致可用内存减少,并可能导致程序变慢或崩溃。 在 Python 中,内存管理通常由解释器处理,但内存泄漏仍然可能发生,尤其是在长时间运行的应用中。在 Python 中诊断和修复内存泄漏需…

作者头像 李华
网站建设 2026/6/10 19:35:34

什么叫组团社,什么叫地接社

在旅游行业中,有两个重要的角色:组团社与地接社,它们分别承担着不同的职责。 组团社,也被称为国内旅游批发商,其主要功能是接受旅游团或海外旅行社的预订。 它们负责制定并下达接待计划,甚至可以提供全程陪…

作者头像 李华
网站建设 2026/6/10 18:05:18

8大关键技术点掌握YashanDB的使用技巧

如何优化查询速度是数据库系统设计和运维中的重要问题,影响着业务响应时间和系统吞吐能力。高效的数据存储、合理的索引设计、智能的执行计划生成以及高并发事务控制技术,均直接关系到查询性能表现。本文围绕YashanDB数据库系统,深入剖析其八…

作者头像 李华
网站建设 2026/6/11 2:08:17

Kubernetes Service 架构深度解析:从虚拟IP到流量的智能寻址

在Kubernetes中,Pod间的直接互联仅是服务通信的基础。要构建一个稳定、弹性且对消费端透明的服务网络,其核心在于Service抽象层。许多开发者对Service的理解仅停留在“一个虚拟IP”的层面,却未能洞悉其背后精妙的流量治理机制:请求…

作者头像 李华
网站建设 2026/6/11 1:16:07

一个免费的在线拼图工具Collaigo

创作背景在社交媒体时代,无论是个人分享生活点滴,还是品牌运营社交媒体账号,拼贴图都成为了内容创作的重要形式。然而,我在使用现有工具时遇到了不少痛点:功能限制:很多工具只能做简单的网格拼图&#xff0…

作者头像 李华
网站建设 2026/6/10 0:40:30

【学习心得】Python好库推荐——pyttsx3

pyttsx3(Python Text-to-Speech eXtended version 3)是一个跨平台的 Python 库,用于将文本转换为语音(Text-to-Speech, TTS)。它可以在不依赖互联网连接的情况下,在本地将文本朗读出来,支持 Win…

作者头像 李华