The phosphor-fan-presence repository provides a set of thermal related applications that control and monitor the cooling of a system using fans. Each application independently controls or monitors an area related to the thermal status of a system that uses fans as its primary cooling mechanism. Since each application independent in its functionality, they can individually be included in a BMC image at configure time to provide only the functionality needed by a user's machine.
By default, build time YAML configuration file(s) are used for each application. The use of YAML configuration file(s) has been deprecated in favor of using runtime JSON configuration file(s). Support for the use of YAML based configuration files will be removed once all applications completely support getting their configuration from JSON file(s) at runtime.
The following applications are built by default:
-Dcontrol-service
flag to disabled at configure time:meson build -Dcontrol-service=disabled
-Dpresence-service
flag to disabled at configure time:meson build -Dpresence-service=disabled
-Dmonitor-service
flag to disabled at configure time:meson build -Dmonitor-service=disabled
-Dcooling-type-service
flag to enabled at configure time:meson build -cooling-type-service=enabled
The following applications must be enabled at configure time to be built:
--sensor-monitor-service
flag to enabled configure time:meson build -Dsensor-monitor-service=enabled
To clean the repository run ./bootstrap.sh clean
.
The location of the YAML configuration file(s) are provided at configure time to each application thru environment variables. The default YAML configuration file(s) used are the examples found within each application's example directory. See each application below (Contents) for more information on how to set their specific configure time options, including the location of the YAML configuration file(s).
To simply build this package to use YAML, without changing the configurations of each application for a specific system, do the following steps:
1. ./bootstrap.sh 2. ./configure ${CONFIGURE_FLAGS} 3. make
See each application below (Contents) for more information on how to set their specific configure time options and details on how to configure each using JSON.
To build this package to use JSON based runtime configuration for all applications, follow these steps and provide the --enable-json
flag at configure time:
1. ./bootstrap.sh 2. ./configure ${CONFIGURE_FLAGS} --enable-json 3. make
Note: Features/Restrictions of applications in this package that are only supported using the JSON based configuration are listed below:
full_speed
. If you require more than just setting fans to the configured full_speed
, it is recommended to continue using YAML based configurations by providing the --disable-json-control
flag at configure time.Controls the fans based on a set of events that are configured using a group of D-Bus objects and one-or-more triggers that run a configured set of actions. These events are meant to be configured to handle all aspects of controlling the fans within a system. Fans are added to zones that then have events configured against the zone to control the fans based on the state of any sized group of D-Bus objects.
CONTROL_BUSNAME
- Application's D-Bus busname to ownCONTROL_OBJPATH
- Application's root D-Bus object pathCONTROL_PERSIST_ROOT_PATH
- Base location to persist zone property states on the BMCFAN_DEF_YAML_FILE
- Build time fan configuration fileFAN_ZONE_YAML_FILE
- Build time zone configuration fileZONE_EVENTS_YAML_FILE
- Build time events configuration fileZONE_CONDITIONS_YAML_FILE
Build time zone conditions configuration fileMonitors the presence state of fans using GPIOs, nonzero tach feedbacks, or a combination of both. This updates a configured location of a fan D-Bus object's Present
property according to the state of the methods used to detect the fan's presence.
NUM_PRESENCE_LOG_ENTRIES
- Maximum number of entries in the message logPRESENCE_CONFIG
- Location of the config fileExample: example.yaml
Monitors the functional state of fans by comparing the fan feedback speed against the current target, applying any configured adjustments to the target due to fan hardware properties. In addition to updating the configured location of a fan D-Bus object's Functional
property in inventory, actions can be configured* to be taken based on the state of fans, i.e.) creating event logs or powering off the system.
Another feature that can be configured is the ability to cancel the monitoring of a set of fans that may be necessary to workaround designs of the fan hardware and/or controller used.
*Actions to be taken based on the state of fans is only available using a JSON based configuration
NUM_MONITOR_LOG_ENTRIES
- Maximum number of entries in the message logTHERMAL_ALERT_BUSNAME
- Application's D-Bus busname to ownTHERMAL_ALERT_OBJPATH
- Application's root D-Bus object pathFAN_MONITOR_YAML_FILE
- Location of the config fileExample: monitor.yaml
Sets the AirCooled
and WaterCooled
property on the xyz.openbmc_project.Inventory.Decorator.CoolingType
interface in inventory based on a given GPIO. No configuration files are used with this application as it is command line driven.
Takes actions, such as powering off the system, based on sensor thresholds and values.
SENSOR_MONITOR_PERSIST_ROOT_PATH
- Base location to persist sensor monitoring dataSHUTDOWN_ALARM_HARD_SHUTDOWN_DELAY_MS
- Milliseconds to delay the alarm hard shutdownSHUTDOWN_ALARM_SOFT_SHUTDOWN_DELAY_MS
- Milliseconds to delay the alarm soft shutdown