if( (slot = getSlot(slotid)) == 0 )
return -1;
-
+
+ eDVBCISession::deleteSessions(slot);
+
return slot->reset();
}
if( (slot = getSlot(slotid)) == 0 )
return -1;
-
- return slot->enableTS(enable);
+
+ int tunernum = 0;
+ if (enable)
+ {
+ PMTHandlerList::iterator it = m_pmt_handlers.begin();
+ while (it != m_pmt_handlers.end())
+ {
+ if ( it->cislot == slot )
+ {
+ eDVBServicePMTHandler *pmthandler = it->pmthandler;
+ eUsePtr<iDVBChannel> channel;
+ if (!pmthandler->getChannel(channel))
+ {
+ ePtr<iDVBFrontend> frontend;
+ if (!channel->getFrontend(frontend))
+ {
+ eDVBFrontend *fe = (eDVBFrontend*) &(*frontend);
+ tunernum = fe->getID();
+ }
+ }
+ break;
+ }
+ ++it;
+ }
+ }
+ return slot->enableTS(enable, tunernum);
}
int eDVBCIInterfaces::initialize(int slotid)
if( (slot = getSlot(slotid)) == 0 )
return -1;
-
+
+ slot->resetPrevSentCAPMTVersion();
+ PMTHandlerList::iterator it = m_pmt_handlers.begin();
+ while (it != m_pmt_handlers.end())
+ {
+ if ( it->cislot == slot )
+ {
+ slot->sendCAPMT(it->pmthandler); // send capmt
+ break;
+ }
+ ++it;
+ }
+
return slot->initialize();
}
+int eDVBCIInterfaces::sendCAPMT(int slotid)
+{
+ eDVBCISlot *slot;
+
+ if( (slot = getSlot(slotid)) == 0 )
+ return -1;
+
+ slot->resetPrevSentCAPMTVersion();
+ PMTHandlerList::iterator it = m_pmt_handlers.begin();
+ while (it != m_pmt_handlers.end())
+ {
+ if ( it->cislot == slot )
+ {
+ slot->sendCAPMT(it->pmthandler); // send capmt
+ return 0;
+ }
+ ++it;
+ }
+
+ return -1;
+}
+
int eDVBCIInterfaces::startMMI(int slotid)
{
eDVBCISlot *slot;
if (it != m_pmt_handlers.end())
{
eDVBCISlot *slot = it->cislot;
- eDVBServicePMTHandler *pmthandler = it->pmthandler;
+// eDVBServicePMTHandler *pmthandler = it->pmthandler;
m_pmt_handlers.erase(it);
if (slot && !--slot->use_count)
{
state = stateRemoved;
enableTS(0);
printf("ci removed\n");
+ eDVBCISession::deleteSessions(this);
notifier->setRequested(eSocketNotifier::Read);
//HACK
eDVBCI_UI::getInstance()->setState(0,0);
enableTS(0);
}
+void eDVBCISlot::setAppManager( eDVBCIApplicationManagerSession *session )
+{
+ application_manager=session;
+}
+
+void eDVBCISlot::setMMIManager( eDVBCIMMISession *session )
+{
+ mmi_session = session;
+}
+
+void eDVBCISlot::setCAManager( eDVBCICAManagerSession *session )
+{
+ ca_manager = session;
+}
+
int eDVBCISlot::getSlotID()
{
return slotid;
int eDVBCISlot::answerEnq(char *value)
{
printf("edvbcislot: answerENQ(%s)\n", value);
+
+ if(mmi_session)
+ mmi_session->answerEnq(value);
+
return 0;
}
int eDVBCISlot::sendCAPMT(eDVBServicePMTHandler *pmthandler, const std::vector<uint16_t> &ids)
{
- const std::vector<uint16_t> &caids = ids.empty() && ca_manager ? ca_manager->getCAIDs() : ids;
+ if (!ca_manager)
+ {
+ eDebug("no ca_manager (no CI plugged?)");
+ return -1;
+ }
+ const std::vector<uint16_t> &caids = ids.empty() ? ca_manager->getCAIDs() : ids;
ePtr<eTable<ProgramMapSection> > ptr;
if (pmthandler->getPMT(ptr))
return -1;
hlen = 4;
}
// end calc capmt length
- if (!ca_manager)
- eDebug("no ca_manager !!! dump unfiltered capmt:");
- else
- eDebug("ca_manager %p dump capmt:", ca_manager);
+ eDebug("ca_manager %p dump capmt:", ca_manager);
for(int i=0;i<wp;i++)
eDebugNoNewLine("%02x ", raw_data[i]);
eDebug("");
#endif
- if (ca_manager)
- {
- //dont need tag and lenfield
- ca_manager->sendCAPMT(raw_data + hlen, wp - hlen);
- prev_sent_capmt_version = pmt_version;
- }
+ //dont need tag and lenfield
+ ca_manager->sendCAPMT(raw_data + hlen, wp - hlen);
+ prev_sent_capmt_version = pmt_version;
}
}
-
+ return 0;
}
-int eDVBCISlot::enableTS(int enable)
+int eDVBCISlot::enableTS(int enable, int tuner)
{
- printf("eDVBCISlot::enableTS(%d)\n", enable);
+ printf("eDVBCISlot::enableTS(%d %d)\n", enable, tuner);
- FILE *f;
- if((f = fopen("/proc/stb/tsmux/input0", "wb")) == NULL) {
- printf("cannot open /proc/stb/audio/j1_mute\n");
+ FILE *input0, *input1, *ci;
+ if((input0 = fopen("/proc/stb/tsmux/input0", "wb")) == NULL) {
+ printf("cannot open /proc/stb/tsmux/input0\n");
+ return 0;
+ }
+ if((input1 = fopen("/proc/stb/tsmux/input1", "wb")) == NULL) {
+ printf("cannot open /proc/stb/tsmux/input1\n");
+ return 0;
+ }
+ if((ci = fopen("/proc/stb/tsmux/input2", "wb")) == NULL) {
+ printf("cannot open /proc/stb/tsmux/input2\n");
return 0;
}
- fprintf(f, "%s", enable?"CI":"A");
-
- fclose(f);
+ fprintf(ci, "%s", tuner==0 ? "A" : "B"); // configure CI data source (TunerA, TunerB)
+ fprintf(input0, "%s", tuner==0 && enable ? "CI" : "A"); // configure ATI input 0 data source
+ fprintf(input1, "%s", tuner==1 && enable ? "CI" : "B"); // configure ATI input 1 data source
+ fclose(input0);
+ fclose(input1);
+ fclose(ci);
return 0;
}
+void eDVBCISlot::resendCAPMT()
+{
+ eDVBCIInterfaces::getInstance()->sendCAPMT(slotid);
+}
eAutoInitP0<eDVBCIInterfaces> init_eDVBCIInterfaces(eAutoInitNumbers::dvb, "CI Slots");