| #pragma once |
| |
| #include "config.h" |
| |
| #include "occ_status.hpp" |
| #include "utils.hpp" |
| |
| #include <experimental/filesystem> |
| #include <sdbusplus/bus.hpp> |
| #include <sdbusplus/bus/match.hpp> |
| |
| namespace open_power |
| { |
| namespace occ |
| { |
| namespace powercap |
| { |
| |
| namespace sdbusRule = sdbusplus::bus::match::rules; |
| |
| /** @class PowerCap |
| * @brief Monitors for changes to the power cap and notifies occ |
| * |
| * The customer power cap is provided to the OCC by host TMGT when the occ |
| * first goes active or is reset. This code is responsible for sending |
| * the power cap to the OCC if the cap is changed while the occ is active. |
| */ |
| |
| class PowerCap |
| { |
| public: |
| /** @brief PowerCap object to inform occ of changes to cap |
| * |
| * This object will monitor for changes to the power cap setting and |
| * power cap enable properties. If a change is detected, and the occ |
| * is active, then this object will notify the OCC of the change. |
| * |
| * @param[in] occStatus - The occ status object |
| */ |
| PowerCap(Status& occStatus, |
| const std::string& occMasterName = OCC_MASTER_NAME) : |
| occMasterName(occMasterName), |
| occStatus(occStatus), |
| pcapMatch( |
| utils::getBus(), |
| sdbusRule::member("PropertiesChanged") + |
| sdbusRule::path( |
| "/xyz/openbmc_project/control/host0/power_cap") + |
| sdbusRule::argN(0, "xyz.openbmc_project.Control.Power.Cap") + |
| sdbusRule::interface("org.freedesktop.DBus.Properties"), |
| std::bind(std::mem_fn(&PowerCap::pcapChanged), this, |
| std::placeholders::_1)){}; |
| |
| /** @brief Return the appropriate value to write to the OCC |
| * |
| * @param[in] pcap - Current user power cap setting |
| * @param[in] pcapEnabled - Current power cap enable setting |
| * |
| * @return The value to write to the occ user pcap |
| */ |
| uint32_t getOccInput(uint32_t pcap, bool pcapEnabled); |
| |
| private: |
| /** @brief Callback for pcap setting changes |
| * |
| * Process change and inform OCC |
| * |
| * @param[in] msg - Data associated with pcap change signal |
| * |
| */ |
| void pcapChanged(sdbusplus::message::message& msg); |
| |
| /** @brief Get the power cap property |
| * |
| * @return Power cap, 0 on failure to indicate no pcap |
| */ |
| uint32_t getPcap(); |
| |
| /** @brief Get the power cap enable property |
| * |
| * @return Whether power cap enabled, will return false on error |
| */ |
| bool getPcapEnabled(); |
| |
| /** @brief Write the input power cap to the occ hwmon entry |
| * |
| * @param[in] pcapValue - Power cap value to write to OCC |
| */ |
| void writeOcc(uint32_t pcapValue); |
| |
| /** |
| * @brief Returns the filename to use for the user power cap |
| * |
| * The file is of the form "powerX_cap_user", where X is any |
| * number. |
| * |
| * @param[in] path - The directory to look for the file in |
| * |
| * @return std::string - The filename, or empty string if not found. |
| */ |
| std::string |
| getPcapFilename(const std::experimental::filesystem::path& path); |
| |
| /** @brief The master occ name */ |
| std::string occMasterName; |
| |
| /* @brief OCC Status object */ |
| Status& occStatus; |
| |
| /** @brief Used to subscribe to dbus pcap property changes **/ |
| sdbusplus::bus::match_t pcapMatch; |
| }; |
| |
| } // namespace powercap |
| |
| } // namespace occ |
| |
| } // namespace open_power |