blob: 6f078f22e43b7bf0b245756751c4934effe65931 [file] [log] [blame]
#include "debugHostSelector_button.hpp"
// add the button iface class to registry
static ButtonIFRegister<DebugHostSelector> buttonRegister;
using namespace phosphor::logging;
void DebugHostSelector::simPress()
{
pressed();
}
void DebugHostSelector::simRelease()
{
released();
}
void DebugHostSelector::simLongPress()
{
pressedLong();
}
/**
* @brief This method is called from sd-event provided callback function
* callbackHandler if platform specific event handling is needed then a
* derived class instance with its specific event handling logic along with
* init() function can be created to override the default event handling
*/
void DebugHostSelector::handleEvent(sd_event_source* /* es */, int fd,
uint32_t /* revents*/)
{
int n = -1;
char buf = '0';
n = ::lseek(fd, 0, SEEK_SET);
if (n < 0)
{
lg2::error("GPIO fd lseek error! : {FORM_FACTOR_TYPE}",
"FORM_FACTOR_TYPE", getFormFactorType());
return;
}
n = ::read(fd, &buf, sizeof(buf));
if (n < 0)
{
lg2::error("GPIO fd read error! : {FORM_FACTOR_TYPE}",
"FORM_FACTOR_TYPE", getFormFactorType());
throw sdbusplus::xyz::openbmc_project::Chassis::Common::Error::
IOError();
}
if (buf == '0')
{
lg2::info("Button pressed : {FORM_FACTOR_TYPE}", "FORM_FACTOR_TYPE",
getFormFactorType());
// emit pressed signal
pressed();
}
else
{
lg2::info("Button released{FORM_FACTOR_TYPE}", "FORM_FACTOR_TYPE",
getFormFactorType());
// emit released signal
released();
}
}