repositories
/
deb_libcec.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
win32: download boost deps from xbmc.org
[deb_libcec.git]
/
src
/
lib
/
AdapterCommunication.cpp
diff --git
a/src/lib/AdapterCommunication.cpp
b/src/lib/AdapterCommunication.cpp
index 3b0ca015454a1250a40da236358bf2f3e0206161..d3eecf45ea7f1045ef466ba38e1291f71f0186ca 100644
(file)
--- a/
src/lib/AdapterCommunication.cpp
+++ b/
src/lib/AdapterCommunication.cpp
@@
-147,7
+147,8
@@
bool CAdapterCommunication::Open(const char *strPort, uint16_t iBaudRate /* = 38
if (CreateThread())
{
if (CreateThread())
{
- m_controller->AddLog(CEC_LOG_DEBUG, "communication thread created");
+ m_startCondition.Wait(&m_mutex);
+ m_controller->AddLog(CEC_LOG_DEBUG, "communication thread started");
return true;
}
else
return true;
}
else
@@
-161,14
+162,17
@@
bool CAdapterCommunication::Open(const char *strPort, uint16_t iBaudRate /* = 38
void CAdapterCommunication::Close(void)
{
CLockObject lock(&m_mutex);
void CAdapterCommunication::Close(void)
{
CLockObject lock(&m_mutex);
- StopThread();
-
+ m_startCondition.Broadcast();
m_rcvCondition.Broadcast();
m_rcvCondition.Broadcast();
+ StopThread();
}
void *CAdapterCommunication::Process(void)
{
}
void *CAdapterCommunication::Process(void)
{
- m_controller->AddLog(CEC_LOG_DEBUG, "communication thread started");
+ {
+ CLockObject lock(&m_mutex);
+ m_startCondition.Signal();
+ }
while (!IsStopped())
{
while (!IsStopped())
{
@@
-372,5
+376,5
@@
bool CAdapterCommunication::PingAdapter(void)
bool CAdapterCommunication::IsOpen(void) const
{
bool CAdapterCommunication::IsOpen(void) const
{
- return !IsStopped() && m_port->IsOpen();
+ return !IsStopped() && m_port->IsOpen()
&& IsRunning()
;
}
}