A tool to test Nic's i2c function
Go to file
leimingsheng 0bb410c72f feat(master : nicsensor) update to version 1.8.2
1.增加配置项fru_size,默认读取大小256字节
2025-12-04 09:21:49 +08:00
docs feat(master : nicsensor) Release Version 1.8 2025-08-18 14:21:01 +08:00
nicsensor_v2 feat(plugin : plugin_%)同步可配置为disable跳过数据转化的功能到V2 2025-07-03 10:08:37 +08:00
test_plugin feat(master : test_tool)添加阈值判断脚本 2025-06-27 14:29:53 +08:00
tool feat(plugin : release) release nicsensor v2 2025-03-13 16:40:53 +08:00
.gitignore create plugin branch 2025-01-06 09:10:08 +08:00
nicsensor_s.sh feat(master : nicsensor) 新增脚本nicsensor_s.sh 2025-08-18 14:20:10 +08:00
nicsensor.sh feat(master : nicsensor) update to version 1.8.2 2025-12-04 09:21:49 +08:00
readme.md feat(master : nicsensor) update to version 1.8.2 2025-12-04 09:21:49 +08:00

nicsensor工具使用说明

本说明仅针对 nicsensorv1.x系列脚本 1.x系列工具本体: nicsensor.sh

目录

1_简介

nicsensor工具是在带有i2ctool工具(i2ctransfer、i2cdetect)的BMC下用于测试网卡I2C功能的工具。

当前支持的功能有:

  • 读取网卡上的I2C传感器
  • 读取并修改网卡上的FRU
  • 透传I2C命令到网卡的芯片上
  • 遍历服务器上的PCIE插槽的I2C信息
  • 部分服务器类型支持读取OCP卡

当前支持测试的传感器类型

  • adc128
  • ina3221
  • emc1413
  • tmp468
  • tmp112

Tip

每次执行脚本都可以在 /tmp/nicsensor_debug.log 查询详细的命令执行记录

2_使用方法

Warning

在使用时针对网卡的硬件特性需要定制化修改脚本的 Project Varible ,变量的对应关系及说明见Project变量说明

2_1_传感器读取

命令格式

./nicsensor.sh <pcie_slot> <sensor_tpye> <sensor_slave>

参数说明

  • pcie slot:网卡位于的PCIE SLOT槽位,需要指定pcie/ocp, 不指定时默认为pcie类型
  • sensor type:传感器类型
  • sensor slave:传感器的slave地址

命令示例

# 读取pcie2槽位上的adc128的信息, adc128芯片的地址为0x1f(7bit)
./nicsensor.sh pcie2 adc128 0x1f

2_2_FRU相关操作

Warning

在写入网卡FRU操作时受限于服务器PCA9641的影响需要将服务器关机后执行

命令格式

# 读取FRU
./nicsensor.sh <pcie_slot> fru <eeprom_slave>

# 写入FRU
./nicsensor.sh <pcie_slot> fru <eeprom_slave> write <filename>

参数说明

  • pcie slot:网卡位于的PCIE SLOT槽位,需要指定pcie/ocp, 不指定时默认为pcie类型
  • eeprom slave: FRU所在的eeprom芯片的slave地址
  • filename: 仅在写入FRU时提供, 要写入的FRU bin文件

命令示例

# 读取pcie2槽位上的fru信息, eeprom的芯片地址为0x50(7bit)
./nicsensor.sh pcie2 fru 0x50

# 写入pcie2槽位上网卡的fru
./nicsensor.sh pcie2 fru 0x50 write fru.bin

2_3_命令透传

命令格式

./nicsensor.sh <pcie_slot> chip <chip slave> <command>

参数说明

  • pcie slot:网卡位于的PCIE SLOT槽位,需要指定pcie/ocp, 不指定时默认为pcie类型
  • chip slave: 芯片的slave地址
  • command: 要透传执行的I2C命令

命令示例

# 对pcie2槽位上的chip透传命令 i2ctransfer -y 12 w2@0x11 0x00 0x00 r2 , 芯片地址为0x11(7bit)
./nicsensor.sh pcie2 chip 0x11 "i2ctransfer -y 12 w2@0x11 0x00 0x00 r2"

2_4_插槽I2C信息遍历

命令格式

./nicsensor.sh detect <nic_type>

参数说明

  • nic type:需要指定pcie/ocp, 不指定时默认为pcie类型

命令示例

./nicsensor.sh detect pcie

2_5_调试模式使用

关联变量 DEBUG_MODE, 启用调试模式时需要将该变量的值配置为1

如果不需要借助脚本来选通服务器上对应的channel, 仅需要做传感器数值测试, 可以启用调试模式。 在调试模式下, 脚本不会执行选通PCA9641以及PCA9546/9548的操作。仅直接测试传感器。因此需要手动调整两个变量

  • DEBUG_MODE
  • i2c_bus

关联变量 DISABLE_DETECT, 启用时配置为1, 将不会在切换PCA9641和PCA9548时进行i2cdetect

2_6_扩展功能

脚本中预留了函数 handle_reserve 用于扩展功能。针对有特殊需求的项目可能会使用。

handle_reserve 中可以自定义需要对网卡实现的功能。在调用该函数之前脚本会将 PCA9641及PCA9548选通。扩展功能时无需考虑PCA9641和PCA9548的状态。

2_7_设定配置功能

Warning

版本要求:

  • 测试版本 1.7.7 以上
  • 正式版本 1.8 及以上

可以通过一组名为 get/set 的指令对脚本中的如下变量做即时修改而无需修改脚本本体。支持修改的变量如下:

  • server_type : 对应属性值缩写 server
  • DEBUG_MODE : 对应属性值缩写 debug
  • DISABLE_DETECT : 对应属性值缩写 detect

命令格式

./nicsensor.sh <get/set> <property> <value>

命令示例

./nicsensor.sh set server 5280m7

./nicsneosr.sh get debug

3_常见问题

3_1_ADC128传感器读值为0

ADC128传感器在使用时需要初始化, 因此第一次读取时传感器可能并未完成初始化, 所以读值为0

3_2_脚本执行时出现大批量语法错误

通常是因为服务器上含有PCA9641切断了BMC的I2C控制权导致重试即可

4_附属工具

4_1_FruParse

提供了一个简单python脚本用于解析FRU的数据, 将nicsensor读取到的FRU数据拷贝到frudata.txt后, 执行 python fru_parse.py即可将读取到的数据转化为FRU内容

4_2_nicsensor_s

基于脚本版本1.8, 剔除了所有记日志的操作用于加速i2c的执行, 确保在9641工作的生命周期内尽快完成i2c任务

5_关于nicsensor_v2

nicsensor_v2将服务器选通channel和读取传感器数值的功能解耦因此在单独使用某个功能时可以直接找到对应的脚本进行测试。 详见nicsensor_v2

6_附录

6_1_Project变量说明

Important

对于所有传感器的xxx_Channel_name, 将其配置为disable即可跳过对应的channel的数据解析。 推荐在硬件上空置的Channel将其配置为 disable,防止脚本解析数据时出现混淆

ADC128相关

  • votage_division_factor_0: ADC128芯片Channel 0的分压系数

  • votage_division_factor_1: ADC128芯片Channel 1的分压系数

  • votage_division_factor_2: ADC128芯片Channel 2的分压系数

  • votage_division_factor_3: ADC128芯片Channel 3的分压系数

  • votage_division_factor_4: ADC128芯片Channel 4的分压系数

  • votage_division_factor_5: ADC128芯片Channel 5的分压系数

  • votage_division_factor_6: ADC128芯片Channel 6的分压系数

  • votage_division_factor_7: ADC128芯片Channel 7的分压系数

  • ADC128_Channel0_name: 定制化ADC128芯片Channel 0的电压名称

  • ADC128_Channel1_name: 定制化ADC128芯片Channel 1的电压名称

  • ADC128_Channel2_name: 定制化ADC128芯片Channel 2的电压名称

  • ADC128_Channel3_name: 定制化ADC128芯片Channel 3的电压名称

  • ADC128_Channel4_name: 定制化ADC128芯片Channel 4的电压名称

  • ADC128_Channel5_name: 定制化ADC128芯片Channel 5的电压名称

  • ADC128_Channel6_name: 定制化ADC128芯片Channel 6的电压名称

  • ADC128_Channel7_name: 定制化ADC128芯片Channel 7的电压名称

INA3221相关

  • shunt_resistor_0: INA3221芯片的Channel 0外接的分流电阻的大小(单位:毫欧)

  • shunt_resistor_1: INA3221芯片的Channel 1外接的分流电阻的大小(单位:毫欧)

  • shunt_resistor_2: INA3221芯片的Channel 2外接的分流电阻的大小(单位:毫欧)

  • INA3221_Channel0_name: 定制化INA3221芯片Channel 0的名称

  • INA3221_Channel1_name: 定制化INA3221芯片Channel 1的名称

  • INA3221_Channel2_name: 定制化INA3221芯片Channel 2的名称

EMC1413相关

  • EMC1413_Channel0_name: 定制化EMC1413芯片Channel 0的温度名称
  • EMC1413_Channel1_name: 定制化EMC1413芯片Channel 1的温度名称
  • EMC1413_Channel2_name: 定制化EMC1413芯片Channel 2的温度名称

TMP468相关

  • TMP468_Channel0_name: 定制化TMP468芯片Loacl Channel的温度名称
  • TMP468_Channel1_name: 定制化TMP468芯片Remote1 Channel的温度名称
  • TMP468_Channel2_name: 定制化TMP468芯片Remote2 Channel的温度名称
  • TMP468_Channel3_name: 定制化TMP468芯片Remote3 Channel的温度名称
  • TMP468_Channel4_name: 定制化TMP468芯片Remote4 Channel的温度名称
  • TMP468_Channel5_name: 定制化TMP468芯片Remote5 Channel的温度名称
  • TMP468_Channel6_name: 定制化TMP468芯片Remote6 Channel的温度名称
  • TMP468_Channel7_name: 定制化TMP468芯片Remote7 Channel的温度名称
  • TMP468_Channel8_name: 定制化TMP468芯片Remote8 Channel的温度名称

TMP112相关

  • TMP112_Sensor_name: 定制化TMP112对应的名称

FRU相关

  • fru_offset: 网卡FRU所在eeprom的偏移量。默认值为 0x00 0x00
  • fru_size: 读取FRU时要读取的长度, 默认读取长度为256, 可根据实际需要扩展

所用服务器

  • server_type: 脚本将工作在哪个服务器上?支持的服务器列表见Support_Server_List, 默认值为auto,支持自动识别受支持的型号。

Tip

server_type被配置为auto时,脚本会尝试自动获取服务器类型,如果获取失败,仍需手动配置该变量。