5.2.1. proc文件系统介绍

proc文件系统接口在/proc节点下创建设备信息节点,用户通过cat或者编程的方式读取相关节点获取设备温度、版本等信息。

bm-smi侧重于以界面的形式直观显示设备信息,proc文件系统接口侧重于为用户提供编程获取设备信息的接口。 下表列举了proc文件系统可以获取的设备信息以及在PCIe和SOC模式下的支持情况:

设备信息

PCIe模式

SOC模式

card_num

支持

不支持

chip_num

支持

不支持

chip_num_on_card

支持

不支持

board_power

支持

不支持

board_temp

支持

不支持

chipid

支持

不支持

chip_temp

支持

不支持

dbdf

支持

不支持

dynfreq

支持

不支持

ecc

支持

不支持

maxboardp

支持

不支持

mode

支持

不支持

pcie_cap_speed

支持

不支持

pcie_cap_width

支持

不支持

pcie_link_speed

支持

不支持

pcie_link_width

支持

不支持

pcie_region

支持

不支持

tpuid

支持

不支持

tpu_maxclk

支持

不支持

tpu_minclk

支持

不支持

tpu_freq

支持

不支持

tpu_power

支持

不支持

firmware_info

支持

不支持

sn

支持

不支持

boot_loader_version

支持

不支持

board_type

支持

不支持

driver_version

支持

不支持

board_version

支持

不支持

mcu_version

支持

不支持

versions

支持

不支持

cdma_in_time

支持

不支持

cdma_in_counter

支持

不支持

cdma_out_time

支持

不支持

cdma_out_counter

支持

不支持

tpu_process_time

支持

不支持

completed_api_counter

支持

不支持

send_api_counter

支持

不支持

tpu_volt

支持

不支持

tpu_cur

支持

不支持

fan_speed

支持

不支持

media

支持

不支持

a53_enable

支持

不支持

arm9_cache

支持

不支持

bmcpu_status

支持

不支持

bom_version

支持

不支持

boot_mode

支持

不支持

clk

支持

不支持

ddr_capacity

支持

不支持

dumpreg

支持

不支持

heap

支持

不支持

location

支持

不支持

pcb_version

支持

不支持

pmu_infos

支持

不支持

status

支持

不支持

vddc_power

支持

不支持

vddphy_power

支持

不支持

jpu

不支持

支持

vpu

不支持

支持

驱动安装时系统根据板卡数量依次创建/proc/bmsophon/card0…n目录,其中card0目录对应存放第0张板卡的信息,card1目录对应存放第1张板卡信息,依次类推。

在板卡目录下根据当前板卡上设备数量依次创建/proc/bmsophon/cardn/bmsophon0…x目录,其中bmsophonx中的x对应板卡n下设备id为x的设备信息,例如机器上只插了一张SC5+,安装驱动后对应生成/proc/bmsophon/card0,card0目录下会生成bmsophon0/1/2目录,分别存放设备0/1/2的信息。

SOC模式只有JPU和VPU支持 proc文件系统接口,节点分别是/proc/jpuinfo和/proc/vpuinfo。

5.2.2. 各项参数的含义

SOC模式只有/proc/jpuinfo和/proc/vpuinfo; PCIe 模式proc文件系统中目录和文件节点安排如下:

bitmain@weiqiao-MS-7B46:~/work/bm168x$ ls /proc/bmsophon/ -l

total 0

-r--r--r--.
1 root root 0 5月 6 23:06 card_num

-r--r--r--.
1 root root 0 5月 6 23:06 chip_num

-r--r--r--.
1 root root 0 5月 6 23:06 driver_version

dr-xr-xr-x 2 root root 0 5月 6 13:46 card0 //文件夹下面有板卡0的信息,如下:

bitmain@weiqiao-MS-7B46:~/work/bm168x$ ls /proc/bmsophon/card0/ -l

total 0

-r--r--r--.
1 root root 0 5月 6 23:06 board_power

-r--r--r--.
1 root root 0 5月 6 23:06 board_temp

-r--r--r--.
1 root root 0 5月 6 23:06 board_type

-r--r--r--.
1 root root 0 5月 6 23:06 board_version

-r--r--r--.
1 root root 0 5月 6 23:06 bom_version

-r--r--r--.
1 root root 0 5月 6 23:06 chipid

-r--r--r--.
1 root root 0 5月 6 23:06 chip_num_on_card

-rw-r--r--.
1 root root 0 5月 6 23:06 fan_speed

-r--r--r--.
1 root root 0 5月 6 23:06 maxboardp

-r--r--r--.
1 root root 0 5月 6 23:06 mode

-r--r--r--.
1 root root 0 5月 6 23:06 pcb_version

-r--r--r--.
1 root root 0 5月 6 23:06 sn

-r--r--r--.
1 root root 0 5月 6 23:06 tpu_maxclk

-r--r--r--.
1 root root 0 5月 6 23:06 tpu_minclk

-r--r--r--.
1 root root 0 5月 6 23:06 versions

dr-xr-xr-x.
2 root root 0 5月 6 23:06 bmsophon0//文件夹下有设备0的信息,如下:

bitmain@weiqiao-MS-7B46:~/work/bm168x$ ls /proc/bmsophon/card0/bmsophon0 -l

total 0

-r--r--r--.
1 root root 0 5月 6 23:11 a53_enable

-r--r--r--.
1 root root 0 5月 6 23:11 arm9_cache

-r--r--r--.
1 root root 0 5月 6 23:11 bmcpu_status

-r--r--r--.
1 root root 0 5月 6 23:11 boot_loader_version

-r--r--r--.
1 root root 0 5月 6 23:11 boot_mode

-r--r--r--.
1 root root 0 5月 6 23:11 cdma_in_counter

-r--r--r--.
1 root root 0 5月 6 23:11 cdma_in_time

-r--r--r--.
1 root root 0 5月 6 23:11 cdma_out_counter

-r--r--r--.
1 root root 0 5月 6 23:11 cdma_out_time

-r--r--r--.
1 root root 0 5月 6 23:11 chip_temp

-r--r--r--.
1 root root 0 5月 6 23:11 clk

-r--r--r--.
1 root root 0 5月 6 23:11 completed_api_counter

-r--r--r--.
1 root root 0 5月 6 23:11 dbdf

-r--r--r--.
1 root root 0 5月 6 23:11 ddr_capacity

-rw-r--r--.
1 root root 0 5月 6 23:11 dumpreg

-rw-r--r--.
1 root root 0 5月 6 23:11 dynfreq

-r--r--r--.
1 root root 0 5月 6 23:11 ecc

-r--r--r--.
1 root root 0 5月 6 23:11 heap

-rw-r--r--.
1 root root 0 5月 6 23:11 jpu

-r--r--r--.
1 root root 0 5月 6 23:11 location

-r--r--r--.
1 root root 0 5月 6 23:11 mcu_version

-rw-r--r--.
1 root root 0 5月 6 23:11 media

-r--r--r--.
1 root root 0 5月 6 23:11 pcie_cap_speed

-r--r--r--.
1 root root 0 5月 6 23:11 pcie_cap_width

-r--r--r--.
1 root root 0 5月 6 23:11 pcie_link_speed

-r--r--r--.
1 root root 0 5月 6 23:11 pcie_link_width

-r--r--r--.
1 root root 0 5月 6 23:11 pcie_region

-r--r--r--.
1 root root 0 5月 6 23:11 pmu_infos

-r--r--r--.
1 root root 0 5月 6 23:11 sent_api_counter

-r--r--r--.
1 root root 0 5月 6 23:11 status

-r--r--r--.
1 root root 0 5月 6 23:11 tpu_cur

-rw-r--r--.
1 root root 0 5月 6 23:06 tpu_freq

-r--r--r--.
1 root root 0 5月 6 23:11 tpuid

-r--r--r--.
1 root root 0 5月 6 23:11 tpu_power

-r--r--r--.
1 root root 0 5月 6 23:11 firmware_info

-r--r--r--.
1 root root 0 5月 6 23:11 tpu_process_time

-rw-r--r--.
1 root root 0 5月 6 23:11 tpu_volt

-rw-r--r--.
1 root root 0 5月 6 23:11 vddc_power

-rw-r--r--.
1 root root 0 5月 6 23:11 vddphy_power

注:如果PCIe模式使用SC5P,则mcu_version会创建在/proc/bmsophon/card/板卡目录下。

如果使用其他类型板卡,则mcu_version会创建在/proc/bmsophon/card/bmsophon/设备目录下。

5.2.3. 各项参数的含义和使用方法

5.2.3.1. PCIe模式各个设备的详细信息

  • card_num

读写属性:只读;

含义:系统板卡数量

  • chip_num

读写属性:只读;

含义:系统设备数量

  • chip_num_on_card

读写属性:只读;

含义:对应板卡上设备数量

  • board_power

读写属性:只读;

含义:板级功耗

  • board_temp

读写属性:只读;

含义:板级温度

  • chipid

读写属性:只读;

含义:芯片id(0x1684x/0x1684/0x1682)

  • chip_temp

读写属性:只读

含义:芯片温度

  • dbdf

读写属性:只读

含义:domain:bus:dev.function

  • dynfreq

读写属性:读写

含义:使能或者禁止动态tpu调频功能;0/1有效,其他值无效

  • ecc

读写属性:只读

含义:打开或者关闭ECC功能

  • maxboardp

读写属性:只读

含义:最大板级功耗

  • mode

读写属性:只读

含义:工作模式,PCIe/SOC

  • pcie_cap_speed

读写属性:只读

含义:设备支持的PCIe最大速度

  • pcie_cap_width

读写属性:只读

含义:设备支持的PCIe接口最大lane的宽度

  • pcie_link_speed

读写属性:只读

含义:设备的PCIe接口速度

  • pcie_link_width

读写属性:只读

含义:设备的PCIe接口lane宽度

  • pcie_region

读写属性:只读

含义:设备PCIe bar的大小

  • tpuid

读写属性:只读

含义:tpu的ID(0/1/2/3……)

  • tpu_maxclk

读写属性:只读

含义:tpu的最大工作频率

  • tpu_minclk

读写属性:只读

含义:tpu的最小工作频率

  • tpu_freq

读写属性:读写

含义:tpu的工作频率,可通过写入参数来改变频率,写入前应向dynfreq写入0来关闭动态tpu调频,示例如下:

sudo -s
echo 0 > /proc/bmsophon/card0/bmsophon0/dynfreq
echo 750 > /proc/bmsophon/card0/bmsophon0/tpu_freq
  • tpu_power

读写属性:只读

含义:tpu的瞬时功率

  • firmware_info

读写属性:只读

含义:firmware的版本信息,包括commit id和编译时间

  • sn

读写属性:只读

含义:板卡产品编号

  • boot_loader_version

读写属性:只读

含义:spi flash 中的bootloader 版本号

  • board_type

读写属性:只读

含义:板卡类型

  • driver_version

读写属性:只读

含义:驱动的版本号

  • board_version

读写属性:只读

含义:板卡硬件的版本号

  • mcu_version

读写属性:只读

含义:mcu软件版本号

  • versions

读写属性:只读

含义:板卡软硬件版本的集合

  • cdma_in_time

读写属性:只读

含义:cdma 从host搬数据到板卡消耗的总时间

  • cdma_in_counter

读写属性:只读

含义:cdma 从host搬数据到板卡的总次数

  • cdma_out_time

读写属性:只读

含义:cdma 从板卡搬数据到host消耗的总时间

  • cdma_out_counter

读写属性:只读

含义:cdma 从板卡搬数据到host的总次数

  • tpu_process_time

读写属性:只读

含义:tpu 处理过程中消耗的时间

  • completed_api_counter

读写属性:只读

含义:已完成api的次数

  • send_api_counter

读写属性:只读

含义:已发送api的次数

  • tpu_volt

读写属性:读写

含义:tpu的电压,可通过写入参数来改变电压

  • tpu_cur

读写属性:只读

含义:tpu 电流

  • fan_speed

读写属性:只读

含义:duty 风扇调速pwm 占空比,fan_speed 风扇实际转速

  • media

读写属性:只读

total_mem_size :vpu和jpu使用内存总大小

used_mem_size :vpu和jpu正在使用的内存

free_mem_size :空闲内存

id :vpu core的编号

link_num :编/解码路数

  • a53_enable

读写属性:只读

含义:a53使能状态

  • arm9_cache

读写属性:只读

含义:arm9的cache的使能状态

  • bmcpu_status

读写属性:只读

含义:bmcpu的状态

  • bom_version

读写属性:只读

含义:bom的版本号

  • boot_mode

读写属性:只读

含义:启动方式

  • clk

读写属性:只读

含义:各个模块的时钟

  • ddr_capacity

读写属性:只读

含义:ddr的容量

  • dumpreg

读写属性:读写

含义:转存寄存器,输入1转存到tpu寄存器,输入2转存到gdma寄存器

  • heap

读写属性:只读

含义:显示各个heap的大小

  • location

读写属性:只读

含义:显示当前位于哪个设备之上

  • pcb_version

读写属性:只读

含义:pcb的版本号

  • pmu_infos

读写属性:只读

含义:更详细的电流电压信息

  • status

读写属性:只读

含义:板卡状态

  • vddc_power

读写属性:只读

含义:vddc功率

  • vddphy_power

读写属性:只读

含义:vddphy功率

5.2.3.2. SOC模式各个设备的详细信息

SOC模式只有JPU和VPU支持proc接口,对应的proc节点为/proc/jpuinfo和/proc/vpuinfo。

  • jpuinfo

读写属性:只读

JPU loadbalance : 记录JPU0-JPU1(1684x),JPU0-JPU3(1684)编码/解码次数,JPU*为芯片内部的JPEG编解码器, 取值范围:0~ 2147483647

  • vpuinfo

读写属性:只读

id: vpu core的编号,取值范围: 0~2(1684x), 0-4(1684)

link_num: 编/解码路数,取值范围:0~32