X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fdvb_ci%2Fdvbci.h;h=c11a1203311ab32fd828a29963252cedb55b5414;hp=2ef70b0e83eab137e1609e72467670819e32dec8;hb=1eae3427009157fd382ca360f8d89593225272c8;hpb=75db34c299094d2ae87941ed464e8efa79848e16 diff --git a/lib/dvb_ci/dvbci.h b/lib/dvb_ci/dvbci.h index 2ef70b0..c11a120 100644 --- a/lib/dvb_ci/dvbci.h +++ b/lib/dvb_ci/dvbci.h @@ -1,8 +1,11 @@ #ifndef __dvbci_dvbci_h #define __dvbci_dvbci_h -#include +#ifndef SWIG +#include +#include +#include #include #include @@ -12,6 +15,7 @@ class eDVBCICAManagerSession; class eDVBCIMMISession; class eDVBServicePMTHandler; class eDVBCISlot; +class eDVBCIInterfaces; struct queueData { @@ -29,25 +33,41 @@ struct queueData } }; +enum data_source +{ + TUNER_A, TUNER_B, TUNER_C, TUNER_D, CI_A, CI_B, CI_C, CI_D +}; + +typedef std::pair providerPair; +typedef std::set providerSet; +typedef std::set caidSet; +typedef std::set serviceSet; + class eDVBCISlot: public iObject, public Object { -DECLARE_REF(eDVBCISlot); -private: + friend class eDVBCIInterfaces; + DECLARE_REF(eDVBCISlot); int slotid; int fd; - void data(int); - eSocketNotifier *notifier; - + ePtr notifier; int state; std::map running_services; eDVBCIApplicationManagerSession *application_manager; eDVBCICAManagerSession *ca_manager; eDVBCIMMISession *mmi_session; std::priority_queue sendqueue; + caidSet possible_caids; + serviceSet possible_services; + providerSet possible_providers; + int use_count; + eDVBCISlot *linked_next; // needed for linked CI handling + data_source current_source; + int current_tuner; + bool user_mapped; + void data(int); + bool first_plugged; public: enum {stateRemoved, stateInserted, stateInvalid, stateResetted}; - int use_count; - eDVBCISlot(eMainloop *context, int nr); ~eDVBCISlot(); @@ -73,9 +93,7 @@ public: int sendCAPMT(eDVBServicePMTHandler *ptr, const std::vector &caids=std::vector()); void removeService(uint16_t program_number=0xFFFF); int getNumOfServices() { return running_services.size(); } - - int enableTS(int enable, int tuner=0); - + int setSource(data_source source); }; struct CIPmtHandler @@ -96,16 +114,18 @@ struct CIPmtHandler typedef std::list PMTHandlerList; +#endif // SWIG + class eDVBCIInterfaces { -DECLARE_REF(eDVBCIInterfaces); + DECLARE_REF(eDVBCIInterfaces); static eDVBCIInterfaces *instance; -private: eSmartPtrList m_slots; eDVBCISlot *getSlot(int slotid); - PMTHandlerList m_pmt_handlers; +#ifndef SWIG public: +#endif eDVBCIInterfaces(); ~eDVBCIInterfaces(); @@ -114,9 +134,8 @@ public: void recheckPMTHandlers(); void gotPMT(eDVBServicePMTHandler *pmthandler); void ciRemoved(eDVBCISlot *slot); + int getSlotState(int slot); - static eDVBCIInterfaces *getInstance(); - int reset(int slot); int initialize(int slot); int startMMI(int slot); @@ -125,8 +144,16 @@ public: int answerEnq(int slot, char *value); int cancelEnq(int slot); int getMMIState(int slot); - int enableTS(int slot, int enable); int sendCAPMT(int slot); + int setInputSource(int tunerno, data_source source); +#ifdef SWIG +public: +#endif + static eDVBCIInterfaces *getInstance(); + int getNumOfSlots() { return m_slots.size(); } + PyObject *getDescrambleRules(int slotid); + RESULT setDescrambleRules(int slotid, SWIG_PYOBJECT(ePyObject) ); + PyObject *readCICaIds(int slotid); }; #endif