X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/b2eebd0fef155a40a8a74468c4488cfb0c656a9a..bef9bfb55955648b877b743c793b9d79a5a7bfe5:/lib/dvb/dvb.h diff --git a/lib/dvb/dvb.h b/lib/dvb/dvb.h index f36e6f67..04543ae2 100644 --- a/lib/dvb/dvb.h +++ b/lib/dvb/dvb.h @@ -23,19 +23,22 @@ class eDVBRegisteredFrontend: public iObject, public Object { DECLARE_REF(eDVBRegisteredFrontend); eTimer *disable; - Signal0 stateChanged; void closeFrontend() { if (!m_inuse && m_frontend->closeFrontend()) // frontend busy disable->start(60000, true); // retry close in 60secs } public: + Signal0 stateChanged; eDVBRegisteredFrontend(eDVBFrontend *fe, iDVBAdapter *adap) :disable(new eTimer(eApp)), m_adapter(adap), m_frontend(fe), m_inuse(0) { - disable = new eTimer(eApp); CONNECT(disable->timeout, eDVBRegisteredFrontend::closeFrontend); } + ~eDVBRegisteredFrontend() + { + delete disable; + } void dec_use() { if (!--m_inuse) @@ -59,7 +62,7 @@ public: struct eDVBRegisteredDemux { -DECLARE_REF(eDVBRegisteredDemux); + DECLARE_REF(eDVBRegisteredDemux); public: iDVBAdapter *m_adapter; ePtr m_demux; @@ -69,7 +72,7 @@ public: class eDVBAllocatedFrontend { -DECLARE_REF(eDVBAllocatedFrontend); + DECLARE_REF(eDVBAllocatedFrontend); public: eDVBAllocatedFrontend(eDVBRegisteredFrontend *fe); @@ -84,7 +87,7 @@ private: class eDVBAllocatedDemux { -DECLARE_REF(eDVBAllocatedDemux); + DECLARE_REF(eDVBAllocatedDemux); public: eDVBAllocatedDemux(eDVBRegisteredDemux *demux); @@ -109,7 +112,7 @@ public: class eDVBAdapterLinux: public iDVBAdapter { -DECLARE_REF(eDVBAdapterLinux); + DECLARE_REF(eDVBAdapterLinux); public: eDVBAdapterLinux(int nr); @@ -134,26 +137,10 @@ class eDVBResourceManager: public iObject, public Object int avail, busy; eSmartPtrList m_adapter; - eSmartPtrList m_demux; eSmartPtrList m_frontend; - void addAdapter(iDVBAdapter *adapter); - - /* allocates a frontend able to tune to frontend paramters 'feperm'. - the frontend must be tuned lateron. there is no guarante - that tuning will succeed - it just means that if this frontend - can't tune, no other frontend could do it. - - there might be a priority given to certain frontend/chid - combinations. this will be evaluated here. */ - - RESULT allocateFrontend(ePtr &fe, ePtr &feparm); - RESULT allocateFrontendByIndex(ePtr &fe, int slot_index); - - /* allocate a demux able to filter on the selected frontend. */ - RESULT allocateDemux(eDVBRegisteredFrontend *fe, ePtr &demux, int cap); - + struct active_channel { eDVBChannelID m_channel_id; @@ -175,17 +162,15 @@ class eDVBResourceManager: public iObject, public Object Signal1 m_channelAdded; - int canAllocateFrontend(ePtr &feparm); - eUsePtr m_cached_channel; Connection m_cached_channel_state_changed_conn; eTimer m_releaseCachedChannelTimer; void DVBChannelStateChanged(iDVBChannel*); - void releaseCachedChannel(); void feStateChanged(); #ifndef SWIG public: #endif + void releaseCachedChannel(); eDVBResourceManager(); virtual ~eDVBResourceManager(); @@ -193,9 +178,13 @@ public: RESULT getChannelList(ePtr &list); enum { - errNoFrontend = -1, + /* errNoFrontend = -1 replaced by more spcific messages */ errNoDemux = -2, - errChidNotFound = -3 + errChidNotFound = -3, + errNoChannelList = -4, + errChannelNotInList = -5, + errAllSourcesBusy = -6, + errNoSourceFound = -7, }; RESULT connectChannelAdded(const Slot1 &channelAdded, ePtr &connection); @@ -205,12 +194,27 @@ public: RESULT allocateChannel(const eDVBChannelID &channelid, eUsePtr &channel); RESULT allocatePVRChannel(eUsePtr &channel); static RESULT getInstance(ePtr &); + + /* allocates a frontend able to tune to frontend paramters 'feperm'. + the frontend must be tuned lateron. there is no guarante + that tuning will succeed - it just means that if this frontend + can't tune, no other frontend could do it. + + there might be a priority given to certain frontend/chid + combinations. this will be evaluated here. */ + RESULT allocateFrontend(ePtr &fe, ePtr &feparm); + + RESULT allocateFrontendByIndex(ePtr &fe, int slot_index); + /* allocate a demux able to filter on the selected frontend. */ + RESULT allocateDemux(eDVBRegisteredFrontend *fe, ePtr &demux, int cap); #ifdef SWIG public: #endif + int canAllocateFrontend(ePtr &feparm); + bool canMeasureFrontendInputPower(); PSignal1 frontendUseMaskChanged; SWIG_VOID(RESULT) allocateRawChannel(eUsePtr &SWIG_OUTPUT, int slot_index); - void setFrontendSlotInformations(SWIG_PYOBJECT(ePyObject) list); + PyObject *setFrontendSlotInformations(SWIG_PYOBJECT(ePyObject) list); }; SWIG_TEMPLATE_TYPEDEF(ePtr, eDVBResourceManager); SWIG_EXTEND(ePtr,