enable TS when appmanager is ready
[enigma2.git] / lib / dvb_ci / dvbci.cpp
index 8f1fcac92c6ad7f1aef3cc8179ef36a747deea5c..a4bc4ff3d3f6f8cb26756983cf356e05cc6170f6 100644 (file)
@@ -76,6 +76,16 @@ int eDVBCIInterfaces::reset(int slotid)
        return slot->reset();
 }
 
+int eDVBCIInterfaces::enableTS(int slotid, int enable)
+{
+       eDVBCISlot *slot;
+
+       if( (slot = getSlot(slotid)) == 0 )
+               return -1;
+       
+       return slot->enableTS(enable);
+}
+
 int eDVBCIInterfaces::initialize(int slotid)
 {
        eDVBCISlot *slot;
@@ -253,6 +263,7 @@ void eDVBCISlot::data(int what)
        if(what == eSocketNotifier::Priority) {
                if(state != stateRemoved) {
                        state = stateRemoved;
+                       enableTS(0);
                        printf("ci removed\n");
                        notifier->setRequested(eSocketNotifier::Read);
                        //HACK
@@ -327,6 +338,7 @@ eDVBCISlot::eDVBCISlot(eMainloop *context, int nr)
 
 eDVBCISlot::~eDVBCISlot()
 {
+       enableTS(0);
 }
 
 int eDVBCISlot::getSlotID()
@@ -338,6 +350,8 @@ int eDVBCISlot::reset()
 {
        printf("edvbcislot: reset requested\n");
 
+       enableTS(0);
+
        ioctl(fd, 0);
 
        return 0;
@@ -472,4 +486,22 @@ int eDVBCISlot::sendCAPMT(eDVBServicePMTHandler *pmthandler, const std::vector<u
        
 }
 
+int eDVBCISlot::enableTS(int enable)
+{
+       printf("eDVBCISlot::enableTS(%d)\n", enable);
+
+       FILE *f;
+       if((f = fopen("/proc/stb/tsmux/input0", "wb")) == NULL) {
+               printf("cannot open /proc/stb/audio/j1_mute\n");
+               return;
+       }
+
+       fprintf(f, "%s", enable?"CI":"A");
+
+       fclose(f);
+
+       return 0;
+}
+
+
 eAutoInitP0<eDVBCIInterfaces> init_eDVBCIInterfaces(eAutoInitNumbers::dvb, "CI Slots");