X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2e0270746af934180499931f95ed91c444c8233e..4e6bb28e14b621f0e818db84150522549dc7b6d4:/lib/dvb/dvb.h diff --git a/lib/dvb/dvb.h b/lib/dvb/dvb.h index 2fca347d..bceb9ad0 100644 --- a/lib/dvb/dvb.h +++ b/lib/dvb/dvb.h @@ -107,7 +107,7 @@ public: virtual RESULT getDemux(ePtr &demux, int nr) = 0; virtual int getNumFrontends() = 0; - virtual RESULT getFrontend(ePtr &fe, int nr) = 0; + virtual RESULT getFrontend(ePtr &fe, int nr, bool simulate=false) = 0; }; class eDVBAdapterLinux: public iDVBAdapter @@ -120,12 +120,12 @@ public: RESULT getDemux(ePtr &demux, int nr); int getNumFrontends(); - RESULT getFrontend(ePtr &fe, int nr); + RESULT getFrontend(ePtr &fe, int nr, bool simulate=false); static int exist(int nr); private: int m_nr; - eSmartPtrList m_frontend; + eSmartPtrList m_frontend, m_simulate_frontend; eSmartPtrList m_demux; }; #endif // SWIG @@ -137,26 +137,10 @@ class eDVBResourceManager: public iObject, public Object int avail, busy; eSmartPtrList m_adapter; - eSmartPtrList m_demux; - eSmartPtrList m_frontend; - + eSmartPtrList m_frontend, m_simulate_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; @@ -166,7 +150,7 @@ class eDVBResourceManager: public iObject, public Object active_channel(const eDVBChannelID &chid, eDVBChannel *ch) : m_channel_id(chid), m_channel(ch) { } }; - std::list m_active_channels; + std::list m_active_channels, m_active_simulate_channels; ePtr m_list; ePtr m_sec; @@ -178,8 +162,6 @@ 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; @@ -209,12 +191,26 @@ public: int canAllocateChannel(const eDVBChannelID &channelid, const eDVBChannelID &ignore); /* allocate channel... */ - RESULT allocateChannel(const eDVBChannelID &channelid, eUsePtr &channel); + RESULT allocateChannel(const eDVBChannelID &channelid, eUsePtr &channel, bool simulate=false); 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, bool simulate=false); + + 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);