#include "CECCommandHandler.h"
#include "../devices/CECBusDevice.h"
+#include "../devices/CECAudioSystem.h"
#include "../CECProcessor.h"
using namespace CEC;
case CEC_OPCODE_USER_CONTROL_RELEASE:
HandleUserControlRelease(command);
break;
+ case CEC_OPCODE_GIVE_AUDIO_STATUS:
+ HandleGiveAudioStatus(command);
+ break;
default:
UnhandledCommand(command);
m_busDevice->GetProcessor()->AddCommand(command);
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportCECVersion(command.initiator);
+ return device->TransmitCECVersion(command.initiator);
+
+ return false;
+}
+
+bool CCECCommandHandler::HandleGiveAudioStatus(const cec_command &command)
+{
+ CCECBusDevice *device = GetDevice(command.destination);
+ if (device && device->GetType() == CEC_DEVICE_TYPE_AUDIO_SYSTEM)
+ return ((CCECAudioSystem *) device)->TransmitAudioStatus(command.initiator);
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportDeckStatus(command.initiator);
+ return device->TransmitDeckStatus(command.initiator);
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportPowerState(command.initiator);
+ return device->TransmitPowerState(command.initiator);
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportVendorID(command.initiator);
+ return device->TransmitVendorID(command.initiator);
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportOSDName(command.initiator);
+ return device->TransmitOSDName(command.initiator);
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->BroadcastPhysicalAddress();
+ return device->TransmitPhysicalAddress();
return false;
}
{
CCECBusDevice *device = GetDevice(command.destination);
if (device)
- return device->ReportMenuState(command.initiator);
+ return device->TransmitMenuState(command.initiator);
}
return false;
}
m_busDevice->AddLog(CEC_LOG_DEBUG, strLog.c_str());
CCECBusDevice *device = m_busDevice->GetProcessor()->m_busDevices[m_busDevice->GetMyLogicalAddress()];
if (device)
- return device->BroadcastActiveSource();
+ return device->TransmitActiveSource();
return false;
}
CStdString strLog;
strLog.Format(">> %i requests stream path from physical address %04x", command.initiator, streamaddr);
m_busDevice->AddLog(CEC_LOG_DEBUG, strLog.c_str());
- if (streamaddr == m_busDevice->GetMyPhysicalAddress())
- {
- CCECBusDevice *device = GetDevice(command.destination);
- if (device)
- return device->BroadcastActiveSource();
- return false;
- }
+ CCECBusDevice *device = GetDeviceByPhysicalAddress(streamaddr);
+ if (device)
+ return device->TransmitActiveSource();
}
return true;
}
return device;
}
+
+CCECBusDevice *CCECCommandHandler::GetDeviceByPhysicalAddress(uint16_t iPhysicalAddress) const
+{
+ CCECBusDevice *device = NULL;
+
+ for (unsigned int iPtr = 0; iPtr < 16; iPtr++)
+ {
+ if (m_busDevice->GetProcessor()->m_busDevices[iPtr]->GetPhysicalAddress() == iPhysicalAddress)
+ {
+ device = m_busDevice->GetProcessor()->m_busDevices[iPtr];
+ break;
+ }
+ }
+
+ return device;
+}