X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FCECProcessor.h;h=5d0cfa2b53cbcab4e1d0fd7c49fa0d8d7f689f58;hb=ddbda099de53712c09315291d96b6d9db2ac1bbc;hp=140911a7022a828628171e67574febac6703706d;hpb=02e7043ec09609e351130b648b282f25a3e1f2b9;p=deb_libcec.git diff --git a/src/lib/CECProcessor.h b/src/lib/CECProcessor.h index 140911a..5d0cfa2 100644 --- a/src/lib/CECProcessor.h +++ b/src/lib/CECProcessor.h @@ -2,7 +2,7 @@ /* * This file is part of the libCEC(R) library. * - * libCEC(R) is Copyright (C) 2011 Pulse-Eight Limited. All rights reserved. + * libCEC(R) is Copyright (C) 2011-2012 Pulse-Eight Limited. All rights reserved. * libCEC(R) is an original work, containing original code. * * libCEC(R) is a trademark of Pulse-Eight Limited. @@ -32,27 +32,29 @@ */ #include -#include +#include "../../include/cectypes.h" +#include "platform/threads/threads.h" +#include "platform/util/buffer.h" #include "adapter/AdapterCommunication.h" -#include "platform/os.h" - -class CSerialPort; namespace CEC { class CLibCEC; - class CAdapterCommunication; + struct IAdapterCommunication; class CCECBusDevice; - class CCECProcessor : public PLATFORM::CThread + class CCECProcessor : public PLATFORM::CThread, public IAdapterCommunicationCallback { public: - CCECProcessor(CLibCEC *controller, const char *strDeviceName, cec_logical_address iLogicalAddress = CECDEVICE_PLAYBACKDEVICE1, uint16_t iPhysicalAddress = CEC_DEFAULT_PHYSICAL_ADDRESS); - CCECProcessor(CLibCEC *controller, const char *strDeviceName, const cec_device_type_list &types); + CCECProcessor(CLibCEC *controller, const char *strDeviceName, const cec_device_type_list &types, uint16_t iPhysicalAddress, cec_client_version clientVersion); + CCECProcessor(CLibCEC *controller, const libcec_configuration *configuration); virtual ~CCECProcessor(void); virtual bool Start(const char *strPort, uint16_t iBaudRate = 38400, uint32_t iTimeoutMs = 10000); virtual void *Process(void); + virtual void Close(void); + + virtual bool OnCommandReceived(const cec_command &command); virtual bool IsMonitoring(void) const { return m_bMonitor; } virtual CCECBusDevice * GetDeviceByPhysicalAddress(uint16_t iPhysicalAddress, bool bRefresh = false) const; @@ -73,10 +75,10 @@ namespace CEC virtual bool IsPresentDeviceType(cec_device_type type); virtual uint16_t GetPhysicalAddress(void) const; virtual uint64_t GetLastTransmission(void) const { return m_iLastTransmission; } - virtual bool IsStarted(void) const { return m_bStarted; } virtual cec_logical_address GetActiveSource(void); virtual bool IsActiveSource(cec_logical_address iAddress); - virtual bool IsInitialised(void) const { return m_bInitialised; } + virtual bool IsInitialised(void); + virtual bool SetStreamPath(uint16_t iPhysicalAddress); virtual bool SetActiveView(void); virtual bool SetActiveSource(cec_device_type type = CEC_DEVICE_TYPE_RESERVED); @@ -98,6 +100,9 @@ namespace CEC virtual bool EnablePhysicalAddressDetection(void) { return false; }; void SetStandardLineTimeout(uint8_t iTimeout); void SetRetryLineTimeout(uint8_t iTimeout); + virtual bool GetCurrentConfiguration(libcec_configuration *configuration); + virtual bool CanPersistConfiguration(void); + virtual bool PersistConfiguration(libcec_configuration *configuration); bool SetLineTimeout(uint8_t iTimeout); @@ -112,9 +117,9 @@ namespace CEC const char *ToString(const cec_system_audio_status mode); const char *ToString(const cec_audio_status status); const char *ToString(const cec_vendor_id vendor); + const char *ToString(const cec_client_version version); virtual bool Transmit(const cec_command &data); - virtual bool Transmit(CCECAdapterMessage *output); virtual void TransmitAbort(cec_logical_address address, cec_opcode opcode, cec_abort_reason reason = CEC_ABORT_REASON_UNRECOGNIZED_OPCODE); virtual bool ChangeDeviceType(cec_device_type from, cec_device_type to); @@ -124,7 +129,7 @@ namespace CEC virtual bool StartBootloader(void); virtual bool PingAdapter(void); virtual void HandlePoll(cec_logical_address initiator, cec_logical_address destination); - virtual bool HandleReceiveFailed(void); + virtual bool HandleReceiveFailed(cec_logical_address initiator); CCECBusDevice * m_busDevices[16]; PLATFORM::CMutex m_transmitMutex; @@ -133,6 +138,7 @@ namespace CEC bool OpenConnection(const char *strPort, uint16_t iBaudRate, uint32_t iTimeoutMs); bool Initialise(void); void SetInitialised(bool bSetTo = true); + void CreateBusDevices(void); void ReplaceHandlers(void); void ScanCECBus(void); @@ -144,21 +150,17 @@ namespace CEC bool FindLogicalAddressAudioSystem(void); void LogOutput(const cec_command &data); - bool ParseMessage(const CCECAdapterMessage &msg); - void ParseCommand(cec_command &command); + void ParseCommand(const cec_command &command); - bool m_bStarted; bool m_bInitialised; + uint16_t m_iPhysicalAddress; uint8_t m_iHDMIPort; cec_logical_address m_iBaseDevice; - cec_command m_currentframe; cec_logical_addresses m_logicalAddresses; - cec_logical_address m_lastInitiator; std::string m_strDeviceName; cec_device_type_list m_types; PLATFORM::CMutex m_mutex; - PLATFORM::CCondition m_startCondition; - CAdapterCommunication* m_communication; + IAdapterCommunication * m_communication; CLibCEC* m_controller; bool m_bMonitor; PLATFORM::SyncedBuffer m_commandBuffer; @@ -168,6 +170,7 @@ namespace CEC uint8_t m_iStandardLineTimeout; uint8_t m_iRetryLineTimeout; uint64_t m_iLastTransmission; + cec_client_version m_clientVersion; }; class CCECBusScan : public PLATFORM::CThread