162306a36Sopenharmony_ci.. include:: ../disclaimer-zh_CN.rst
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci:Original: Documentation/infiniband/ipoib.rst
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci:翻译:
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci 司延腾 Yanteng Si <siyanteng@loongson.cn>
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci:校译:
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci 王普宇 Puyu Wang <realpuyuwang@gmail.com>
1262306a36Sopenharmony_ci 时奎亮 Alex Shi <alexs@kernel.org>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci.. _cn_infiniband_ipoib:
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci=========================
1762306a36Sopenharmony_ciinfiniband上的IP(IPoIB)
1862306a36Sopenharmony_ci=========================
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci  ib_ipoib驱动是IETF ipoib工作组发布的RFC 4391和4392所规定的
2162306a36Sopenharmony_ci  infiniband上IP协议的一个实现。它是一个“本地”实现,即把接口类型设置为
2262306a36Sopenharmony_ci  ARPHRD_INFINIBAND,硬件地址长度为20(早期的专有实现向内核伪装为以太网
2362306a36Sopenharmony_ci  接口)。
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci分区和P_Keys
2662306a36Sopenharmony_ci============
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci  当IPoIB驱动被加载时,它会使用索引为0的P_Key给每个端口创建一个接口。要用
2962306a36Sopenharmony_ci  不同的P_Key创建一个接口,将所需的P_Key写入主接口的
3062306a36Sopenharmony_ci  /sys/class/net/<intf name>/create_child文件里面。比如说::
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci    echo 0x8001 > /sys/class/net/ib0/create_child
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci  这将用P_Key 0x8001创建一个名为ib0.8001的接口。要删除一个子接口,使用
3562306a36Sopenharmony_ci  ``delete_child`` 文件::
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci    echo 0x8001 > /sys/class/net/ib0/delete_child
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  任何接口的P_Key都由“pkey”文件给出,而子接口的主接口在“parent”中。
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci  子接口的创建/删除也可以使用IPoIB的rtnl_link_ops来完成,使用两种
4262306a36Sopenharmony_ci  方式创建的子接口的行为是一样的。
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci数据报与连接模式
4562306a36Sopenharmony_ci================
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci  IPoIB驱动支持两种操作模式:数据报和连接。模式是通过接口的
4862306a36Sopenharmony_ci  /sys/class/net/<intf name>/mode文件设置和读取的。
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci  在数据报模式下,使用IB UD(不可靠数据报)传输,因此接口MTU等于IB L2 MTU
5162306a36Sopenharmony_ci  减去IPoIB封装头(4字节)。例如,在一个典型的具有2K MTU的IB结构中,IPoIB
5262306a36Sopenharmony_ci  MTU将是2048 - 4 = 2044字节。
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci  在连接模式下,使用IB RC(可靠的连接)传输。连接模式利用IB传输的连接特性,
5562306a36Sopenharmony_ci  允许MTU达到最大的IP包大小64K,这减少了处理大型UDP数据包、TCP段等所需的
5662306a36Sopenharmony_ci  IP包数量,提高了大型信息的性能。
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  在连接模式下,接口的UD QP仍被用于组播和与不支持连接模式的对等体的通信。
5962306a36Sopenharmony_ci  在这种情况下,ICMP PMTU数据包的RX仿真被用来使网络堆栈对这些邻居使用较
6062306a36Sopenharmony_ci  小的UD MTU。
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci无状态卸载
6362306a36Sopenharmony_ci==========
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci  如果IB HW支持IPoIB无状态卸载,IPoIB会向网络堆栈广播TCP/IP校验和/或大量
6662306a36Sopenharmony_ci  传送(LSO)负载转移能力。
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci  大量传送(LSO)负载转移也已实现,可以使用ethtool调用打开/关闭。目前,LRO
6962306a36Sopenharmony_ci  只支持具有校验和卸载能力的设备。
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci  无状态卸载只在数据报模式下支持。
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci中断管理
7462306a36Sopenharmony_ci========
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci  如果底层IB设备支持CQ事件管理,可以使用ethtool来设置中断缓解参数,从而减少
7762306a36Sopenharmony_ci  处理中断产生的开销。IPoIB的主要代码路径不使用TX完成信号的事件,所以只支持
7862306a36Sopenharmony_ci  RX管理。
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci调试信息
8162306a36Sopenharmony_ci========
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci  通过将CONFIG_INFINIBAND_IPOIB_DEBUG设置为“y”来编译IPoIB驱动,跟踪信
8462306a36Sopenharmony_ci  息被编译到驱动中。通过将模块参数debug_level和mcast_debug_level设置为1来
8562306a36Sopenharmony_ci  打开它们。这些参数可以在运行时通过/sys/module/ib_ipoib/的文件来控制。
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci  CONFIG_INFINIBAND_IPOIB_DEBUG也启用debugfs虚拟文件系统中的文件。通过挂
8862306a36Sopenharmony_ci  载这个文件系统,例如用::
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_ci    mount -t debugfs none /sys/kernel/debug
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci  可以从/sys/kernel/debug/ipoib/ib0_mcg等文件中获得关于多播组的统计数据。
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci  这个选项对性能的影响可以忽略不计,所以在正常运行时,在debug_level设置为
9562306a36Sopenharmony_ci  0的情况下启用这个选项是安全的。
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci  CONFIG_INFINIBAND_IPOIB_DEBUG_DATA当data_debug_level设置为1时,可以
9862306a36Sopenharmony_ci  在数据路径中启用更多的调试输出。 然而,即使禁用输出,启用这个配置选项也
9962306a36Sopenharmony_ci  会影响性能,因为它在快速路径中增加了测试。
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci引用
10262306a36Sopenharmony_ci====
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci  在InfiniBand上传输IP(IPoIB)(RFC 4391)。
10562306a36Sopenharmony_ci    http://ietf.org/rfc/rfc4391.txt
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci  infiniband上的IP:上的IP架构(RFC 4392)。
10862306a36Sopenharmony_ci    http://ietf.org/rfc/rfc4392.txt
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_ci  infiniband上的IP: 连接模式 (RFC 4755)
11162306a36Sopenharmony_ci    http://ietf.org/rfc/rfc4755.txt
112