1*88e37e3dSYanteng Si.. include:: ../disclaimer-zh_CN.rst 2*88e37e3dSYanteng Si 3*88e37e3dSYanteng Si:Original: Documentation/infiniband/ipoib.rst 4*88e37e3dSYanteng Si 5*88e37e3dSYanteng Si:翻译: 6*88e37e3dSYanteng Si 7*88e37e3dSYanteng Si 司延腾 Yanteng Si <siyanteng@loongson.cn> 8*88e37e3dSYanteng Si 9*88e37e3dSYanteng Si:校译: 10*88e37e3dSYanteng Si 11*88e37e3dSYanteng Si 王普宇 Puyu Wang <realpuyuwang@gmail.com> 12*88e37e3dSYanteng Si 时奎亮 Alex Shi <alexs@kernel.org> 13*88e37e3dSYanteng Si 14*88e37e3dSYanteng Si.. _cn_infiniband_ipoib: 15*88e37e3dSYanteng Si 16*88e37e3dSYanteng Si========================= 17*88e37e3dSYanteng Siinfiniband上的IP(IPoIB) 18*88e37e3dSYanteng Si========================= 19*88e37e3dSYanteng Si 20*88e37e3dSYanteng Si ib_ipoib驱动是IETF ipoib工作组发布的RFC 4391和4392所规定的 21*88e37e3dSYanteng Si infiniband上IP协议的一个实现。它是一个“本地”实现,即把接口类型设置为 22*88e37e3dSYanteng Si ARPHRD_INFINIBAND,硬件地址长度为20(早期的专有实现向内核伪装为以太网 23*88e37e3dSYanteng Si 接口)。 24*88e37e3dSYanteng Si 25*88e37e3dSYanteng Si分区和P_Keys 26*88e37e3dSYanteng Si============ 27*88e37e3dSYanteng Si 28*88e37e3dSYanteng Si 当IPoIB驱动被加载时,它会使用索引为0的P_Key给每个端口创建一个接口。要用 29*88e37e3dSYanteng Si 不同的P_Key创建一个接口,将所需的P_Key写入主接口的 30*88e37e3dSYanteng Si /sys/class/net/<intf name>/create_child文件里面。比如说:: 31*88e37e3dSYanteng Si 32*88e37e3dSYanteng Si echo 0x8001 > /sys/class/net/ib0/create_child 33*88e37e3dSYanteng Si 34*88e37e3dSYanteng Si 这将用P_Key 0x8001创建一个名为ib0.8001的接口。要删除一个子接口,使用 35*88e37e3dSYanteng Si ``delete_child`` 文件:: 36*88e37e3dSYanteng Si 37*88e37e3dSYanteng Si echo 0x8001 > /sys/class/net/ib0/delete_child 38*88e37e3dSYanteng Si 39*88e37e3dSYanteng Si 任何接口的P_Key都由“pkey”文件给出,而子接口的主接口在“parent”中。 40*88e37e3dSYanteng Si 41*88e37e3dSYanteng Si 子接口的创建/删除也可以使用IPoIB的rtnl_link_ops来完成,使用两种 42*88e37e3dSYanteng Si 方式创建的子接口的行为是一样的。 43*88e37e3dSYanteng Si 44*88e37e3dSYanteng Si数据报与连接模式 45*88e37e3dSYanteng Si================ 46*88e37e3dSYanteng Si 47*88e37e3dSYanteng Si IPoIB驱动支持两种操作模式:数据报和连接。模式是通过接口的 48*88e37e3dSYanteng Si /sys/class/net/<intf name>/mode文件设置和读取的。 49*88e37e3dSYanteng Si 50*88e37e3dSYanteng Si 在数据报模式下,使用IB UD(不可靠数据报)传输,因此接口MTU等于IB L2 MTU 51*88e37e3dSYanteng Si 减去IPoIB封装头(4字节)。例如,在一个典型的具有2K MTU的IB结构中,IPoIB 52*88e37e3dSYanteng Si MTU将是2048 - 4 = 2044字节。 53*88e37e3dSYanteng Si 54*88e37e3dSYanteng Si 在连接模式下,使用IB RC(可靠的连接)传输。连接模式利用IB传输的连接特性, 55*88e37e3dSYanteng Si 允许MTU达到最大的IP包大小64K,这减少了处理大型UDP数据包、TCP段等所需的 56*88e37e3dSYanteng Si IP包数量,提高了大型信息的性能。 57*88e37e3dSYanteng Si 58*88e37e3dSYanteng Si 在连接模式下,接口的UD QP仍被用于组播和与不支持连接模式的对等体的通信。 59*88e37e3dSYanteng Si 在这种情况下,ICMP PMTU数据包的RX仿真被用来使网络堆栈对这些邻居使用较 60*88e37e3dSYanteng Si 小的UD MTU。 61*88e37e3dSYanteng Si 62*88e37e3dSYanteng Si无状态卸载 63*88e37e3dSYanteng Si========== 64*88e37e3dSYanteng Si 65*88e37e3dSYanteng Si 如果IB HW支持IPoIB无状态卸载,IPoIB会向网络堆栈广播TCP/IP校验和/或大量 66*88e37e3dSYanteng Si 传送(LSO)负载转移能力。 67*88e37e3dSYanteng Si 68*88e37e3dSYanteng Si 大量传送(LSO)负载转移也已实现,可以使用ethtool调用打开/关闭。目前,LRO 69*88e37e3dSYanteng Si 只支持具有校验和卸载能力的设备。 70*88e37e3dSYanteng Si 71*88e37e3dSYanteng Si 无状态卸载只在数据报模式下支持。 72*88e37e3dSYanteng Si 73*88e37e3dSYanteng Si中断管理 74*88e37e3dSYanteng Si======== 75*88e37e3dSYanteng Si 76*88e37e3dSYanteng Si 如果底层IB设备支持CQ事件管理,可以使用ethtool来设置中断缓解参数,从而减少 77*88e37e3dSYanteng Si 处理中断产生的开销。IPoIB的主要代码路径不使用TX完成信号的事件,所以只支持 78*88e37e3dSYanteng Si RX管理。 79*88e37e3dSYanteng Si 80*88e37e3dSYanteng Si调试信息 81*88e37e3dSYanteng Si======== 82*88e37e3dSYanteng Si 83*88e37e3dSYanteng Si 通过将CONFIG_INFINIBAND_IPOIB_DEBUG设置为“y”来编译IPoIB驱动,跟踪信 84*88e37e3dSYanteng Si 息被编译到驱动中。通过将模块参数debug_level和mcast_debug_level设置为1来 85*88e37e3dSYanteng Si 打开它们。这些参数可以在运行时通过/sys/module/ib_ipoib/的文件来控制。 86*88e37e3dSYanteng Si 87*88e37e3dSYanteng Si CONFIG_INFINIBAND_IPOIB_DEBUG也启用debugfs虚拟文件系统中的文件。通过挂 88*88e37e3dSYanteng Si 载这个文件系统,例如用:: 89*88e37e3dSYanteng Si 90*88e37e3dSYanteng Si mount -t debugfs none /sys/kernel/debug 91*88e37e3dSYanteng Si 92*88e37e3dSYanteng Si 可以从/sys/kernel/debug/ipoib/ib0_mcg等文件中获得关于多播组的统计数据。 93*88e37e3dSYanteng Si 94*88e37e3dSYanteng Si 这个选项对性能的影响可以忽略不计,所以在正常运行时,在debug_level设置为 95*88e37e3dSYanteng Si 0的情况下启用这个选项是安全的。 96*88e37e3dSYanteng Si 97*88e37e3dSYanteng Si CONFIG_INFINIBAND_IPOIB_DEBUG_DATA当data_debug_level设置为1时,可以 98*88e37e3dSYanteng Si 在数据路径中启用更多的调试输出。 然而,即使禁用输出,启用这个配置选项也 99*88e37e3dSYanteng Si 会影响性能,因为它在快速路径中增加了测试。 100*88e37e3dSYanteng Si 101*88e37e3dSYanteng Si引用 102*88e37e3dSYanteng Si==== 103*88e37e3dSYanteng Si 104*88e37e3dSYanteng Si 在InfiniBand上传输IP(IPoIB)(RFC 4391)。 105*88e37e3dSYanteng Si http://ietf.org/rfc/rfc4391.txt 106*88e37e3dSYanteng Si 107*88e37e3dSYanteng Si infiniband上的IP:上的IP架构(RFC 4392)。 108*88e37e3dSYanteng Si http://ietf.org/rfc/rfc4392.txt 109*88e37e3dSYanteng Si 110*88e37e3dSYanteng Si infiniband上的IP: 连接模式 (RFC 4755) 111*88e37e3dSYanteng Si http://ietf.org/rfc/rfc4755.txt 112