fixes for old api.. not all tested..
[enigma2.git] / lib / dvb / demux.cpp
index e1d8bbaf7b4d6aae9389dcbcb1a110d0fd8ed82d..286821c318992999b4716d73cd4a841d7232cc52 100644 (file)
@@ -1,10 +1,16 @@
+#include <config.h>
 #include <stdio.h>
 #include <fcntl.h>
 #include <sys/ioctl.h>
 #include <errno.h>
 #include <unistd.h>
 
+#if HAVE_DVB_API_VERSION < 3
+#include <ost/dmx.h>
+#else
 #include <linux/dvb/dmx.h>
+#endif
+
 #include "crc32.h"
 
 #include <lib/base/eerror.h>
@@ -13,7 +19,7 @@
 #include <lib/dvb/esection.h>
 #include <lib/dvb/decoder.h>
 
-eDVBDemux::eDVBDemux(int adapter, int demux): adapter(adapter), demux(demux), ref(0)
+eDVBDemux::eDVBDemux(int adapter, int demux): adapter(adapter), demux(demux)
 {
 }
 
@@ -58,10 +64,14 @@ void eDVBSectionReader::data(int)
        read(data);
 }
 
-eDVBSectionReader::eDVBSectionReader(eDVBDemux *demux, eMainloop *context, RESULT &res): ref(0), demux(demux)
+eDVBSectionReader::eDVBSectionReader(eDVBDemux *demux, eMainloop *context, RESULT &res): demux(demux)
 {
        char filename[128];
+#if HAVE_DVB_API_VERSION < 3
+       sprintf(filename, "/dev/dvb/card%d/demux%d", demux->adapter, demux->demux);
+#else
        sprintf(filename, "/dev/dvb/adapter%d/demux%d", demux->adapter, demux->demux);
+#endif
        fd = ::open(filename, O_RDWR);
        
        if (fd >= 0)
@@ -92,11 +102,18 @@ RESULT eDVBSectionReader::start(const eDVBSectionFilterMask &mask)
        if (fd < 0)
                return -ENODEV;
 
+#if HAVE_DVB_API_VERSION < 3
+       dmxSctFilterParams sct;
+#else
        dmx_sct_filter_params sct;
-       
+#endif
        sct.pid     = mask.pid;
        sct.timeout = 0;
+#if HAVE_DVB_API_VERSION < 3
+       sct.flags   = 0;
+#else
        sct.flags   = DMX_IMMEDIATE_START;
+#endif
        if (mask.flags & eDVBSectionFilterMask::rfCRC)
        {
                sct.flags |= DMX_CHECK_CRC;
@@ -106,11 +123,25 @@ RESULT eDVBSectionReader::start(const eDVBSectionFilterMask &mask)
        
        memcpy(sct.filter.filter, mask.data, DMX_FILTER_SIZE);
        memcpy(sct.filter.mask, mask.mask, DMX_FILTER_SIZE);
+#if HAVE_DVB_API_VERSION >= 3
        memcpy(sct.filter.mode, mask.mode, DMX_FILTER_SIZE);
+#endif
        
        res = ::ioctl(fd, DMX_SET_FILTER, &sct);
        if (!res)
+       {
+#if HAVE_DVB_API_VERSION < 3
+               res = ::ioctl(fd, DMX_SET_NEGFILTER_MASK, mask.mode);
+               if (!res)
+               {
+                       res = ::ioctl(fd, DMX_START, 0);
+                       if (!res)
+                               active = 1;
+               }
+#else
                active = 1;
+#endif
+       }
        return res;
 }
 
@@ -126,6 +157,6 @@ RESULT eDVBSectionReader::stop()
 
 RESULT eDVBSectionReader::connectRead(const Slot1<void,const __u8*> &r, ePtr<eConnection> &conn)
 {
-       conn = new eConnection(read.connect(r));
+       conn = new eConnection(this, read.connect(r));
        return 0;
 }