m_lastDestination(CECDEVICE_UNKNOWN),
m_bNextIsEscaped(false),
m_bGotStart(false),
- m_bInitialised(false)
+ m_bInitialised(false),
+ m_pingThread(NULL)
{
for (unsigned int iPtr = 0; iPtr < 15; iPtr++)
m_bWaitingForAck[iPtr] = false;
}
else if (bStartListening)
{
- if (CreateThread())
+ m_pingThread = new CAdapterPingThread(this, CEC_ADAPTER_PING_TIMEOUT);
+ if (CreateThread() && m_pingThread->CreateThread())
{
CLibCEC::AddLog(CEC_LOG_DEBUG, "communication thread started");
return true;
void CUSBCECAdapterCommunication::Close(void)
{
+ if (m_pingThread)
+ m_pingThread->StopThread(0);
+ delete m_pingThread;
+ m_pingThread = NULL;
StopThread(0);
}
cec_command command;
command.Clear();
bool bCommandReceived(false);
- CTimeout pingTimeout(CEC_ADAPTER_PING_TIMEOUT);
while (!IsStopped())
{
{
if (!IsStopped() && bCommandReceived)
m_callback->OnCommandReceived(command);
- /* ping the adapter every 15 seconds */
- if (pingTimeout.TimeLeft() == 0)
- {
- pingTimeout.Init(CEC_ADAPTER_PING_TIMEOUT);
- PingAdapter();
- }
+ Sleep(5);
}
/* set the ackmask to 0 before closing the connection */
{
data->state = ADAPTER_MESSAGE_STATE_WAITING_TO_BE_SENT;
SendMessageToAdapter(data);
- data->event.Wait(5000);
if ((data->expectControllerAck && data->state != ADAPTER_MESSAGE_STATE_SENT_ACKED) ||
(!data->expectControllerAck && data->state != ADAPTER_MESSAGE_STATE_SENT))
bool CUSBCECAdapterCommunication::PingAdapter(void)
{
- CLockObject lock(m_mutex);
CLibCEC::AddLog(CEC_LOG_DEBUG, "sending ping");
CCECAdapterMessage params;
CLibCEC::AddLog(CEC_LOG_DEBUG, "did not receive ack");
}
}
- msg->event.Signal();
}
CStdString CUSBCECAdapterCommunication::GetPortName(void)
return retVal;
}
+
+void *CAdapterPingThread::Process(void)
+{
+ while (!IsStopped())
+ {
+ if (m_timeout.TimeLeft() == 0)
+ {
+ m_timeout.Init(CEC_ADAPTER_PING_TIMEOUT);
+ m_com->PingAdapter();
+ }
+
+ Sleep(500);
+ }
+ return NULL;
+}
namespace CEC
{
class CCECProcessor;
+ class CAdapterPingThread;
class CUSBCECAdapterCommunication : public IAdapterCommunication, private PLATFORM::CThread
{
IAdapterCommunicationCallback * m_callback;
bool m_bInitialised;
bool m_bWaitingForAck[15];
+ CAdapterPingThread * m_pingThread;
+ };
+
+ class CAdapterPingThread : public PLATFORM::CThread
+ {
+ public:
+ CAdapterPingThread(CUSBCECAdapterCommunication *com, uint32_t iTimeout) :
+ m_com(com),
+ m_timeout(iTimeout){}
+ virtual ~CAdapterPingThread(void) {}
+
+ virtual void* Process(void);
+ private:
+ CUSBCECAdapterCommunication *m_com;
+ PLATFORM::CTimeout m_timeout;
};
};