return bReturn;
}
-bool CCECProcessor::SetLineTimeout(uint8_t iTimeout)
-{
- bool bReturn(false);
- CCECAdapterMessage *output = new CCECAdapterMessage;
-
- output->push_back(MSGSTART);
- output->push_escaped(MSGCODE_TRANSMIT_IDLETIME);
- output->push_escaped(iTimeout);
- output->push_back(MSGEND);
-
- if ((bReturn = Transmit(output)) == false)
- m_controller->AddLog(CEC_LOG_ERROR, "could not set the idletime");
- delete output;
- return bReturn;
-}
-
void *CCECProcessor::Process(void)
{
bool bParseFrame(false);
}
else
{
+ m_busDevices[m_logicalAddresses.primary]->TransmitPhysicalAddress();
CLockObject lock(&m_mutex);
m_bStarted = true;
m_controller->AddLog(CEC_LOG_DEBUG, "processor thread started");
}
}
- return SetStreamPath(m_busDevices[addr]->GetPhysicalAddress(false)) &&
- m_busDevices[addr]->TransmitActiveSource();
+ bReturn = m_busDevices[CECDEVICE_TV]->PowerOn() &&
+ m_busDevices[addr]->TransmitActiveSource() &&
+ SetStreamPath(m_busDevices[addr]->GetPhysicalAddress(false));
+
+ if (bReturn && (m_busDevices[addr]->GetType() == CEC_DEVICE_TYPE_PLAYBACK_DEVICE ||
+ m_busDevices[addr]->GetType() == CEC_DEVICE_TYPE_RECORDING_DEVICE))
+ {
+ bReturn = ((CCECPlaybackDevice *)m_busDevices[addr])->TransmitDeckStatus(CECDEVICE_TV);
+ }
+
+ return bReturn;
}
bool CCECProcessor::SetActiveSource(cec_logical_address iAddress)
bool bReturn(false);
CLockObject lock(&m_mutex);
{
- while (output->needs_retry() && ++output->tries <= output->maxTries)
+ m_communication->SetLineTimeout(3);
+
+ do
{
+ if (output->tries > 0)
+ m_communication->SetLineTimeout(5);
+
CLockObject msgLock(&output->mutex);
if (!m_communication || !m_communication->Write(output))
return bReturn;
}
else
bReturn = true;
- }
+ }while (output->transmit_timeout > 0 && output->needs_retry() && ++output->tries <= output->maxTries);
}
+ m_communication->SetLineTimeout(3);
+
return bReturn;
}
}
if (bError)
+ {
message->reply = msg.message();
+ m_controller->AddLog(CEC_LOG_DEBUG, msg.ToString());
+ }
else
{
- m_controller->AddLog(CEC_LOG_DEBUG, msg.ToString());
-
switch(msg.message())
{
case MSGCODE_COMMAND_ACCEPTED:
+ m_controller->AddLog(CEC_LOG_DEBUG, msg.ToString());
if (iPacketsLeft > 0)
iPacketsLeft--;
break;
case MSGCODE_TRANSMIT_SUCCEEDED:
+ m_controller->AddLog(CEC_LOG_DEBUG, msg.ToString());
bTransmitSucceeded = (iPacketsLeft == 0);
bError = !bTransmitSucceeded;
message->reply = MSGCODE_TRANSMIT_SUCCEEDED;
break;
default:
- if (ParseMessage(msg))
- m_commandBuffer.Push(m_currentframe);
+ // ignore other data while waiting
+ break;
}
iNow = GetTimeMs();
device = m_processor->m_busDevices[iPtr];
if (device && device->GetStatus() == CEC_DEVICE_STATUS_PRESENT)
{
- if (!IsStopped())
- device->GetPhysicalAddress(false);
- Sleep(5);
-
- if (!IsStopped())
- device->GetCecVersion();
- Sleep(5);
-
if (!IsStopped())
device->GetVendorId();
Sleep(5);