Add a helper function to capture command metadata
Due to openbmc/openbmc#2364, certain command response files may be
missing. Add a helper function to call the PMBus::exists() function to
skip trying to read in metadata for missing files.
Change-Id: I101c5ccebe76dd29fb07369fd082072ce94f021b
Signed-off-by: Brandon Wyman <bjwyman@gmail.com>
diff --git a/power-supply/power_supply.cpp b/power-supply/power_supply.cpp
index 0bdbbfa..670065b 100644
--- a/power-supply/power_supply.cpp
+++ b/power-supply/power_supply.cpp
@@ -81,6 +81,23 @@
updatePowerState();
}
+void PowerSupply::captureCmd(util::NamesValues& nv, const std::string& cmd,
+ witherspoon::pmbus::Type type)
+{
+ if (pmbusIntf.exists(cmd, type))
+ {
+ try
+ {
+ auto val = pmbusIntf.read(cmd, type);
+ nv.add(cmd, val);
+ }
+ catch (std::exception& e)
+ {
+ log<level::INFO>("Unable to capture metadata", entry("CMD=%s",
+ cmd));
+ }
+ }
+}
void PowerSupply::analyze()
{
@@ -281,11 +298,9 @@
{
inputFault = true;
- statusInput = pmbusIntf.read(STATUS_INPUT, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("STATUS_INPUT", statusInput);
+ captureCmd(nv, STATUS_INPUT, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyInputFault;
@@ -313,28 +328,18 @@
{
using namespace witherspoon::pmbus;
- std::uint8_t statusInput = 0;
- std::uint8_t statusVout = 0;
- std::uint8_t statusIout = 0;
- std::uint8_t statusMFR = 0;
-
// Check PG# and UNIT_IS_OFF
if (((statusWord & status_word::POWER_GOOD_NEGATED) ||
(statusWord & status_word::UNIT_IS_OFF)) &&
!powerOnFault)
{
- statusInput = pmbusIntf.read(STATUS_INPUT, Type::Debug);
- auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
- statusVout = pmbusIntf.read(status0Vout, Type::Debug);
- statusIout = pmbusIntf.read(STATUS_IOUT, Type::Debug);
- statusMFR = pmbusIntf.read(STATUS_MFR, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("STATUS_INPUT", statusInput);
- nv.add("STATUS_VOUT", statusVout);
- nv.add("STATUS_IOUT", statusIout);
- nv.add("MFR_SPECIFIC", statusMFR);
+ captureCmd(nv, STATUS_INPUT, Type::Debug);
+ auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
+ captureCmd(nv, status0Vout, Type::Debug);
+ captureCmd(nv, STATUS_IOUT, Type::Debug);
+ captureCmd(nv, STATUS_MFR, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyShouldBeOn;
@@ -353,27 +358,17 @@
{
using namespace witherspoon::pmbus;
- std::uint8_t statusInput = 0;
- std::uint8_t statusVout = 0;
- std::uint8_t statusIout = 0;
- std::uint8_t statusMFR = 0;
-
// Check for an output overcurrent fault.
if ((statusWord & status_word::IOUT_OC_FAULT) &&
!outputOCFault)
{
- statusInput = pmbusIntf.read(STATUS_INPUT, Type::Debug);
- auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
- statusVout = pmbusIntf.read(status0Vout, Type::Debug);
- statusIout = pmbusIntf.read(STATUS_IOUT, Type::Debug);
- statusMFR = pmbusIntf.read(STATUS_MFR, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("STATUS_INPUT", statusInput);
- nv.add("STATUS_VOUT", statusVout);
- nv.add("STATUS_IOUT", statusIout);
- nv.add("MFR_SPECIFIC", statusMFR);
+ captureCmd(nv, STATUS_INPUT, Type::Debug);
+ auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
+ captureCmd(nv, status0Vout, Type::Debug);
+ captureCmd(nv, STATUS_IOUT, Type::Debug);
+ captureCmd(nv, STATUS_MFR, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyOutputOvercurrent;
@@ -391,27 +386,17 @@
{
using namespace witherspoon::pmbus;
- std::uint8_t statusInput = 0;
- std::uint8_t statusVout = 0;
- std::uint8_t statusIout = 0;
- std::uint8_t statusMFR = 0;
-
// Check for an output overvoltage fault.
if ((statusWord & status_word::VOUT_OV_FAULT) &&
!outputOVFault)
{
- statusInput = pmbusIntf.read(STATUS_INPUT, Type::Debug);
- auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
- statusVout = pmbusIntf.read(status0Vout, Type::Debug);
- statusIout = pmbusIntf.read(STATUS_IOUT, Type::Debug);
- statusMFR = pmbusIntf.read(STATUS_MFR, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("STATUS_INPUT", statusInput);
- nv.add("STATUS_VOUT", statusVout);
- nv.add("STATUS_IOUT", statusIout);
- nv.add("MFR_SPECIFIC", statusMFR);
+ captureCmd(nv, STATUS_INPUT, Type::Debug);
+ auto status0Vout = pmbusIntf.insertPageNum(STATUS_VOUT, 0);
+ captureCmd(nv, status0Vout, Type::Debug);
+ captureCmd(nv, STATUS_IOUT, Type::Debug);
+ captureCmd(nv, STATUS_MFR, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyOutputOvervoltage;
@@ -429,23 +414,15 @@
{
using namespace witherspoon::pmbus;
- std::uint8_t statusMFR = 0;
- std::uint8_t statusTemperature = 0;
- std::uint8_t statusFans12 = 0;
-
// Check for a fan fault or warning condition
if ((statusWord & status_word::FAN_FAULT) &&
!fanFault)
{
- statusMFR = pmbusIntf.read(STATUS_MFR, Type::Debug);
- statusTemperature = pmbusIntf.read(STATUS_TEMPERATURE, Type::Debug);
- statusFans12 = pmbusIntf.read(STATUS_FANS_1_2, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("MFR_SPECIFIC", statusMFR);
- nv.add("STATUS_TEMPERATURE", statusTemperature);
- nv.add("STATUS_FANS_1_2", statusFans12);
+ captureCmd(nv, STATUS_MFR, Type::Debug);
+ captureCmd(nv, STATUS_TEMPERATURE, Type::Debug);
+ captureCmd(nv, STATUS_FANS_1_2, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyFanFault;
@@ -481,20 +458,12 @@
// out less current.
// Capture command responses with potentially relevant information,
// and call out the power supply reporting the condition.
- std::uint8_t statusMFR = 0;
- std::uint8_t statusIout = 0;
- std::uint8_t statusFans12 = 0;
-
- statusMFR = pmbusIntf.read(STATUS_MFR, Type::Debug);
- statusIout = pmbusIntf.read(STATUS_IOUT, Type::Debug);
- statusFans12 = pmbusIntf.read(STATUS_FANS_1_2, Type::Debug);
-
util::NamesValues nv;
nv.add("STATUS_WORD", statusWord);
- nv.add("MFR_SPECIFIC", statusMFR);
- nv.add("STATUS_IOUT", statusIout);
+ captureCmd(nv, STATUS_MFR, Type::Debug);
+ captureCmd(nv, STATUS_IOUT, Type::Debug);
nv.add("STATUS_TEMPERATURE", statusTemperature);
- nv.add("STATUS_FANS_1_2", statusFans12);
+ captureCmd(nv, STATUS_FANS_1_2, Type::Debug);
using metadata = xyz::openbmc_project::Power::Fault::
PowerSupplyTemperatureFault;
diff --git a/power-supply/power_supply.hpp b/power-supply/power_supply.hpp
index 379a937..474ad8d 100644
--- a/power-supply/power_supply.hpp
+++ b/power-supply/power_supply.hpp
@@ -3,6 +3,7 @@
#include "device.hpp"
#include "pmbus.hpp"
#include "timer.hpp"
+#include "names_values.hpp"
namespace witherspoon
{
@@ -201,6 +202,16 @@
void powerStateChanged(sdbusplus::message::message& msg);
/**
+ * @brief Wrapper for PMBus::read() and adding metadata
+ *
+ * @param[out] nv - NamesValues instance to store cmd string and value
+ * @param[in] cmd - String for the command to read data from.
+ * @param[in] type - The type of file to read the command from.
+ */
+ void captureCmd(util::NamesValues& nv, const std::string& cmd,
+ witherspoon::pmbus::Type type);
+
+ /**
* @brief Checks for input voltage faults and logs error if needed.
*
* Check for voltage input under voltage fault (VIN_UV_FAULT) and/or