From: Ronny Strutz Date: Fri, 12 Aug 2005 20:10:16 +0000 (+0000) Subject: add the missing ca-mgr code ;) X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=commitdiff_plain;h=640fa7fc2dab8135f04952e3dec9abd1d715a328 add the missing ca-mgr code ;) --- diff --git a/lib/dvb_ci/dvbci.h b/lib/dvb_ci/dvbci.h index 78c1cc8..b72b21b 100644 --- a/lib/dvb_ci/dvbci.h +++ b/lib/dvb_ci/dvbci.h @@ -4,6 +4,8 @@ #include class eDVBCISession; +class eDVBCIApplicationManagerSession; +class eDVBCICAManagerSession; class eDVBCISlot: public iObject, public Object { @@ -22,6 +24,9 @@ public: virtual ~eDVBCISlot(); int eDVBCISlot::write(const unsigned char *data, size_t len); + + eDVBCIApplicationManagerSession *application_manager; + eDVBCICAManagerSession *ca_manager; }; class eDVBCIInterfaces diff --git a/lib/dvb_ci/dvbci_camgr.cpp b/lib/dvb_ci/dvbci_camgr.cpp index eb30c41..2ad1f1e 100644 --- a/lib/dvb_ci/dvbci_camgr.cpp +++ b/lib/dvb_ci/dvbci_camgr.cpp @@ -2,3 +2,48 @@ #include +int eDVBCICAManagerSession::receivedAPDU(const unsigned char *tag, const void *data, int len) +{ + printf("SESSION(%d)/CA %02x %02x %02x: ", session_nb, tag[0], tag[1],tag[2]); + for (int i=0; i #include +#include +#include int eDVBCISession::buildLengthField(unsigned char *pkt, int len) { @@ -54,6 +56,11 @@ void eDVBCISession::sendAPDU(const unsigned char *tag, const void *data, int len sendSPDU(0x90, 0, 0, pkt, len+3+l); } +void eDVBCISession::sendSPDU(unsigned char tag, const void *data, int len, const void *apdu, int alen) +{ + sendSPDU(slot, tag, data, len, session_nb, apdu, alen); +} + void eDVBCISession::sendSPDU(eDVBCISlot *slot, unsigned char tag, const void *data, int len, unsigned short session_nb, const void *apdu,int alen) { unsigned char pkt[4096]; @@ -123,11 +130,11 @@ eDVBCISession *eDVBCISession::createSession(eDVBCISlot *slot, const unsigned cha printf("RESOURCE MANAGER\n"); break; case 0x00020041: -// session=eDVBCIModule::getInstance()->application_manager = new eDVBCIApplicationManagerSession; + session=slot->application_manager = new eDVBCIApplicationManagerSession; printf("APPLICATION MANAGER\n"); break; case 0x00030041: -// session=eDVBCIModule::getInstance()->ca_manager=new eDVBCICAManagerSession; + session=slot->ca_manager=new eDVBCICAManagerSession; printf("CA MANAGER\n"); break; case 0x00240041: diff --git a/lib/dvb_ci/dvbci_session.h b/lib/dvb_ci/dvbci_session.h index 5f95ee8..dd123ee 100644 --- a/lib/dvb_ci/dvbci_session.h +++ b/lib/dvb_ci/dvbci_session.h @@ -22,6 +22,7 @@ protected: 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); public: enum { stateInCreation, stateBusy, stateInDeletion, stateStarted, statePrivate};