refs bug #485
[enigma2.git] / lib / dvb_ci / dvbci_session.h
index dd123eee601bc1f3595aefaa801c70b2db0c6f12..89a58f3b504351248185b2948d4cddffb2ac8a9e 100644 (file)
@@ -2,15 +2,17 @@
 #define __dvbci_dvbci_tc_h
 
 #include <lib/base/ebase.h>
+#include <lib/base/object.h>
 #include <lib/dvb_ci/dvbci.h>
 
 #define SLMS   256
 
 class eDVBCISession
 {
-       static eDVBCISession *sessions[SLMS];
-       static eDVBCISession *eDVBCISession::createSession(eDVBCISlot *slot, const unsigned char *resource_identifier, unsigned char &status);
-       static void eDVBCISession::sendSPDU(eDVBCISlot *slot, unsigned char tag,const void *data, int len, unsigned short session_nb, const void *apdu=0,int alen=0);
+       DECLARE_REF(eDVBCISession);
+       static ePtr<eDVBCISession> sessions[SLMS];
+       static void createSession(eDVBCISlot *slot, const unsigned char *resource_identifier, unsigned char &status, ePtr<eDVBCISession> &ptr);
+       static void sendSPDU(eDVBCISlot *slot, unsigned char tag,const void *data, int len, unsigned short session_nb, const void *apdu=0,int alen=0);
        static void sendOpenSessionResponse(eDVBCISlot *slot,unsigned char session_status, const unsigned char *resource_identifier,unsigned short session_nb);
        void recvCreateSessionResponse(const unsigned char *data);
        void recvCloseSessionRequest(const unsigned char *data);
@@ -21,9 +23,16 @@ protected:
        eDVBCISlot *slot;               //base only
        unsigned short session_nb;
        virtual int receivedAPDU(const unsigned char *tag, const void *data, int len) = 0;
-       void eDVBCISession::sendAPDU(const unsigned char *tag, const void *data=0,int len=0);
-       void eDVBCISession::sendSPDU(unsigned char tag, const void *data, int len,const void *apdu=0, int alen=0);
+       void sendAPDU(const unsigned char *tag, const void *data=0,int len=0);
+       void sendSPDU(unsigned char tag, const void *data, int len,const void *apdu=0, int alen=0);
+       virtual int doAction()=0;
+       void handleClose();
 public:
+       virtual ~eDVBCISession();
+
+       static void deleteSessions(const eDVBCISlot *slot);
+
+       int poll() { if (action) { action=doAction(); return 1; } return 0; }
        enum { stateInCreation, stateBusy, stateInDeletion, stateStarted, statePrivate};
        
        static int parseLengthField(const unsigned char *pkt, int &len);
@@ -33,6 +42,9 @@ public:
        
        int getState() { return state; }
        int getStatus() { return status; }
+       
+       static int pollAll();
+       
 };
 
 #endif