case CEC_OPCODE_GIVE_SYSTEM_AUDIO_MODE_STATUS:
HandleGiveSystemAudioModeStatus(command);
break;
+ case CEC_OPCODE_SYSTEM_AUDIO_MODE_REQUEST:
+ HandleSetSystemAudioModeRequest(command);
+ break;
default:
UnhandledCommand(command);
m_busDevice->GetProcessor()->AddCommand(command);
bool CCECCommandHandler::HandleDeviceVendorCommandWithId(const cec_command &command)
{
- CCECBusDevice *device = GetDevice(command.initiator);
- if (device)
- device->SetVendorId(command.parameters);
-
+ SetVendorId(command);
return true;
}
bool CCECCommandHandler::HandleDeviceVendorId(const cec_command &command)
{
- CCECBusDevice *device = GetDevice(command.initiator);
- if (device)
- device->SetVendorId(command.parameters);
-
+ SetVendorId(command);
return true;
}
CCECBusDevice *device = GetDevice(command.initiator);
if (device)
- device->SetPhysicalAddress(iNewAddress, iOldAddress);
+ device->SetStreamPath(iNewAddress, iOldAddress);
}
return true;
}
return true;
}
+bool CCECCommandHandler::HandleSetSystemAudioModeRequest(const cec_command &command)
+{
+ if (command.parameters.size >= 1)
+ {
+ CCECBusDevice *device = GetDevice(command.destination);
+ if (device&& device->GetType() == CEC_DEVICE_TYPE_AUDIO_SYSTEM)
+ return ((CCECAudioSystem *) device)->SetSystemAudioMode(command);
+ }
+ return true;
+}
+
bool CCECCommandHandler::HandleGiveSystemAudioModeStatus(const cec_command &command)
{
CCECBusDevice *device = GetDevice(command.destination);
return device;
}
+
+
+void CCECCommandHandler::SetVendorId(const cec_command &command)
+{
+ if (command.parameters.size < 3)
+ {
+ m_busDevice->AddLog(CEC_LOG_WARNING, "invalid vendor ID received");
+ return;
+ }
+
+ uint64_t iVendorId = ((uint64_t)command.parameters[0] << 3) +
+ ((uint64_t)command.parameters[1] << 2) +
+ (uint64_t)command.parameters[2];
+
+ CCECBusDevice *device = GetDevice((cec_logical_address) command.initiator);
+ if (device)
+ device->SetVendorId(iVendorId, iVendorId);
+}