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)
state = stateRemoved;
enableTS(0);
printf("ci removed\n");
+ eDVBCISession::deleteSessions(this);
notifier->setRequested(eSocketNotifier::Read);
//HACK
eDVBCI_UI::getInstance()->setState(0,0);
int eDVBCISlot::answerEnq(char *value)
{
printf("edvbcislot: answerENQ(%s)\n", value);
+
+ if(mmi_session)
+ mmi_session->answerEnq(value);
+
return 0;
}
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) {
+ 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;
}