blob: bb4dc8b2a42d4f0f7ac6ea830a243629d01d7601 [file] [log] [blame]
#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