Overview
openbmc散热控制实现主要是在phosphor-pid-control
中完成,它使用简单的配置文件来控制系统组件内部温度。
BMC将运行一个守护程序,通过预定义的区域控制风扇。这个应用程序将使用 thermal control,并基于从本地传感器获取到的信息和ipmi oem命令,使每个定义的区域温度保持在一个范围内。
Configuring - How to configure phosphor-pid-control?
散热控制有两种方式来配置phosphor-pid-control
1、使用entity-manager解析出来的数据作为输入,该方式为默认方式,不支持动态修改参数(默认运行方式)
2、phosphor-pid-control
支持重新加载配置文件,可以在串口下新增配置文件,重启服务进行解析(调试使用)
D-Bus Configuration
如果配置文件不存在,会使用dbus作为数据获取来源。 当使用entity-manager
提供的pid
,pid.Zone
和Stepwise
时,配置的key值与json文件方式是不同的,但是最终他们可以产生相同的作用。
entity-manager
解析的配置是不可修改的,作为默认的配置文件供各模块使用。
JSON Configuration
phosphor-pid-control
支持以入参形式修改相关配置加载方式。
默认的配置文件路径为/usr/share/swampd/config.json
,它可以被--conf
/-c
参数进行修改。
配置文件中应该有两个关键字段,sensors
和zones
,sensors
是传感器的集合,zones
是区域的集合。
Sensors
```
"sensors" : [
{
"name": "fan1",
"type": "fan",
"readPath": "/xyz/openbmc_project/sensors/fan_tach/fan1",
"writePath": "/sys/devices/platform/ahb/ahb:apb/1e786000.pwm-tacho-controller/hwmon/**/pwm1",
"min": 0,
"max": 255,
"ignoreDbusMinMax": true
},
{
"name": "fan2",
"type": "fan",
"readPath": "/xyz/openbmc_project/sensors/fan_tach/fan2",
"writePath": "/sys/devices/platform/ahb/ahb:apb/1e786000.pwm-tacho-controller/hwmon/**/pwm2",
"min": 0,
"max": 255,
"timeout": 4,
},
...
```
每个传感器下配置如下
name
:传感器名称,用于和传感器配置匹配。
type
:传感器类型,目前支持三种类型:fan
、temp
、margin
readPath
(optional):传感器数值的读取路径
writePath
(optional):传感器数值的写入路径
min
/max
(optional):当max
不为0时,写入的数值应为最小值和最大值之间的最大值。
timeout
(optional)