从零学习 InfiniBand-network架构(九) —— IB协议中子网本地地址

news2024/11/19 5:55:30

从零学习 InfiniBand-network架构(九) —— IB协议中子网本地地址


🔈声明:
😃博主主页:王_嘻嘻的CSDN主页
🔑未经作者允许,禁止转载
🚩本专题部分内容源于《InfiniBand-network architecture》,侵权必删

   本章介绍了IBA子网中报文从源端口路由到目的端口时使用的地址,解释了在CA、交换机和路由器上的端口如何编号。解释了Local ID (LID)地址空间、LID地址的用途以及SM为每个端口分配的唯一LID;最后介绍了SM路径数据库的概念。


端口号

  在解释后续的Local ID等概念前,需要先介绍一下端口的概念:我理解的端口是除设备本体外,数据传输的最高层,数据的目标就是在端口间的传输
  而在IB架构中,三类设备CA、路由器(router)和交换机(switcher)的端口实现数量和功能略有区别:

  • CA:端口数在1—255之间
    CA的每个端口,必须在SM启动阶段就分配完16-bits的LID地址;
    每个端口在子网下必须有唯一的LID。
  • 路由器:端口数在2—255之间,如果只有1个端口,那么路由器将变成‘死路‘,具体路由器规则可参照第一章:从零学习 InfiniBand-network架构(一) —— IB协议中常用术语及定义;
    LID规则与CA一致;
  • 交换机:端口数在3—255之间,port0是管理端口
    Port0将分配唯一的LID,而不能分配LID范围。

LID地址空间

  Local ID是在同一个子网下,对设备的端口进行编号的一个结果。
  分配给端口的LID是由SM分配的16位值。这意味着有64K个LID可分配给子网端口,LID整体地址范围细分如下:

  • 0000h不能被使用
  • 0001h—BFFFh(48K)作为单播地址,单播包不会运往多个Port
  • C000h—FFFEh(16K)作为多播地址,多播包会前往多个目的地
  • FFFFh作为permissive LID PLID,有特殊用途;

使用LID的目的

  数据需要使用LID标记的根本原因在于:包在路由过程中需要通过LID来辨认目的地方向。
  在实际应用中DLID(destination LID)和SLID(source LID)共同组成Local Route Header(LRH),DLID表示目标端口的LID,SLID表示源端口的LID,如下图所示。

请添加图片描述


以下是一个报文从HCA出发,并一路通过LID搜索目标端口的过程:

  • 源端TCA将报文传入链路中;
  • 在到达目的端口的路径中,数据包到达第一个交换机的端口;
  • 交换机的链路层会检查包的DLID内容,确定是单播包还是多播包,并根据内部的查找表确定,包接下去该前往的端口;
  • 到达目标TCA端口后,端口的链路层解码数据包的DLID字段并确定它是目标端口,之后,数据包被传递到网络层进行处理。
    请添加图片描述

DLID解析

  当端口接收到Packet后,在链路层会检查Packet的DLID项的值是否落在PortInfo所设置的DLID范围内,如果DLID正确,代表packet抵达正确目的地,Port会将包向更高层传输并处理

  此外,当SQ(RC UC UD时)或者EEC(RD)发送Packet时,需要提供给链路层一个选择器,为了选择哪个LID插入到Packet中的LRH:SLID项中。

选择器实际上在规范的描述中被称为Source Path Bits,可以通过一列Verb修改该选择器:

  • Modify QP verb
  • Modify EEC verb
  • Create Address Handle verb

SM路径库

  需要注意的是,子网中任意两个CA和/或路由器端口之间通常存在多条路径。在配置阶段,SM会将CA和路由器端口之间所有可能的path都进行记录,构建一个路径库
  当软件后续需要在QP间构建连接时,通过查询该路径库来确定路径,并由LID或GID指定。



搜索关注我的公众号【IC墨鱼仔】,获取我的更多IC干货分享!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/72396.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

鸿蒙3.0应用开发若干问题及上架总结

1.如何去掉默认标题栏,实现全屏显示? 在config.json中的ability配置信息中添加属性: "abilities": [ {..."metaData": {"customizeData": [{"name": "hwc-theme","value": &q…

Buildroot系列开发(五)bootloader简述

参考:百问网 文章目录1.什么是Boot-loader?2.有哪些bootloader?哪些支持linux?3.Bootloader支持的Flash设备4.Bootloader支持的文件系统类型4.Bootloader支持的CPU架构5.Bootloader总结1.什么是Boot-loader? 2.有哪些bootloader?哪些支持linux&#…

广州蓝景分享——前端学习5 种在 JavaScript 中获取字符串第一个字符的方法

在本文中,我们将研究多种方法来轻松获取 JavaScript 中字符串的第一个字符。 1.charAt() 方法 要获取字符串的第一个字符,我们可以在字符串上调用 charAt() ,将 0 作为参数传递。例如,str.charAt(0) 返回 str 的第一个字符。 c…

AT1106S(PHS/EN输入接口通道0.8A低压H桥直流刷式电机驱动IC)

描述 泛海微AT1106S为摄像机、消费类产品、玩具和其它低电压或者电池供电的运动控制类应用提供了一个集成的电机驱动器解决方案。泛海微AT1106S能够驱动一个直流电机或其他诸 如螺线管的器件。输出驱动模块由N MOS功率管构成的H桥组成,以驱动电机绕组。泛海微AT110…

车企接连押注「重感知」 ,高精地图真会被弃用?

实现高阶智能驾驶,“重感知”是否为大势所趋? 答案正日益明晰。 2022年,以特斯拉为代表的“重感知”阵营,押注者正日趋增多。以在2022年尝试落地城市NOA的三家厂商为例:毫末智行一早便属“重感知”阵营;小…

【20221208】【每日一题】目标和

给你一个整数数组 nums 和一个整数 target 。 向数组中的每个整数前添加 或 - ,然后串联起所有整数,可以构造一个 表达式 : 例如,nums [2, 1] ,可以在 2 之前添加 ,在 1 之前添加 - ,然后串…

5G无线技术基础自学系列 | SA移动性管理流程

素材来源:《5G无线网络规划与优化》 一边学习一边整理内容,并与大家分享,侵权即删,谢谢支持! 附上汇总贴:5G无线技术基础自学系列 | 汇总_COCOgsta的博客-CSDN博客 SA移动性管理流程包括站内切换、Xn切换…

Java基础之序列化和反序列化

序列化的实现 java.io中的对象流提供了序列化和反序列化对象的方法 对象输出流 ObjectOutputStream 构造方法: ObjectOutputStream(OutputStream out) 保存对象的方法: void writeObject(Object obj) 对象输入流 ObjectInputStream 构造方法&…

使用 MySQL、Thymeleaf 和 Spring Boot Framework 上传、存储和查看图像

在本文中,我们将使用 Spring Boot 框架从头开始构建映像库应用程序,用户可以在其中列出其映像。 以下是我们将在应用程序中实现的功能。 用户可以列出他们的图像以及详细信息,例如, 名字描述图像价格。(如果他们想卖…

Win11 启用旧右键菜单 _ Windows11 右键改回老版

Win11 系统在使用上和之前的系统差不多,但是在设计上,有了很大的改变,系统界面,设置等功能都使用了全新的风格,包括右键菜单,这让很多用户使用起来都很不习惯,因此想改回旧版的右键菜单来使用。…

汽车控制器概述

目录 一、整车控制器(VCU) 功能 工作模式 二、发动机控制器/电子控制单元(ECU) ECU基本组成 ECU的作用 ECU的工作原理 常见的ECU的类型 三、电机控制器(MCU) 四、 电池管理系统(BMS&a…

cubeIDE开发, stm32的USB从设备串口驱动设计

一、USB_OTG简介 USB_OTG(OTG,ON THE GO)是一款双角色设备(DRD) 控制器,同时支持从机(USB DEVICE)功能和主机(USB HOST)功能。在主机模式下,OTG 支持全速(OTG…

2022圣诞在即,出海品牌如何做好网红营销?

随着2022圣诞节逐渐临近,节日气氛也开始浓郁起来,尤其在社交媒体上,圣诞主题的内容越来越多,随之而来的则是各种营销与折扣。受经济形势影响,性价比在当下显得尤为重要,有60%的消费者表示,今年圣…

【能效分析】安科瑞变电所运维云平台解决方案应用分析

概述 安科瑞 李亚俊 壹捌柒贰壹零玖捌柒伍柒 AcrelCloud-1000变电所运维云平台基于互联网+大数据、移动通讯等技术开发的云端管理平台,满足用户或运维公司监测众多变电所回路运行状态和参数、室内环境温湿度、电缆及母线运行温度、现场设备或环境视频场…

CentOS MySQL安装

1.查询是否已经存在mariadb。 rpm -qa|grep mariadb如果存在需要卸载。 rpm -e --nodeps mariadb-libs-5.5.68-1.el7.x86_642.通过xftp上传MySQL和Hive压缩包。 3.解压压缩包。 tar -zxvf apache-hive-2.3.4-bin.tar.gz -C /opt/apps/ tar -zxvf mysql-5.7.27-el7-x86_64.ta…

042-推箱子游戏源代码2

上一讲:041-推箱子游戏1_CSDN专家-赖老师(软件之家)的博客-CSDN博客 摘要: 1、使用JAVA基础知识 2、GUI界面编程实现推箱子界面,常用控件的综合应用; 3、使用JAVA绘图技术实现推箱子过程的绘图功能; 4、使用键盘事件,通过方向键实现推箱子过程; 5、使用音频技术,…

Android实现车辆检测(含Android源码 可实时运行)

Android实现车辆检测(含Android源码 可实时运行) 目录 Android实现车辆检测(含Android源码 可实时运行) 1. 前言 2. 车辆检测数据集说明 3. 基于YOLOv5的车辆检测模型训练 4.车辆检测模型Android部署 (1) 将Pytorch模型转换ONNX模型 &#xff08…

Python编程 圣诞树教程 (附代码)程序员的浪漫

作者简介:一名在校计算机学生、每天分享Python的学习经验、和学习笔记。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.python 做圣诞树 1.turtle库 2.python函数的定义规则 2.引入库 3.定…

中断系统中的设备树__在S3C2440上使用设备树描述中断体验

目录 1 怎么描述一个中断 2 怎么描述一个中断控制器 3 总结 1 怎么描述一个中断 我们想在设备树文件中描述一个中断,那么需要两个东西 a.指定是哪一个中断控制器 b.是中断控制器里面的哪一个中断。 假设我们有一个网卡,当网卡有数据时会产生一个中…

论文速度系列三:SA-SSD、CIA-SSD、SE-SSD

如有错误,恳请指出。 参考网上资料,对一些经典论文进行快速思路整理 文章目录1. SA-SSD2. CIA-SSD3. SE-SSD1. SA-SSD paper:《Structure Aware Single-stage 3D Object Detection from Point Cloud》(2020CVPR) 结构…