1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
#include "evdev.hpp"
#include "xyz/openbmc_project/Common/error.hpp"
#include <fcntl.h>
#include <libevdev/libevdev.h>
#include <phosphor-logging/elog-errors.hpp>
#include <phosphor-logging/elog.hpp>
#include <phosphor-logging/log.hpp>
namespace phosphor
{
namespace gpio
{
using namespace phosphor::logging;
using namespace sdbusplus::xyz::openbmc_project::Common::Error;
// Populate the file descriptor for passed in device
int Evdev::openDevice()
{
using namespace phosphor::logging;
auto fd = open(path.c_str(), O_RDONLY | O_NONBLOCK);
if (fd < 0)
{
log<level::ERR>("Failed to open device path",
entry("DEVICEPATH=%s", path.c_str()),
entry("ERRNO=%d", errno));
elog<InternalFailure>();
}
return fd;
}
// Initializes the event device with the fd
void Evdev::initEvDev()
{
if (devicePtr)
{
// Init can be done only once per device
return;
}
struct libevdev* evdev = nullptr;
auto rc = libevdev_new_from_fd((fd)(), &evdev);
if (rc < 0)
{
log<level::ERR>("Failed to initialize evdev");
elog<InternalFailure>();
return;
}
// Packing in the unique_ptr
devicePtr.reset(evdev);
}
// Attaches the FD to event loop and registers the callback handler
void Evdev::registerCallback()
{
decltype(eventSource.get()) sourcePtr = nullptr;
auto rc = sd_event_add_io(event.get(), &sourcePtr, (fd)(), EPOLLIN,
callbackHandler, this);
eventSource.reset(sourcePtr);
if (rc < 0)
{
log<level::ERR>("Failed to register callback handler",
entry("ERROR=%s", strerror(-rc)));
elog<InternalFailure>();
}
}
} // namespace gpio
} // namespace phosphor
|