libcec v0.5 (WIP)
[deb_libcec.git] / src / lib / AdapterCommunication.h
index 270d96b9f5303746ecc0b7d42d9813f4dc478a69..8ce9c5b790d82dab14cdc13d01c0a585c67d9f8e 100644 (file)
  *     http://www.pulse-eight.net/
  */
 
-#include <queue>
-#include <stdio.h>
 #include "../../include/CECExports.h"
-#include "../../include/CECTypes.h"
-#include "util/buffer.h"
-#include "util/threads.h"
-
-class CSerialPort;
+#include "platform/threads.h"
+#include <string>
 
 namespace CEC
 {
-  class CCECParser;
+  class CSerialPort;
+  class CLibCEC;
 
   class CAdapterCommunication : CThread
   {
   public:
-    CAdapterCommunication(CCECParser *parser);
+    CAdapterCommunication(CLibCEC *controller);
     virtual ~CAdapterCommunication();
 
-    bool Open(const char *strPort, int iBaudRate = 38400, int iTimeoutMs = 10000);
-    bool Read(cec_frame &msg, int iTimeout = 1000);
+    bool Open(const char *strPort, uint16_t iBaudRate = 38400, uint32_t iTimeoutMs = 10000);
+    bool Read(cec_frame &msg, uint32_t iTimeout = 1000);
     bool Write(const cec_frame &frame);
+    bool PingAdapter(void);
     void Close(void);
     bool IsOpen(void) const { return !m_bStop && m_bStarted; }
     std::string GetError(void) const;
 
     void *Process(void);
+
+    bool StartBootloader(void);
+    bool SetAckMask(uint16_t iMask);
+    static void PushEscaped(cec_frame &vec, uint8_t byte);
   private:
-    void AddData(uint8_t *data, int iLen);
-    bool ReadFromDevice(int iTimeout);
+    void AddData(uint8_t *data, uint8_t iLen);
+    bool ReadFromDevice(uint32_t iTimeout);
 
     CSerialPort *        m_port;
-    CCECParser *         m_parser;
+    CLibCEC *            m_controller;
     uint8_t*             m_inbuf;
-    int                  m_iInbufSize;
-    int                  m_iInbufUsed;
+    int16_t              m_iInbufSize;
+    int16_t              m_iInbufUsed;
     bool                 m_bStarted;
     bool                 m_bStop;
-    CMutex               m_commMutex;
-    CMutex               m_bufferMutex;
-    CCondition           m_condition;
+    CMutex               m_mutex;
+    CCondition           m_rcvCondition;
   };
 };