X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FProtocols%2FDVB%2FDVBDemuxHandles.cc;h=f71251e0d3f0a10c2f2a7e90609bec0696ab4004;hb=fd3a0e8ac95d1158e9ea661ddf9187b67c70169f;hp=3a66a06246f2306c037323f2f08b2e0d57ca5ac9;hpb=34199e3d9e56891d51d497fc2367d14258fa0c37;p=senf.git diff --git a/Socket/Protocols/DVB/DVBDemuxHandles.cc b/Socket/Protocols/DVB/DVBDemuxHandles.cc index 3a66a06..f71251e 100644 --- a/Socket/Protocols/DVB/DVBDemuxHandles.cc +++ b/Socket/Protocols/DVB/DVBDemuxHandles.cc @@ -33,6 +33,7 @@ #include #include "../../../Utils/Exception.hh" + //#include "DVBDemuxHandles.mpp" #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// @@ -43,8 +44,7 @@ prefix_ void senf::DVBDemuxSectionSocketProtocol::init_client(unsigned short adapter, unsigned short device) const { - std::string devDemux = str( boost::format( - "/dev/dvb/adapter%d/demux%d") % adapter % device); + std::string devDemux = str( boost::format("/dev/dvb/adapter%d/demux%d") % adapter % device); int f = open(devDemux.c_str(), O_RDONLY | O_NONBLOCK); if (f < 0){ SENF_THROW_SYSTEM_EXCEPTION("Could not open demux device of DVB adapter ") << devDemux << "."; @@ -58,20 +58,19 @@ prefix_ unsigned senf::DVBDemuxSectionSocketProtocol::available() return 4096; } -prefix_ void senf::DVBDemuxSectionSocketProtocol::setSectionFilter(unsigned short int pid, unsigned int timeout, unsigned int flags, unsigned char filter, unsigned char mask, unsigned char mode) +prefix_ void senf::DVBDemuxSectionSocketProtocol::setSectionFilter(unsigned short int pid, unsigned char filter, unsigned int flags, unsigned char mask, unsigned char mode, unsigned int timeout) const { struct dmx_sct_filter_params sec_filter; ::memset(&sec_filter, 0, sizeof(struct dmx_sct_filter_params)); - - sec_filter.pid = pid; - sec_filter.filter.filter[0] = filter; - sec_filter.filter.mask[0] = mask; - sec_filter.filter.mode[0] = mode; - sec_filter.flags = flags; + sec_filter.pid = pid; + sec_filter.filter.filter[0] = filter; + sec_filter.filter.mask[0] = mask; + sec_filter.filter.mode[0] = mode; + sec_filter.flags = flags; - if (::ioctl(fd(), DMX_SET_FILTER, filter) < 0) - SENF_THROW_SYSTEM_EXCEPTION("Could not set section filter of DVB adapter."); + if (::ioctl(fd(), DMX_SET_FILTER, &sec_filter) < 0) + SENF_THROW_SYSTEM_EXCEPTION("Could not set section filter of DVB adapter."); } // ---------------------------------------------------------------- @@ -93,10 +92,19 @@ prefix_ unsigned senf::DVBDemuxPESSocketProtocol::available() return 4096; //??? } -prefix_ void senf::DVBDemuxPESSocketProtocol::setPESFilter(struct dmx_pes_filter_params *filter) +prefix_ void senf::DVBDemuxPESSocketProtocol::setPESFilter(unsigned short int pid, dmx_input_t input, dmx_output_t output, dmx_pes_type_t pesType, unsigned int flags) const { - if (::ioctl(fd(), DMX_SET_PES_FILTER, filter) < 0) + + struct dmx_pes_filter_params pes_filter; + ::memset(&pes_filter, 0, sizeof(struct dmx_pes_filter_params)); + pes_filter.pid = pid; + pes_filter.input = input; + pes_filter.output = output; + pes_filter.pes_type = pesType; + pes_filter.flags = flags; + + if (::ioctl(fd(), DMX_SET_PES_FILTER, &pes_filter) < 0) SENF_THROW_SYSTEM_EXCEPTION("Could not set PES filter of DVB adapter."); }