X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2Fadapter%2FUSBCECAdapterCommunication.cpp;h=e9d4d9333e399430a008b72ccf779bc3d3117f86;hb=884f239fe81ebd0489bdee277de6b719c1495557;hp=ac66d04423087c795a3fa25fe0b4eeba8e9e2b1b;hpb=aa4cfa6482c4408f80b5393baf2dcefceb8ddc9b;p=deb_libcec.git diff --git a/src/lib/adapter/USBCECAdapterCommunication.cpp b/src/lib/adapter/USBCECAdapterCommunication.cpp index ac66d04..e9d4d93 100644 --- a/src/lib/adapter/USBCECAdapterCommunication.cpp +++ b/src/lib/adapter/USBCECAdapterCommunication.cpp @@ -42,24 +42,6 @@ using namespace PLATFORM; #define CEC_ADAPTER_PING_TIMEOUT 15000 -void *CUSBCECAdapterProcessor::Process(void) -{ - cec_command command; - while (!IsStopped()) - { - if (m_inBuffer.Pop(command)) - m_callback->OnCommandReceived(command); - Sleep(5); - } - - return NULL; -} - -void CUSBCECAdapterProcessor::AddCommand(cec_command command) -{ - m_inBuffer.Push(command); -} - CUSBCECAdapterCommunication::CUSBCECAdapterCommunication(CCECProcessor *processor, const char *strPort, uint16_t iBaudRate /* = 38400 */) : m_port(NULL), m_processor(processor), @@ -69,8 +51,8 @@ CUSBCECAdapterCommunication::CUSBCECAdapterCommunication(CCECProcessor *processo m_lastDestination(CECDEVICE_UNKNOWN), m_bNextIsEscaped(false), m_bGotStart(false), - m_messageProcessor(NULL), - m_bInitialised(false) + m_bInitialised(false), + m_pingThread(NULL) { for (unsigned int iPtr = 0; iPtr < 15; iPtr++) m_bWaitingForAck[iPtr] = false; @@ -206,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; @@ -216,6 +199,7 @@ bool CUSBCECAdapterCommunication::Open(IAdapterCommunicationCallback *cb, uint32 delete m_port; m_port = NULL; CLibCEC::AddLog(CEC_LOG_ERROR, "could not create a communication thread"); + return false; } } else @@ -229,54 +213,32 @@ 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); } void *CUSBCECAdapterCommunication::Process(void) { - m_messageProcessor = new CUSBCECAdapterProcessor(m_callback); - m_messageProcessor->CreateThread(); - cec_command command; command.Clear(); bool bCommandReceived(false); - CTimeout pingTimeout(CEC_ADAPTER_PING_TIMEOUT); while (!IsStopped()) { { CLockObject lock(m_mutex); - ReadFromDevice(50); - bCommandReceived = m_callback && Read(command, 0) && m_bInitialised; + bCommandReceived = m_callback && Read(command, 50) && m_bInitialised; } /* push the next command to the callback method if there is one */ if (!IsStopped() && bCommandReceived) - m_messageProcessor->AddCommand(command); - - /* ping the adapter every 15 seconds */ - if (pingTimeout.TimeLeft() == 0) - { - pingTimeout.Init(CEC_ADAPTER_PING_TIMEOUT); - PingAdapter(); - } + m_callback->OnCommandReceived(command); - if (!IsStopped()) - { - Sleep(5); - WriteNextCommand(); - } + Sleep(5); } - /* stop the message processor */ - m_messageProcessor->StopThread(); - delete m_messageProcessor; - m_messageProcessor = NULL; - - /* notify all threads that are waiting on messages to be sent */ - CCECAdapterMessage *msg(NULL); - while (m_outBuffer.Pop(msg)) - msg->event.Broadcast(); - /* set the ackmask to 0 before closing the connection */ SetAckMaskInternal(0, true); @@ -333,8 +295,7 @@ cec_adapter_message_state CUSBCECAdapterCommunication::Write(const cec_command & bool CUSBCECAdapterCommunication::Write(CCECAdapterMessage *data) { data->state = ADAPTER_MESSAGE_STATE_WAITING_TO_BE_SENT; - m_outBuffer.Push(data); - data->event.Wait(5000); + SendMessageToAdapter(data); if ((data->expectControllerAck && data->state != ADAPTER_MESSAGE_STATE_SENT_ACKED) || (!data->expectControllerAck && data->state != ADAPTER_MESSAGE_STATE_SENT)) @@ -364,9 +325,10 @@ bool CUSBCECAdapterCommunication::Read(cec_command &command, uint32_t iTimeout) return false; } -bool CUSBCECAdapterCommunication::Read(CCECAdapterMessage &msg, uint32_t iTimeout) +bool CUSBCECAdapterCommunication::Read(CCECAdapterMessage &msg, uint32_t iTimeout, size_t iLen) { CLockObject lock(m_mutex); + ReadFromDevice(iTimeout, iLen); msg.Clear(); CCECAdapterMessage *buf(NULL); @@ -410,7 +372,6 @@ bool CUSBCECAdapterCommunication::StartBootloader(void) bool CUSBCECAdapterCommunication::PingAdapter(void) { - CLockObject lock(m_mutex); CLibCEC::AddLog(CEC_LOG_DEBUG, "sending ping"); CCECAdapterMessage params; @@ -817,9 +778,8 @@ bool CUSBCECAdapterCommunication::WaitForAck(CCECAdapterMessage &message) while (!bTransmitSucceeded && !bError && iNow < iTargetTime) { - ReadFromDevice(50); CCECAdapterMessage msg; - if (!Read(msg, 0)) + if (!Read(msg, 50)) { iNow = GetTimeMs(); continue; @@ -988,14 +948,6 @@ void CUSBCECAdapterCommunication::SendMessageToAdapter(CCECAdapterMessage *msg) CLibCEC::AddLog(CEC_LOG_DEBUG, "did not receive ack"); } } - msg->event.Signal(); -} - -void CUSBCECAdapterCommunication::WriteNextCommand(void) -{ - CCECAdapterMessage *msg(NULL); - if (m_outBuffer.Pop(msg)) - SendMessageToAdapter(msg); } CStdString CUSBCECAdapterCommunication::GetPortName(void) @@ -1055,10 +1007,8 @@ cec_datapacket CUSBCECAdapterCommunication::GetSetting(cec_adapter_messagecode m return retVal; } - Sleep(250); // TODO ReadFromDevice() isn't waiting for the timeout to pass on win32 - ReadFromDevice(CEC_DEFAULT_TRANSMIT_WAIT, iResponseLength + 3 /* start + msgcode + iResponseLength + end */); CCECAdapterMessage input; - if (Read(input, 0)) + if (Read(input, CEC_DEFAULT_TRANSMIT_WAIT, iResponseLength + 3 /* start + msgcode + iResponseLength + end */)) { if (input.Message() != msgCode) CLibCEC::AddLog(CEC_LOG_ERROR, "invalid response to %s received (%s)", CCECAdapterMessage::ToString(msgCode), CCECAdapterMessage::ToString(input.Message())); @@ -1075,3 +1025,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; +}