signal all waiting threads when receiving an active source message, cache the current...
[deb_libcec.git] / src / lib / CECProcessor.cpp
index e432033961ab0a487cbeb4d4768d44455ac48824..399e065daa81f9872e4d95d3efb54e2773c49d05 100644 (file)
@@ -351,7 +351,7 @@ cec_logical_address CCECProcessor::GetActiveSource(bool bRequestActiveSource /*
   if (activeSource)
     return activeSource->GetLogicalAddress();
 
-  if (bRequestActiveSource)
+  if (bRequestActiveSource && m_busDevices->GetActiveSourceAddress() == CEC_INVALID_PHYSICAL_ADDRESS)
   {
     // request the active source from the bus
     CCECBusDevice *primary = GetPrimaryDevice();