CCECCommandHandler(busDevice),
m_bSLEnabled(false),
m_bPowerStateReset(false),
- m_bActiveSourceSent(false)
+ m_bActiveSourceSent(false),
+ m_bVendorIdSent(false)
{
m_vendorId = CEC_VENDOR_LG;
CCECBusDevice *primary = m_processor->GetPrimaryDevice();
/* start as 'in transition standby->on' */
primary->SetPowerStatus(CEC_POWER_STATUS_IN_TRANSITION_STANDBY_TO_ON);
primary->TransmitPowerState(CECDEVICE_TV);
-
- /* reply with LGs vendor id */
- primary->TransmitVendorID(CECDEVICE_BROADCAST, false);
}
return true;
bool CSLCommandHandler::ActivateSource(void)
{
+ /* reply with LGs vendor id */
+ if (!m_bVendorIdSent)
+ {
+ m_bVendorIdSent = true;
+ m_processor->GetPrimaryDevice()->TransmitVendorID(CECDEVICE_BROADCAST, false);
+ }
+
if (!m_bSLEnabled)
+ {
+ CLibCEC::AddLog(CEC_LOG_NOTICE, "not activating the source until SL has been initialised");
return true;
+ }
if (m_bActiveSourceSent)
return true;
{
uint16_t iAddress = ((uint16_t)command.parameters[0] << 8) | ((uint16_t)command.parameters[1]);
if (iAddress != m_busDevice->GetPhysicalAddress(false))
+ {
+ CLibCEC::AddLog(CEC_LOG_NOTICE, "resetting SL initialised state");
m_bSLEnabled = false;
+ }
return m_processor->SetActiveSource(iAddress);
}
{
if (command.initiator == CECDEVICE_TV)
{
+ CLibCEC::AddLog(CEC_LOG_NOTICE, "resetting SL initialised state");
m_bSLEnabled = false;
m_bPowerStateReset = false;
m_bActiveSourceSent = false;