X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/7fd4f3d49a6d2f93cae4769cf8678358ebd1abce..4b8b88b747f1229b3538320d934d686e0d71e812:/lib/dvb/pmt.h diff --git a/lib/dvb/pmt.h b/lib/dvb/pmt.h index 136c1673..bfef5b46 100644 --- a/lib/dvb/pmt.h +++ b/lib/dvb/pmt.h @@ -1,24 +1,61 @@ #ifndef __lib_dvb_dvbmid_h #define __lib_dvb_dvbmid_h +#include #include #include #include #include -#include -#include +#include +#include + +#include +#include +#include +#include +#include + +class eDVBServicePMTHandler; + +typedef std::map CAServiceMap; + +class eDVBCAService: public Object +{ + eServiceReferenceDVB m_service; + uint8_t m_used_demux[10]; + unsigned int m_prev_build_hash; + + int m_sock, m_clilen; + struct sockaddr_un m_servaddr; + unsigned int m_sendstate; + unsigned char m_capmt[2048]; + eTimer m_retryTimer; + void sendCAPMT(); + void Connect(); + + static CAServiceMap exist; + eDVBCAService(); + ~eDVBCAService(); +public: + static RESULT register_demux( const eServiceReferenceDVB &ref, int demux_num, eDVBCAService *&caservice ); + static RESULT unregister_demux( const eServiceReferenceDVB &ref, int demux_num, eTable *ptr ); + void buildCAPMT(eTable *ptr); +}; 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; + eDVBCAService *m_ca_servicePtr; + + eAUTable > m_PMT; + eAUTable > m_PAT; - ePtr m_channel; + eUsePtr m_channel; + eUsePtr m_pvr_channel; ePtr m_resourceManager; ePtr m_demux; @@ -27,12 +64,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) @@ -61,10 +102,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); };