blob: 8901a2b3705c840f7421917e3241407cb4e9cefc [file] [log] [blame]
#pragma once
#include <queue>
#include <sdbusplus/bus.hpp>
#include <phosphor-logging/elog.hpp>
#include <xyz/openbmc_project/Control/Host/server.hpp>
#include <timer.hpp>
namespace phosphor
{
namespace host
{
using namespace phosphor::logging;
/** @class Host
* @brief OpenBMC control host interface implementation.
* @details A concrete implementation for xyz.openbmc_project.Control.Host
* DBus API.
*/
class Host : public sdbusplus::server::object::object<
sdbusplus::xyz::openbmc_project::Control::server::Host>
{
public:
/** @brief Constructs Host Control Interface
*
* @param[in] bus - The Dbus bus object
* @param[in] objPath - The Dbus object path
* @param[in] events - The sd_event pointer
*/
Host(sdbusplus::bus::bus& bus,
const char* objPath,
sd_event* events) :
sdbusplus::server::object::object<
sdbusplus::xyz::openbmc_project::Control::server::Host>(
bus, objPath),
bus(bus),
timer(events,
std::bind(&Host::hostTimeout, this))
{}
/** @brief Send input command to host
*
* Note that the command will be queued in a FIFO if other commands
* to the host have yet to be run
*
* @param[in] command - Input command to execute
*/
void execute(Command command) override;
/** @brief Return the next entry in the queue
*
* Also signal that the command is complete since the interface
* contract is that we emit this signal once the message has been
* passed to the host (which is required when calling this interface)
*
*/
Command getNextCommand();
private:
/** @brief Check if anything in queue and alert host if so */
void checkQueue();
/** @brief Call back interface on message timeouts to host */
void hostTimeout();
/** @brief Persistent sdbusplus DBus bus connection. */
sdbusplus::bus::bus& bus;
/** @brief Queue to store the requested commands */
std::queue<Command> workQueue{};
/** @brief Timer for commands to host */
phosphor::ipmi::Timer timer;
};
} // namespace host
} // namespace phosphor