X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/8d8294b4b354436adde202604fffb55c181d686c..319b1d154578f02388b6a7910c5048ed3bab1343:/lib/dvb/pmt.h diff --git a/lib/dvb/pmt.h b/lib/dvb/pmt.h index 2d47852f..79d7917c 100644 --- a/lib/dvb/pmt.h +++ b/lib/dvb/pmt.h @@ -1,6 +1,7 @@ #ifndef __lib_dvb_dvbmid_h #define __lib_dvb_dvbmid_h +#include #include #include #include @@ -8,13 +9,48 @@ #include #include +#include +#include +#include +#include +#include + +class eDVBCAService; + +typedef std::map CAServiceMap; + +class eDVBCAService: public Object +{ + eServiceReferenceDVB m_service; + uint8_t m_used_demux[32]; + 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_service( const eServiceReferenceDVB &ref, int demux_nums[2], eDVBCAService *&caservice ); + static RESULT unregister_service( const eServiceReferenceDVB &ref, int demux_nums[2], eTable *ptr ); + void buildCAPMT(eTable *ptr); +}; + class eDVBServicePMTHandler: public Object { + friend class eDVBCAService; eServiceReferenceDVB m_reference; ePtr m_service; int m_last_channel_state; - + eDVBCAService *m_ca_servicePtr; + eAUTable > m_PMT; eAUTable > m_PAT; @@ -25,27 +61,39 @@ class eDVBServicePMTHandler: public Object void channelStateChanged(iDVBChannel *); ePtr m_channelStateChanged_connection; + void channelEvent(iDVBChannel *, int event); + ePtr m_channelEvent_connection; void PMTready(int error); void PATready(int error); + + int m_use_decode_demux; + uint8_t m_decode_demux_num; + public: eDVBServicePMTHandler(); + ~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 - eventTuned // a channel was sucessfully (re-)tuned in, you may start additional filters now + eventTuned, // a channel was sucessfully (re-)tuned in, you may start additional filters now + + eventSOF, // seek pre start + eventEOF, // a file playback did end }; Signal1 serviceEvent; - + struct videoStream { int pid; + int component_tag; }; struct audioStream @@ -53,7 +101,9 @@ public: int pid; enum { atMPEG, atAC3, atDTS }; int type; // mpeg2, ac3, dts, ... - // language code, ... + + int component_tag; + std::string language_code; /* iso-639, if available. */ }; struct program @@ -62,13 +112,24 @@ public: std::vector audioStreams; // ca info int pcrPid; + int pmtPid; + int textPid; + bool isCrypted; }; int getProgramInfo(struct program &program); - int getDemux(ePtr &demux); + int getDataDemux(ePtr &demux); + int getDecodeDemux(ePtr &demux); + int getPVRChannel(ePtr &pvr_channel); + int getService(eServiceReferenceDVB &service) { service = m_reference; return 0; } + int getPMT(ePtr > &ptr) { return m_PMT.getCurrent(ptr); } + int getChannel(eUsePtr &channel); + + int tune(eServiceReferenceDVB &ref, int use_decode_demux, eCueSheet *sg=0); + void free(); - int tune(eServiceReferenceDVB &ref); + int m_pmt_pid; }; #endif