ensure power status is always correct
There's a slight bug here in that anytime determineStatusOfPower() is
called, the PowerStatus was set to Good for a period of time. This can
cause confusion on clients monitoring the property. Instead of
defaulting it to good, set it after the true status is known.
Signed-off-by: Andrew Geissler <geissonator@yahoo.com>
Change-Id: If48eb5bd1c2bd94d51d12aff54a186aba295b179
diff --git a/chassis_state_manager.cpp b/chassis_state_manager.cpp
index d526358..3989bca 100644
--- a/chassis_state_manager.cpp
+++ b/chassis_state_manager.cpp
@@ -203,19 +203,21 @@
void Chassis::determineStatusOfPower()
{
- // Default PowerStatus to good
- server::Chassis::currentPowerStatus(PowerStatus::Good);
-
- determineStatusOfUPSPower();
- if (server::Chassis::currentPowerStatus() != PowerStatus::Good)
+ bool powerGood = determineStatusOfUPSPower();
+ if (!powerGood)
{
return;
}
- determineStatusOfPSUPower();
+ powerGood = determineStatusOfPSUPower();
+ if (powerGood)
+ {
+ // All checks passed, set power status to good
+ server::Chassis::currentPowerStatus(PowerStatus::Good);
+ }
}
-void Chassis::determineStatusOfUPSPower()
+bool Chassis::determineStatusOfUPSPower()
{
// Find all implementations of the UPower interface
auto mapper = bus.new_method_call(MAPPER_BUSNAME, MAPPER_PATH,
@@ -288,7 +290,7 @@
std::get<uint>(properties["State"]));
server::Chassis::currentPowerStatus(
PowerStatus::UninterruptiblePowerSupply);
- return;
+ return false;
}
if (std::get<uint>(properties["BatteryLevel"]) ==
@@ -297,7 +299,7 @@
info("UPS Battery Level is Full");
// Only one UPS per system, we've found it and it's all
// good so exit function
- return;
+ return true;
}
else
{
@@ -306,7 +308,7 @@
std::get<uint>(properties["BatteryLevel"]));
server::Chassis::currentPowerStatus(
PowerStatus::UninterruptiblePowerSupply);
- return;
+ return false;
}
}
catch (const sdbusplus::exception::exception& e)
@@ -318,10 +320,10 @@
}
}
}
- return;
+ return true;
}
-void Chassis::determineStatusOfPSUPower()
+bool Chassis::determineStatusOfPSUPower()
{
// Find all implementations of the PowerSystemInputs interface
auto mapper = bus.new_method_call(MAPPER_BUSNAME, MAPPER_PATH,
@@ -372,7 +374,7 @@
{
info("Power System Inputs status is in Fault state");
server::Chassis::currentPowerStatus(PowerStatus::BrownOut);
- return;
+ return false;
}
}
catch (const sdbusplus::exception::exception& e)
@@ -385,7 +387,7 @@
}
}
}
- return;
+ return true;
}
void Chassis::uPowerChangeEvent(sdbusplus::message::message& msg)
diff --git a/chassis_state_manager.hpp b/chassis_state_manager.hpp
index e82a4cd..82ad2d1 100644
--- a/chassis_state_manager.hpp
+++ b/chassis_state_manager.hpp
@@ -100,13 +100,17 @@
/** @brief Determine status of power provided by an Uninterruptible Power
* Supply into the system
+ *
+ * @return True if UPS power is good, false otherwise
*/
- void determineStatusOfUPSPower();
+ bool determineStatusOfUPSPower();
/** @brief Determine status of power provided by the power supply units into
* the system
+ *
+ * @return True if PSU power is good, false otherwise
*/
- void determineStatusOfPSUPower();
+ bool determineStatusOfPSUPower();
/**
* @brief subscribe to the systemd signals