X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2Fadapter%2FUSBCECAdapterCommunication.cpp;h=ab26d84550f30f010113f12a0228cc55cb330219;hb=56e53c14cf072c449743fa36f2f80318cd64bfc3;hp=fb6f26707ab06c53f5bd5c5600dd433b0b10ef0d;hpb=eb0c8917a6a4305e5d603266c7660fd5f6186821;p=deb_libcec.git diff --git a/src/lib/adapter/USBCECAdapterCommunication.cpp b/src/lib/adapter/USBCECAdapterCommunication.cpp index fb6f267..ab26d84 100644 --- a/src/lib/adapter/USBCECAdapterCommunication.cpp +++ b/src/lib/adapter/USBCECAdapterCommunication.cpp @@ -51,7 +51,8 @@ CUSBCECAdapterCommunication::CUSBCECAdapterCommunication(CCECProcessor *processo 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; @@ -187,7 +188,8 @@ bool CUSBCECAdapterCommunication::Open(IAdapterCommunicationCallback *cb, uint32 } 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; @@ -211,6 +213,10 @@ bool CUSBCECAdapterCommunication::Open(IAdapterCommunicationCallback *cb, uint32 void CUSBCECAdapterCommunication::Close(void) { + if (m_pingThread) + m_pingThread->StopThread(0); + delete m_pingThread; + m_pingThread = NULL; StopThread(0); } @@ -219,7 +225,6 @@ void *CUSBCECAdapterCommunication::Process(void) cec_command command; command.Clear(); bool bCommandReceived(false); - CTimeout pingTimeout(CEC_ADAPTER_PING_TIMEOUT); while (!IsStopped()) { { @@ -232,12 +237,7 @@ void *CUSBCECAdapterCommunication::Process(void) 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 */ @@ -297,7 +297,6 @@ bool CUSBCECAdapterCommunication::Write(CCECAdapterMessage *data) { 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)) @@ -373,7 +372,6 @@ bool CUSBCECAdapterCommunication::StartBootloader(void) bool CUSBCECAdapterCommunication::PingAdapter(void) { - CLockObject lock(m_mutex); CLibCEC::AddLog(CEC_LOG_DEBUG, "sending ping"); CCECAdapterMessage params; @@ -951,7 +949,6 @@ void CUSBCECAdapterCommunication::SendMessageToAdapter(CCECAdapterMessage *msg) CLibCEC::AddLog(CEC_LOG_DEBUG, "did not receive ack"); } } - msg->event.Signal(); } CStdString CUSBCECAdapterCommunication::GetPortName(void) @@ -1030,3 +1027,18 @@ cec_datapacket CUSBCECAdapterCommunication::GetSetting(cec_adapter_messagecode m 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; +}