X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/8d8294b4b354436adde202604fffb55c181d686c..b44cb0f9a39ba6c319dc5f89439e52c93f3a0f23:/lib/dvb/pmt.h diff --git a/lib/dvb/pmt.h b/lib/dvb/pmt.h index 2d47852f..a60f37b2 100644 --- a/lib/dvb/pmt.h +++ b/lib/dvb/pmt.h @@ -8,13 +8,51 @@ #include #include +#include +#include +#include +#include +#include + +class eDVBServicePMTHandler; + +class eDVBCAService: public Object +{ + eDVBServicePMTHandler &m_parent; + int m_sock, m_clilen; + struct sockaddr_un m_servaddr; + unsigned int m_sendstate; + unsigned char *m_capmt; + eTimer m_retryTimer; + void sendCAPMT(); + void Connect(); +public: + eDVBCAService( eDVBServicePMTHandler &parent ) + :m_parent(parent), m_sendstate(0), m_capmt(NULL), m_retryTimer(eApp) + { + CONNECT(m_retryTimer.timeout, eDVBCAService::sendCAPMT); + Connect(); +// eDebug("[eDVBCAHandler] new service %s", service.toString().c_str() ); + } + ~eDVBCAService() + { + delete [] m_capmt; + ::close(m_sock); +// eDebug("[eDVBCAHandler] leave service %s", me.toString().c_str() ); + } + void buildCAPMT(); +}; + class eDVBServicePMTHandler: public Object { + friend class eDVBCAService; eServiceReferenceDVB m_reference; ePtr m_service; int m_last_channel_state; - + uint16_t m_pmt_pid; + eDVBCAService *m_ca_servicePtr; + eAUTable > m_PMT; eAUTable > m_PAT; @@ -28,12 +66,16 @@ class eDVBServicePMTHandler: public Object void PMTready(int error); void PATready(int error); + + int m_record; public: - eDVBServicePMTHandler(); + eDVBServicePMTHandler(int record); + ~eDVBServicePMTHandler(); enum { eventNoResources, // a requested resource couldn't be allocated + eventTuneFailed, // tune failed eventNoPAT, // no pat could be received (timeout) eventNoPATEntry, // no pat entry for the corresponding SID could be found eventNoPMT, // no pmt could be received (timeout) @@ -62,6 +104,7 @@ public: std::vector audioStreams; // ca info int pcrPid; + int pmtPid; }; int getProgramInfo(struct program &program);