Move sourcecode into 'senf/' directory
[senf.git] / senf / Socket / Protocols / DVB / DVBFrontendHandle.cc
diff --git a/senf/Socket/Protocols/DVB/DVBFrontendHandle.cc b/senf/Socket/Protocols/DVB/DVBFrontendHandle.cc
new file mode 100644 (file)
index 0000000..bb63f70
--- /dev/null
@@ -0,0 +1,279 @@
+// $Id$
+//
+// Copyright (C) 2007
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
+//     Anton Gillert <atx@berlios.de>
+//     Thorsten Horstmann <tho@berlios.de>
+//
+// This program is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the
+// Free Software Foundation, Inc.,
+// 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+
+/** \file
+    \brief DVBFrontendHandle non-inline non-template implementation */
+
+#include "DVBFrontendHandle.hh"
+//#include "DVBFrontendHandle.ih"
+
+// Custom includes
+#include <boost/format.hpp>
+#include <sys/socket.h>
+#include "../../../Utils/Exception.hh"
+#include <sys/ioctl.h>
+
+
+//#include "DVBFrontendHandle.mpp"
+#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
+
+///////////////////////////////////////////////////////////////////////////
+// senf::DVBFrontendHandle
+using namespace std;
+
+prefix_ void senf::DVBFrontendSocketProtocol::init_client(unsigned short adapter, unsigned short device, int flags)
+    const
+{
+    string devFrontend = str( boost::format("/dev/dvb/adapter%d/frontend%d") % adapter % device);
+    int f = open(devFrontend.c_str(), flags);
+    if (f < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("")<< "Could not open frontend device of DVB adapter " << devFrontend << ".";
+    fd(f);
+}
+
+prefix_ unsigned senf::DVBFrontendSocketProtocol::available()
+    const
+{
+    return 0;
+}
+
+prefix_ bool senf::DVBFrontendSocketProtocol::eof()
+    const
+{
+    return false;
+}
+
+prefix_ void senf::DVBFrontendSocketProtocol::tune(const struct dvb_frontend_parameters & frontend)
+    const 
+{
+    // tuning
+    if (::ioctl(fd(), FE_SET_FRONTEND, &frontend) )
+        SENF_THROW_SYSTEM_EXCEPTION("") << "ioctl FE_SET_FRONTEND failed. Socket should initialized with r/w permissions.";;
+}
+
+prefix_ void senf::DVBFrontendSocketProtocol::tuneDVB_T(unsigned int frequency, 
+        fe_spectral_inversion_t inversion,
+        fe_bandwidth_t bandwidth, 
+        fe_code_rate_t code_rate_HP, /* high priority stream code rate */
+        fe_code_rate_t code_rate_LP, /* low priority stream code rate */
+        fe_modulation_t constellation, /* modulation type */
+        fe_transmit_mode_t transmission_mode, 
+        fe_guard_interval_t guard_interval,
+        fe_hierarchy_t hierarchy_information
+        )
+    const
+{
+    struct dvb_ofdm_parameters ofdm; /* DVB-T Parameters */
+    struct dvb_frontend_parameters frontend;
+    
+    ::memset(&frontend, 0, sizeof(struct dvb_frontend_parameters));
+    ::memset(&ofdm, 0, sizeof(struct dvb_ofdm_parameters));
+    
+    ofdm.bandwidth = bandwidth;
+    ofdm.code_rate_HP = code_rate_HP;
+    ofdm.code_rate_LP = code_rate_LP;
+    ofdm.constellation = constellation; 
+    ofdm.guard_interval = guard_interval;
+    ofdm.hierarchy_information = hierarchy_information;
+    
+    frontend.frequency = frequency;
+    frontend.inversion = inversion;
+    frontend.u.ofdm = ofdm;
+    
+    tune(frontend);
+    
+}
+prefix_ void senf::DVBFrontendSocketProtocol::tuneDVB_S(unsigned int frequency, 
+        fe_spectral_inversion_t inversion, 
+        unsigned int symbole_rate, /* symbol rate in Symbols per second */
+        fe_code_rate_t fec_inner /* forward error correction (see above) */
+    )
+    const
+{
+    struct dvb_qpsk_parameters qpsk; /* DVB-S Parameters*/
+    struct dvb_frontend_parameters frontend;
+    
+    ::memset(&frontend, 0, sizeof(struct dvb_frontend_parameters));
+    ::memset(&qpsk, 0, sizeof(struct dvb_qpsk_parameters));
+    
+    qpsk.symbol_rate = symbole_rate;
+    qpsk.fec_inner = fec_inner;
+    
+    frontend.frequency = frequency;
+    frontend.inversion = inversion;
+    frontend.u.qpsk = qpsk;
+    
+    tune(frontend);
+}
+
+prefix_ void senf::DVBFrontendSocketProtocol::tuneDVB_C(unsigned int frequency, 
+        fe_spectral_inversion_t inversion,
+        unsigned int symbol_rate,
+        fe_code_rate_t fec_inner,
+        fe_modulation_t modulation
+        )
+const
+{
+    struct dvb_qam_parameters qam; /* DVB-C Parameters*/
+    struct dvb_frontend_parameters frontend;
+    
+    ::memset(&frontend, 0, sizeof(struct dvb_frontend_parameters));
+    ::memset(&qam, 0, sizeof(struct dvb_qam_parameters));
+    
+    qam.symbol_rate = symbol_rate;
+    qam.fec_inner = fec_inner;
+    qam.modulation = modulation;
+    
+    
+    frontend.frequency = frequency;
+    frontend.inversion = inversion;
+    frontend.u.qam = qam;
+       
+    tune(frontend);
+}
+prefix_ void senf::DVBFrontendSocketProtocol::setNonBlock(bool on) 
+    const
+{
+   if(on)
+       ::fcntl(fd(), F_SETFL, ::fcntl(fd(), F_GETFL) | O_NONBLOCK);
+   else
+       ::fcntl(fd(), F_SETFL, ::fcntl(fd(), F_GETFL) & ~O_NONBLOCK);
+
+}
+prefix_ dvb_frontend_info senf::DVBFrontendSocketProtocol::getInfo()
+    const
+{
+    struct dvb_frontend_info info;
+    ::memset(&info, 0, sizeof(struct dvb_frontend_info));
+    
+    if( ::ioctl(fd(), FE_GET_INFO, &info) ) {
+        SENF_THROW_SYSTEM_EXCEPTION("") << "Could not read on fildescriptor.";
+    }
+    return info;
+}
+
+prefix_ dvb_frontend_parameters senf::DVBFrontendSocketProtocol::getFrontendParam() const {
+    struct dvb_frontend_parameters frontend_;
+    
+    ::memset(&frontend_, 0, sizeof(struct dvb_frontend_parameters));
+    
+    if(::ioctl(fd(), FE_GET_FRONTEND, &frontend_)) {
+        switch(errno) {
+            case EBADF:
+                SENF_THROW_SYSTEM_EXCEPTION("fd is not a valid open file descriptor.");
+                break;
+            case EFAULT:
+                SENF_THROW_SYSTEM_EXCEPTION( "frontend_ points to invalid address." );
+                break;
+            case EINVAL:
+                SENF_THROW_SYSTEM_EXCEPTION( "Maximum supported symbol rate reached. This call may not be implemented by kernel driver!" );
+                break;
+            default:
+                SENF_THROW_SYSTEM_EXCEPTION("Errno: ") << errno;
+        }
+    }
+    return frontend_;
+}
+
+prefix_ dvb_frontend_event senf::DVBFrontendSocketProtocol::getEvent() const{
+    struct dvb_frontend_event ev ;
+    
+    ::memset(&ev, 0, sizeof(struct dvb_frontend_event));
+    
+    if(::ioctl(fd(), FE_GET_EVENT, &ev)) {
+        switch(errno) {
+            case EBADF:
+                SENF_THROW_SYSTEM_EXCEPTION("Could not read from frontend device, read-only access to the device is sufficient.");
+                break;
+            case EWOULDBLOCK:
+                SENF_THROW_SYSTEM_EXCEPTION( "No event pending and device is in nonblocking mode." );
+                break;
+            default:
+                SENF_THROW_SYSTEM_EXCEPTION("Errno: ") << errno;
+        }
+    }
+    return ev;
+}
+
+prefix_ int16_t senf::DVBFrontendSocketProtocol::signalStrength()
+    const
+{
+    int16_t strength;
+    if (::ioctl(fd(), FE_READ_SIGNAL_STRENGTH, &strength) < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("Could not get signal strength of DVB adapter.");
+    return strength;
+}
+
+prefix_ int16_t senf::DVBFrontendSocketProtocol::signalNoiseRatio()
+    const 
+{
+    int16_t snr;
+    if (::ioctl(fd(), FE_READ_SNR, &snr) < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("Could not get signal-to-noise ratio of DVB adapter.");
+    return snr;
+}
+
+prefix_ uint32_t senf::DVBFrontendSocketProtocol::bitErrorRate()
+    const
+{
+    uint32_t ber;
+    if (::ioctl(fd(), FE_READ_BER, &ber) < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("Could not get bit error rate of DVB adapter.");
+    return ber;
+}
+
+prefix_ uint32_t senf::DVBFrontendSocketProtocol::uncorrectedBlocks()
+    const
+{
+    uint32_t uncorrected_blocks;
+    if (::ioctl(fd(), FE_READ_UNCORRECTED_BLOCKS, &uncorrected_blocks) < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("Could not get bit error rate of DVB adapter.");
+    return uncorrected_blocks;
+}
+
+
+prefix_ fe_status_t senf::DVBFrontendSocketProtocol::status()
+    const
+{
+    fe_status_t status;
+    if (::ioctl(fd(), FE_READ_STATUS, &status) < 0)
+        SENF_THROW_SYSTEM_EXCEPTION("Could not get bit error rate of DVB adapter.");
+    return status;
+}
+
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_
+//#include "DVBFrontendHandle.mpp"
+
+
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// compile-command: "scons -u test"
+// comment-column: 40
+// End: