git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fixed refcount of eListboxPythonStringContent
[enigma2.git]
/
lib
/
dvb
/
demux.cpp
diff --git
a/lib/dvb/demux.cpp
b/lib/dvb/demux.cpp
index be9ac937b04905ffb7dfc037f1ef19e55a52d0a7..286821c318992999b4716d73cd4a841d7232cc52 100644
(file)
--- a/
lib/dvb/demux.cpp
+++ b/
lib/dvb/demux.cpp
@@
-1,10
+1,16
@@
+#include <config.h>
#include <stdio.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include <errno.h>
#include <unistd.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>
#include <linux/dvb/dmx.h>
+#endif
+
#include "crc32.h"
#include <lib/base/eerror.h>
#include "crc32.h"
#include <lib/base/eerror.h>
@@
-13,7
+19,7
@@
#include <lib/dvb/esection.h>
#include <lib/dvb/decoder.h>
#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);
}
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];
{
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);
sprintf(filename, "/dev/dvb/adapter%d/demux%d", demux->adapter, demux->demux);
+#endif
fd = ::open(filename, O_RDWR);
if (fd >= 0)
fd = ::open(filename, O_RDWR);
if (fd >= 0)
@@
-92,11
+102,18
@@
RESULT eDVBSectionReader::start(const eDVBSectionFilterMask &mask)
if (fd < 0)
return -ENODEV;
if (fd < 0)
return -ENODEV;
+#if HAVE_DVB_API_VERSION < 3
+ dmxSctFilterParams sct;
+#else
dmx_sct_filter_params sct;
dmx_sct_filter_params sct;
-
+#endif
sct.pid = mask.pid;
sct.timeout = 0;
sct.pid = mask.pid;
sct.timeout = 0;
+#if HAVE_DVB_API_VERSION < 3
+ sct.flags = 0;
+#else
sct.flags = DMX_IMMEDIATE_START;
sct.flags = DMX_IMMEDIATE_START;
+#endif
if (mask.flags & eDVBSectionFilterMask::rfCRC)
{
sct.flags |= DMX_CHECK_CRC;
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);
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);
memcpy(sct.filter.mode, mask.mode, DMX_FILTER_SIZE);
+#endif
res = ::ioctl(fd, DMX_SET_FILTER, &sct);
if (!res)
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;
active = 1;
+#endif
+ }
return res;
}
return res;
}