monitor: Use only init mode when using JSON
Fan monitor is currently split into 2 modes - 'init' which is used
right after a power on, and 'monitor', which is used later after the
fans-ready target is started. Normally, the 'init' mode just sets the
fans to functional and then exits, and the real monitoring work is done
in the 'monitor' mode.
In the future this application will need to be able to check for fan
problems as soon as it starts up after power on so that it can handle
shutting down due to missing fans. To prepare for this, move all
functionality into the init mode, and just exit immediately when called
to run in the monitor mode. Only do this when compiled to use the JSON
configuration, as this is new and I don't want to change how the
existing YAML setups work.
This also creates a new 'monitor_start_delay' entry in the JSON to say
how long to wait after startup before actually doing any sensor
monitoring, which then gives the same behavior as how the monitor mode
would delay by waiting for the fan control ready target, which itself is
started by fan control --init after a hardcoded delay. This field is
optional to preserve backwards compatibility and defaults to 0s.
Signed-off-by: Matt Spinler <spinler@us.ibm.com>
Change-Id: I623a233f50233e734f50cd9e80139c60467518d8
diff --git a/monitor/json_parser.cpp b/monitor/json_parser.cpp
index 227530f..51df226 100644
--- a/monitor/json_parser.cpp
+++ b/monitor/json_parser.cpp
@@ -191,6 +191,13 @@
funcDelay = fan["functional_delay"].get<size_t>();
}
+ // Monitor start delay is optional and defaults to 0
+ size_t monitorDelay = 0;
+ if (fan.contains("monitor_start_delay"))
+ {
+ monitorDelay = fan["monitor_start_delay"].get<size_t>();
+ }
+
// Handle optional conditions
auto cond = std::optional<Condition>();
if (fan.contains("condition"))
@@ -221,13 +228,12 @@
entry("JSON_DUMP=%s", fan["condition"].dump().c_str()));
}
}
-
fanDefs.emplace_back(
std::tuple(fan["inventory"].get<std::string>(), funcDelay,
fan["allowed_out_of_range_time"].get<size_t>(),
fan["deviation"].get<size_t>(),
fan["num_sensors_nonfunc_for_fan_nonfunc"].get<size_t>(),
- sensorDefs, cond));
+ monitorDelay, sensorDefs, cond));
}
return fanDefs;