| #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 |