With the internal headers now in include/libcamera/internal/, we may have identically named headers in include/libcamera/. Their header guards would clash. Rename the header guards of internal headers to prevent any issue. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
59 lines
1.2 KiB
C++
59 lines
1.2 KiB
C++
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
/*
|
|
* Copyright (C) 2019, Google Inc.
|
|
*
|
|
* event_dispatcher_poll.h - Poll-based event dispatcher
|
|
*/
|
|
#ifndef __LIBCAMERA_INTERNAL_EVENT_DISPATCHER_POLL_H__
|
|
#define __LIBCAMERA_INTERNAL_EVENT_DISPATCHER_POLL_H__
|
|
|
|
#include <list>
|
|
#include <map>
|
|
#include <vector>
|
|
|
|
#include <libcamera/event_dispatcher.h>
|
|
|
|
struct pollfd;
|
|
|
|
namespace libcamera {
|
|
|
|
class EventNotifier;
|
|
class Timer;
|
|
|
|
class EventDispatcherPoll final : public EventDispatcher
|
|
{
|
|
public:
|
|
EventDispatcherPoll();
|
|
~EventDispatcherPoll();
|
|
|
|
void registerEventNotifier(EventNotifier *notifier);
|
|
void unregisterEventNotifier(EventNotifier *notifier);
|
|
|
|
void registerTimer(Timer *timer);
|
|
void unregisterTimer(Timer *timer);
|
|
|
|
void processEvents();
|
|
void interrupt();
|
|
|
|
private:
|
|
struct EventNotifierSetPoll {
|
|
short events() const;
|
|
EventNotifier *notifiers[3];
|
|
};
|
|
|
|
int poll(std::vector<struct pollfd> *pollfds);
|
|
void processInterrupt(const struct pollfd &pfd);
|
|
void processNotifiers(const std::vector<struct pollfd> &pollfds);
|
|
void processTimers();
|
|
|
|
std::map<int, EventNotifierSetPoll> notifiers_;
|
|
std::list<Timer *> timers_;
|
|
int eventfd_;
|
|
|
|
bool processingEvents_;
|
|
};
|
|
|
|
} /* namespace libcamera */
|
|
|
|
#endif /* __LIBCAMERA_INTERNAL_EVENT_DISPATCHER_POLL_H__ */
|