summaryrefslogtreecommitdiffstats
path: root/monitor/fan.cpp
diff options
context:
space:
mode:
authorMatthew Barth <msbarth@us.ibm.com>2018-01-26 12:53:15 -0600
committerMatthew Barth <msbarth@linux.vnet.ibm.com>2018-01-30 15:29:43 +0000
commit0a9fe160d600ece0c5797741042d0e6f975ab101 (patch)
tree37e1948ae086507bb06db636487151e20c87cac5 /monitor/fan.cpp
parent9a5b6994c745480a78ef658148cfd96dd3e12bdb (diff)
downloadphosphor-fan-presence-0a9fe160d600ece0c5797741042d0e6f975ab101.tar.gz
phosphor-fan-presence-0a9fe160d600ece0c5797741042d0e6f975ab101.zip
Set tach sensor to functional on start
With the addition of a functional state for each fan rotor tach sensor, these should be set to functional on each power on. This is done during fan monitor init mode when no monitor is done and then again once monitoring mode begins. Change-Id: I3c73c1be5f912c7cee8499f47cc799ac3c20983b Signed-off-by: Matthew Barth <msbarth@us.ibm.com>
Diffstat (limited to 'monitor/fan.cpp')
-rw-r--r--monitor/fan.cpp48
1 files changed, 25 insertions, 23 deletions
diff --git a/monitor/fan.cpp b/monitor/fan.cpp
index 9d2593f..b1aa233 100644
--- a/monitor/fan.cpp
+++ b/monitor/fan.cpp
@@ -40,34 +40,36 @@ Fan::Fan(Mode mode,
_numSensorFailsForNonFunc(std::get<numSensorFailsForNonfuncField>(def)),
_trustManager(trust)
{
+ // Setup tach sensors for monitoring
+ auto& sensors = std::get<sensorListField>(def);
+ for (auto& s : sensors)
+ {
+ try
+ {
+ _sensors.emplace_back(
+ std::make_unique<TachSensor>(
+ mode,
+ bus,
+ *this,
+ std::get<sensorNameField>(s),
+ std::get<hasTargetField>(s),
+ std::get<timeoutField>(def),
+ events));
+
+ _trustManager->registerSensor(_sensors.back());
+ }
+ catch (InvalidSensorError& e)
+ {
+
+ }
+ }
+
//Start from a known state of functional
updateInventory(true);
- // Setup tach sensors for monitoring when in monitor mode
+ // Check current tach state when entering monitor mode
if (mode != Mode::init)
{
- auto& sensors = std::get<sensorListField>(def);
- for (auto& s : sensors)
- {
- try
- {
- _sensors.emplace_back(
- std::make_unique<TachSensor>(
- bus,
- *this,
- std::get<sensorNameField>(s),
- std::get<hasTargetField>(s),
- std::get<timeoutField>(def),
- events));
-
- _trustManager->registerSensor(_sensors.back());
- }
- catch (InvalidSensorError& e)
- {
-
- }
- }
-
//The TachSensors will now have already read the input
//and target values, so check them.
tachChanged();
OpenPOWER on IntegriCloud