mirror of https://github.com/Icinga/icinga2.git
parent
83889dcbb0
commit
ecfaf019fd
|
@ -24,10 +24,6 @@
|
|||
#include <boost/foreach.hpp>
|
||||
#include <map>
|
||||
|
||||
#ifndef _WIN32
|
||||
# include <poll.h>
|
||||
#endif /* _WIN32 */
|
||||
|
||||
using namespace icinga;
|
||||
|
||||
struct SocketEventDescriptor
|
||||
|
@ -55,6 +51,7 @@ static boost::mutex l_SocketIOMutex;
|
|||
static boost::condition_variable l_SocketIOCV;
|
||||
static bool l_SocketIOFDChanged;
|
||||
static std::map<SOCKET, SocketEventDescriptor> l_SocketIOSockets;
|
||||
static std::map<SOCKET, int> l_SocketIOEventChanges;
|
||||
|
||||
void SocketEvents::InitializeThread(void)
|
||||
{
|
||||
|
@ -88,6 +85,8 @@ void SocketEvents::ThreadProc(void)
|
|||
boost::mutex::scoped_lock lock(l_SocketIOMutex);
|
||||
|
||||
if (l_SocketIOFDChanged) {
|
||||
Log(LogWarning, "SocketEvents", "Updated event FDs");
|
||||
|
||||
pfds.resize(l_SocketIOSockets.size());
|
||||
descriptors.resize(l_SocketIOSockets.size());
|
||||
|
||||
|
@ -96,9 +95,11 @@ void SocketEvents::ThreadProc(void)
|
|||
typedef std::map<SOCKET, SocketEventDescriptor>::value_type kv_pair;
|
||||
|
||||
BOOST_FOREACH(const kv_pair& desc, l_SocketIOSockets) {
|
||||
if (desc.second.EventInterface)
|
||||
desc.second.EventInterface->m_PFD = &pfds[i];
|
||||
|
||||
pfds[i].fd = desc.first;
|
||||
pfds[i].events = desc.second.Events;
|
||||
pfds[i].revents = 0;
|
||||
descriptors[i] = desc.second;
|
||||
|
||||
i++;
|
||||
|
@ -186,7 +187,7 @@ void SocketEvents::WakeUpThread(bool wait)
|
|||
* Constructor for the SocketEvents class.
|
||||
*/
|
||||
SocketEvents::SocketEvents(const Socket::Ptr& socket, Object *lifesupportObject)
|
||||
: m_FD(socket->GetFD())
|
||||
: m_FD(socket->GetFD()), m_PFD(NULL)
|
||||
{
|
||||
boost::call_once(l_SocketIOOnceFlag, &SocketEvents::InitializeThread);
|
||||
|
||||
|
@ -257,7 +258,11 @@ void SocketEvents::ChangeEvents(int events)
|
|||
return;
|
||||
|
||||
it->second.Events = events;
|
||||
l_SocketIOFDChanged = true;
|
||||
|
||||
if (m_PFD && boost::this_thread::get_id() == l_SocketIOThread.get_id())
|
||||
m_PFD->events = events;
|
||||
else
|
||||
l_SocketIOFDChanged = true;
|
||||
}
|
||||
|
||||
WakeUpThread();
|
||||
|
|
|
@ -23,6 +23,10 @@
|
|||
#include "base/i2-base.hpp"
|
||||
#include "base/socket.hpp"
|
||||
|
||||
#ifndef _WIN32
|
||||
# include <poll.h>
|
||||
#endif /* _WIN32 */
|
||||
|
||||
namespace icinga
|
||||
{
|
||||
|
||||
|
@ -50,6 +54,7 @@ protected:
|
|||
private:
|
||||
SOCKET m_FD;
|
||||
bool m_Events;
|
||||
pollfd *m_PFD;
|
||||
|
||||
static void InitializeThread(void);
|
||||
static void ThreadProc(void);
|
||||
|
|
Loading…
Reference in New Issue