blob: 9f059f0a13a8fef21eeb8d6d24f3027ca033e128 [file] [log] [blame]
#pragma once
#include <gpiod.h>
#include <boost/asio/io_context.hpp>
#include <boost/asio/posix/stream_descriptor.hpp>
#include <map>
#include <vector>
namespace phosphor
{
namespace gpio
{
/** @class GpioMonitor
* @brief Responsible for catching GPIO state change
* condition and starting systemd targets.
*/
class GpioMonitor
{
public:
GpioMonitor() = delete;
~GpioMonitor() = default;
GpioMonitor(const GpioMonitor&) = delete;
GpioMonitor& operator=(const GpioMonitor&) = delete;
GpioMonitor(GpioMonitor&&) = delete;
GpioMonitor& operator=(GpioMonitor&&) = delete;
/** @brief Constructs GpioMonitor object.
*
* @param[in] line - GPIO line from libgpiod
* @param[in] config - configuration of line with event
* @param[in] io - io service
* @param[in] target - systemd unit to be started on GPIO
* value change
* @param[in] targets - systemd units to be started on GPIO
* value change
* @param[in] lineMsg - GPIO line message to be used for log
* @param[in] continueRun - Whether to continue after event occur
*/
GpioMonitor(gpiod_line* line, gpiod_line_request_config& config,
boost::asio::io_context& io, const std::string& target,
const std::map<std::string, std::vector<std::string>>& targets,
const std::string& lineMsg, bool continueRun) :
gpioLine(line), gpioConfig(config), gpioEventDescriptor(io),
target(target), targets(targets), gpioLineMsg(lineMsg),
continueAfterEvent(continueRun)
{
requestGPIOEvents();
};
private:
/** @brief GPIO line */
gpiod_line* gpioLine;
/** @brief GPIO line configuration */
gpiod_line_request_config gpioConfig;
/** @brief GPIO event descriptor */
boost::asio::posix::stream_descriptor gpioEventDescriptor;
/** @brief Systemd unit to be started when the condition is met */
const std::string target;
/** @brief Multi systemd units to be started when the condition is met */
std::map<std::string, std::vector<std::string>> targets;
/** @brief GPIO line name message */
std::string gpioLineMsg;
/** @brief If the monitor should continue after event */
bool continueAfterEvent;
/** @brief register handler for gpio event
*
* @return - 0 on success and -1 otherwise
*/
int requestGPIOEvents();
/** @brief Schedule an event handler for GPIO event to trigger */
void scheduleEventHandler();
/** @brief Handle the GPIO event and starts configured target */
void gpioEventHandler();
};
} // namespace gpio
} // namespace phosphor