Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3612172
  • 博文数量: 211
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 7406
  • 用 户 组: 普通用户
  • 注册时间: 2013-01-23 18:56
个人简介

将晦涩难懂的技术讲的通俗易懂

文章分类

全部博文(211)

文章存档

2025年(2)

2024年(11)

2023年(9)

2022年(4)

2021年(12)

2020年(8)

2019年(18)

2018年(19)

2017年(9)

2016年(26)

2015年(18)

2014年(54)

2013年(20)

发布时间:2025-01-05 23:13:54

NCCL源码解析4——channel搜索——lvyilong316      上文计算出GPU和NIC节点到其他任意节点的最优路径了,本节看下nccl中channel的搜索过程。NCCL中channel的概念表示一个通信“信道”。注意这里没有说他是路径,因为它和路径还是有区别的。如下图所示,我们可以说A到B有两个pa.........【阅读全文】

阅读(50) | 评论(0) | 转发(0)

发布时间:2025-01-01 18:28:43

NCCL源码解析3——拓扑生成——lvyilong316      在前面两部分讨论了 NCCL 如何初始化 bootstrap 网络,并基于 bootstrap 网络建立所有进程间的通信环。之后,每个进程均获得了所有进程的监听地址。也就是说,每个进程均可以和其它任意进程建立连接。下面,我们分析如何通过 initTransports.........【阅读全文】

阅读(73) | 评论(0) | 转发(0)

发布时间:2024-12-22 13:38:11

......【阅读全文】

阅读(177) | 评论(0) | 转发(0)

发布时间:2024-12-15 23:00:14

NCCL源码解析2——bootstrap网络初始化——lvyilong316      我们在前一部分中介绍了root进程生成ncclUniqueId的过程。ncclUniqueId数据结构中包含了root进程的监听地址和端口,用于其它进程与root进程进行连接。同时帮助root进程创建了bootstrapRoot这个线程,用于等待其他rank来传.........【阅读全文】

阅读(175) | 评论(0) | 转发(0)

发布时间:2024-11-23 23:46:31

NCCL源码解析1——生成ncclUniqueId——lvyilong316NCCL 通信库通过 ncclGetUniqueId 函数生成并获取 「ncclUniqueId」。本质上,ncclUniqueId 是一个大小为 128 字节数组,如下所示。#define NCCL_UNIQUE_ID_BYTES 128typedef struct { char internal[NCCL_UNIQUE_ID_BYTES]; } ncclUniqueId;ncclGe.........【阅读全文】

阅读(157) | 评论(0) | 转发(0)
给主人留下些什么吧!~~

zf8292024-11-13 13:41

zf829:您好,请教大神一个问题,设备直通给VM时,中断到底会不会导致VM_EXIT吗,如果会,那VIRTIO直通时还会导致IO性能下降吧?“当透传设备产生中断时,vfio_msihandler ISR执行,该函数不做实际的服务程序处理,仅仅通过eventfd_signal激活irqfd_inject,然后最终调用deliver_posted_interrupt向虚机注入中断,中断号即为虚机配置透传设备时的中断号。”  这段描述在代码上我也仔细看了,逻辑肯定是对的,但另一方面我还是不确定中断到底会不会导致VM_EXIT

这里的中断主要是指数据包收发的中断

回复  |  举报

zf8292024-11-13 11:35

您好,请教大神一个问题,设备直通给VM时,中断到底会不会导致VM_EXIT吗,如果会,那VIRTIO直通时还会导致IO性能下降吧?“当透传设备产生中断时,vfio_msihandler ISR执行,该函数不做实际的服务程序处理,仅仅通过eventfd_signal激活irqfd_inject,然后最终调用deliver_posted_interrupt向虚机注入中断,中断号即为虚机配置透传设备时的中断号。”  这段描述在代码上我也仔细看了,逻辑肯定是对的,但另一方面我还是不确定中断到底会不会导致VM_EXIT

回复  |  举报

lemon222024-10-09 22:34

你好,有个关于实现方面的问题:当协议栈收到来自app的数据(如ping)时,会发给tun设备,然后又被发送给vpn程序,程序对其进行加密或者一些处理之后,要发送出去,这里是通过什么方式发送出去的呢?我看你关于itun/tap的文章中写的是通过socket发送给协议栈,然后自动给物理网卡后发送出去,实现来说,就是直接用socket与下一跳建立连接,然后代码用socket发送吗?那这样是不是不会再次经过TUN设备了?因为我看好像有的原理写的是再次写入到tun设备,然后tun设备给协议栈,最后再发送。
这里有点不太清楚如何具体的实现发送的

回复  |  举报

lvyilong3162023-06-06 15:06

zhangtongjian12:你好,请教下,“qemu和vhost-user前后端协商过程”中讲到的初始化多队列时,多队列初始化时,对应的kvm中断机制中irqfd和ioeventfd是和队列数目对应的吗?还是一个虚拟机就一个irqfd和ioeventfd?

和队列对应

回复  |  举报

zhangtongjian122023-06-02 10:29

你好,请教下,“qemu和vhost-user前后端协商过程”中讲到的初始化多队列时,多队列初始化时,对应的kvm中断机制中irqfd和ioeventfd是和队列数目对应的吗?还是一个虚拟机就一个irqfd和ioeventfd?

回复  |  举报
留言热议
请登录后留言。

登录 注册