X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d63d2c3c6cbbd574dda4f8b00ebe6c661735edd5..cae001777c7b32bdb4f6f4199e9f49058946fe9f:/lib/dvb/pmt.h diff --git a/lib/dvb/pmt.h b/lib/dvb/pmt.h index ee2040af..a60f37b2 100644 --- a/lib/dvb/pmt.h +++ b/lib/dvb/pmt.h @@ -2,23 +2,63 @@ #define __lib_dvb_dvbmid_h #include -#include +#include +#include #include -#include -#include +#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; + ePtr m_service; int m_last_channel_state; - - eAUTable > m_PMT; - eAUTable > m_PAT; + uint16_t m_pmt_pid; + eDVBCAService *m_ca_servicePtr; - ePtr m_channel; - ePtr m_resourceManager; + eAUTable > m_PMT; + eAUTable > m_PAT; + + eUsePtr m_channel; + eUsePtr m_pvr_channel; + ePtr m_resourceManager; ePtr m_demux; void channelStateChanged(iDVBChannel *); @@ -26,17 +66,21 @@ 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) - eventNewProgramInfo // we just received a PMT + eventNewProgramInfo, // we just received a PMT + eventTuned // a channel was sucessfully (re-)tuned in, you may start additional filters now }; Signal1 serviceEvent; @@ -60,10 +104,12 @@ public: std::vector audioStreams; // ca info int pcrPid; + int pmtPid; }; int getProgramInfo(struct program &program); int getDemux(ePtr &demux); + int getPVRChannel(ePtr &pvr_channel); int tune(eServiceReferenceDVB &ref); };