| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 1 | #pragma once | 
|  | 2 |  | 
| Brandon Wyman | 8d19577 | 2020-01-27 15:03:51 -0600 | [diff] [blame] | 3 | #include "pmbus.hpp" | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 4 | #include "types.hpp" | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 5 | #include "utility.hpp" | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 6 |  | 
|  | 7 | #include <sdbusplus/bus/match.hpp> | 
|  | 8 |  | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 9 | namespace phosphor::power::psu | 
|  | 10 | { | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 11 |  | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 12 | /** | 
|  | 13 | * @class PowerSupply | 
|  | 14 | * Represents a PMBus power supply device. | 
|  | 15 | */ | 
|  | 16 | class PowerSupply | 
|  | 17 | { | 
|  | 18 | public: | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 19 | PowerSupply() = delete; | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 20 | PowerSupply(const PowerSupply&) = delete; | 
|  | 21 | PowerSupply(PowerSupply&&) = delete; | 
|  | 22 | PowerSupply& operator=(const PowerSupply&) = delete; | 
|  | 23 | PowerSupply& operator=(PowerSupply&&) = delete; | 
|  | 24 | ~PowerSupply() = default; | 
|  | 25 |  | 
|  | 26 | /** | 
| Brandon Wyman | c63941c | 2020-01-27 16:49:33 -0600 | [diff] [blame] | 27 | * @param[in] invpath - String for inventory path to use | 
|  | 28 | * @param[in] i2cbus - The bus number this power supply is on | 
|  | 29 | * @param[in] i2caddr - The 16-bit I2C address of the power supply | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 30 | */ | 
| Brandon Wyman | c63941c | 2020-01-27 16:49:33 -0600 | [diff] [blame] | 31 | PowerSupply(sdbusplus::bus::bus& bus, const std::string& invpath, | 
|  | 32 | std::uint8_t i2cbus, const std::string& i2caddr) : | 
|  | 33 | bus(bus), | 
| Brandon Wyman | 8d19577 | 2020-01-27 15:03:51 -0600 | [diff] [blame] | 34 | inventoryPath(invpath), | 
|  | 35 | pmbusIntf(phosphor::pmbus::createPMBus(i2cbus, i2caddr)) | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 36 | { | 
|  | 37 | // Setup the functions to call when the D-Bus inventory path for the | 
|  | 38 | // Present property changes. | 
|  | 39 | presentMatch = std::make_unique<sdbusplus::bus::match_t>( | 
|  | 40 | bus, | 
|  | 41 | sdbusplus::bus::match::rules::propertiesChanged(inventoryPath, | 
|  | 42 | INVENTORY_IFACE), | 
|  | 43 | [this](auto& msg) { this->inventoryChanged(msg); }); | 
|  | 44 | presentAddedMatch = std::make_unique<sdbusplus::bus::match_t>( | 
|  | 45 | bus, | 
|  | 46 | sdbusplus::bus::match::rules::interfacesAdded() + | 
|  | 47 | sdbusplus::bus::match::rules::path_namespace(inventoryPath), | 
|  | 48 | [this](auto& msg) { this->inventoryChanged(msg); }); | 
|  | 49 | // Get the current state of the Present property. | 
|  | 50 | updatePresence(); | 
|  | 51 | } | 
|  | 52 |  | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 53 | phosphor::pmbus::PMBusBase& getPMBus() | 
|  | 54 | { | 
|  | 55 | return *pmbusIntf; | 
|  | 56 | } | 
|  | 57 |  | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 58 | /** | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 59 | * Power supply specific function to analyze for faults/errors. | 
|  | 60 | * | 
|  | 61 | * Various PMBus status bits will be checked for fault conditions. | 
|  | 62 | * If a certain fault bits are on, the appropriate error will be | 
|  | 63 | * committed. | 
|  | 64 | */ | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 65 | void analyze(); | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 66 |  | 
|  | 67 | /** | 
|  | 68 | * Write PMBus CLEAR_FAULTS | 
|  | 69 | * | 
|  | 70 | * This function will be called in various situations in order to clear | 
|  | 71 | * any fault status bits that may have been set, in order to start over | 
|  | 72 | * with a clean state. Presence changes and power state changes will | 
|  | 73 | * want to clear any faults logged. | 
|  | 74 | */ | 
|  | 75 | void clearFaults() | 
|  | 76 | { | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 77 | faultFound = false; | 
|  | 78 | inputFault = false; | 
|  | 79 | mfrFault = false; | 
|  | 80 | vinUVFault = false; | 
| Brandon Wyman | 4e01665 | 2020-04-28 19:31:17 -0500 | [diff] [blame] | 81 |  | 
|  | 82 | // The PMBus device driver does not allow for writing CLEAR_FAULTS | 
|  | 83 | // directly. However, the pmbus hwmon device driver code will send a | 
|  | 84 | // CLEAR_FAULTS after reading from any of the hwmon "files" in sysfs, so | 
|  | 85 | // reading in1_crit should result in clearing the fault bits in | 
|  | 86 | // STATUS_BYTE/STATUS_WORD. | 
|  | 87 | // I do not care what the return value is. | 
|  | 88 | static_cast<void>( | 
|  | 89 | pmbusIntf->read("in1_crit", phosphor::pmbus::Type::Hwmon)); | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 90 | } | 
|  | 91 |  | 
|  | 92 | /** | 
|  | 93 | * @brief Adds properties to the inventory. | 
|  | 94 | * | 
|  | 95 | * Reads the values from the device and writes them to the | 
|  | 96 | * associated power supply D-Bus inventory object. | 
|  | 97 | * | 
|  | 98 | * This needs to be done on startup, and each time the presence | 
|  | 99 | * state changes. | 
|  | 100 | * | 
|  | 101 | * Properties added: | 
|  | 102 | * - Serial Number | 
|  | 103 | * - Part Number | 
|  | 104 | * - CCIN (Customer Card Identification Number) - added as the Model | 
|  | 105 | * - Firmware version | 
|  | 106 | */ | 
|  | 107 | void updateInventory() | 
|  | 108 | { | 
|  | 109 | } | 
|  | 110 |  | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 111 | /** | 
|  | 112 | * @brief Accessor function to indicate present status | 
|  | 113 | */ | 
|  | 114 | bool isPresent() const | 
|  | 115 | { | 
|  | 116 | return present; | 
|  | 117 | } | 
|  | 118 |  | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 119 | /** | 
|  | 120 | * @brief Returns true if a fault was found. | 
|  | 121 | */ | 
|  | 122 | bool isFaulted() const | 
|  | 123 | { | 
|  | 124 | return faultFound; | 
|  | 125 | } | 
|  | 126 |  | 
|  | 127 | /** | 
|  | 128 | * @brief Returns true if INPUT fault occurred. | 
|  | 129 | */ | 
|  | 130 | bool hasInputFault() const | 
|  | 131 | { | 
|  | 132 | return inputFault; | 
|  | 133 | } | 
|  | 134 |  | 
|  | 135 | /** | 
|  | 136 | * @brief Returns true if MFRSPECIFIC occurred. | 
|  | 137 | */ | 
|  | 138 | bool hasMFRFault() const | 
|  | 139 | { | 
|  | 140 | return mfrFault; | 
|  | 141 | } | 
|  | 142 |  | 
|  | 143 | /** | 
|  | 144 | * @brief Returns true if VIN_UV_FAULT occurred. | 
|  | 145 | */ | 
|  | 146 | bool hasVINUVFault() const | 
|  | 147 | { | 
|  | 148 | return vinUVFault; | 
|  | 149 | } | 
|  | 150 |  | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 151 | private: | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 152 | /** @brief systemd bus member */ | 
|  | 153 | sdbusplus::bus::bus& bus; | 
|  | 154 |  | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 155 | /** @brief True if a fault has already been found and not cleared */ | 
|  | 156 | bool faultFound = false; | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 157 |  | 
| Brandon Wyman | 3f1242f | 2020-01-28 13:11:25 -0600 | [diff] [blame] | 158 | /** @brief True if bit 5 of STATUS_WORD high byte is on. */ | 
|  | 159 | bool inputFault = false; | 
|  | 160 |  | 
|  | 161 | /** @brief True if bit 4 of STATUS_WORD high byte is on. */ | 
|  | 162 | bool mfrFault = false; | 
|  | 163 |  | 
|  | 164 | /** @brief True if bit 3 of STATUS_WORD low byte is on. */ | 
|  | 165 | bool vinUVFault = false; | 
|  | 166 |  | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 167 | /** | 
|  | 168 | * @brief D-Bus path to use for this power supply's inventory status. | 
|  | 169 | **/ | 
|  | 170 | std::string inventoryPath; | 
|  | 171 |  | 
|  | 172 | /** @brief True if the power supply is present. */ | 
|  | 173 | bool present = false; | 
|  | 174 |  | 
|  | 175 | /** @brief D-Bus match variable used to subscribe to Present property | 
|  | 176 | * changes. | 
|  | 177 | **/ | 
|  | 178 | std::unique_ptr<sdbusplus::bus::match_t> presentMatch; | 
|  | 179 |  | 
|  | 180 | /** @brief D-Bus match variable used to subscribe for Present property | 
|  | 181 | * interface added. | 
|  | 182 | */ | 
|  | 183 | std::unique_ptr<sdbusplus::bus::match_t> presentAddedMatch; | 
|  | 184 |  | 
|  | 185 | /** | 
| Brandon Wyman | 8d19577 | 2020-01-27 15:03:51 -0600 | [diff] [blame] | 186 | * @brief Pointer to the PMBus interface | 
|  | 187 | * | 
|  | 188 | * Used to read or write to/from PMBus power supply devices. | 
|  | 189 | */ | 
|  | 190 | std::unique_ptr<phosphor::pmbus::PMBusBase> pmbusIntf; | 
|  | 191 |  | 
|  | 192 | /** | 
| Brandon Wyman | aed1f75 | 2019-11-25 18:10:52 -0600 | [diff] [blame] | 193 | *  @brief Updates the presence status by querying D-Bus | 
|  | 194 | * | 
|  | 195 | * The D-Bus inventory properties for this power supply will be read to | 
|  | 196 | * determine if the power supply is present or not and update this | 
|  | 197 | * object's present member variable to reflect current status. | 
|  | 198 | **/ | 
|  | 199 | void updatePresence(); | 
|  | 200 |  | 
|  | 201 | /** | 
|  | 202 | * @brief Callback for inventory property changes | 
|  | 203 | * | 
|  | 204 | * Process change of Present property for power supply. | 
|  | 205 | * | 
|  | 206 | * @param[in]  msg - Data associated with Present change signal | 
|  | 207 | **/ | 
|  | 208 | void inventoryChanged(sdbusplus::message::message& msg); | 
| Brandon Wyman | a0f33ce | 2019-10-17 18:32:29 -0500 | [diff] [blame] | 209 | }; | 
|  | 210 |  | 
|  | 211 | } // namespace phosphor::power::psu |