news 2026/4/16 15:53:13

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/4/16 14:28:58

docker运行报错启动守护进程

docker运行报错 failed to connect to the docker API at npipe:////./pipe/dockerDesktopLinuxEngine; check if the path is correct and if the daemon is running: open //./pipe/dockerDesktopLinuxEngine: The system cannot find the file specified. docker 解决办法 点…

作者头像 李华
网站建设 2026/4/11 13:48:52

7个有效方法提升YashanDB的查询响应速度

在现代数据应用中,查询响应速度直接影响系统的用户体验和业务处理效率。如何在海量数据和复杂业务场景下优化数据库查询性能,成为数据库管理和应用开发中的关键问题。YashanDB作为具备单机、分布式及共享集群多种部署模式的高性能数据库系统,…

作者头像 李华
网站建设 2026/4/15 19:12:12

蓝桥杯JAVA--启蒙之路(二)JAVA 程序基础

一前言 由于我们的重点是数据结构与算法,所以我会快速的将JAVA 基础知识过一遍,而且有了c语言的基础JAVA是很好学的。 二主要内容 本节我们将介绍Java程序的基础知识,包括: Java程序基本结构 我们先剖析一个完整的Java程序&a…

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

吃透 C 语言核心知识点:从内存存储到文件操作的实战指南

作为 C 语言学习者,想要真正掌握这门语言,不能只停留在语法表层,必须深入理解内存管理、指针操作、自定义类型等核心机制。本文结合实战代码,系统拆解 C 语言关键知识点,帮你打通从基础到进阶的学习脉络。一、数据在内…

作者头像 李华