X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/967664233fc4ce992405a0e86e0c6cd594dfba57..df7d9f3578c68b22c95ab9daa23bd0fa168f6d11:/lib/dvb/frontend.h diff --git a/lib/dvb/frontend.h b/lib/dvb/frontend.h index 9036dc3e..2cccf885 100644 --- a/lib/dvb/frontend.h +++ b/lib/dvb/frontend.h @@ -1,12 +1,14 @@ #ifndef __dvb_frontend_h #define __dvb_frontend_h -#include #include +#include + +class eSecCommandList; class eDVBFrontendParameters: public iDVBFrontendParameters { - DECLARE_REF; + DECLARE_REF(eDVBFrontendParameters); union { eDVBFrontendParametersSatellite sat; @@ -22,9 +24,9 @@ public: RESULT getDVBC(eDVBFrontendParametersCable &p) const; RESULT getDVBT(eDVBFrontendParametersTerrestrial &p) const; - RESULT setDVBS(eDVBFrontendParametersSatellite &p); - RESULT setDVBC(eDVBFrontendParametersCable &p); - RESULT setDVBT(eDVBFrontendParametersTerrestrial &p); + RESULT setDVBS(const eDVBFrontendParametersSatellite &p); + RESULT setDVBC(const eDVBFrontendParametersCable &p); + RESULT setDVBT(const eDVBFrontendParametersTerrestrial &p); RESULT calculateDifference(const iDVBFrontendParameters *parm, int &diff) const; @@ -33,21 +35,50 @@ public: class eDVBFrontend: public iDVBFrontend, public Object { - DECLARE_REF; + DECLARE_REF(eDVBFrontend); int m_type; + int m_fe; int m_fd; + char m_filename[128]; #if HAVE_DVB_API_VERSION < 3 int m_secfd; + char m_sec_filename[128]; #endif + + FRONTENDPARAMETERS parm; int m_state; Signal1 m_stateChanged; ePtr m_sec; eSocketNotifier *m_sn; int m_tuning; eTimer *m_timeout; - + eTimer *m_tuneTimer; + + eSecCommandList m_sec_sequence; + + int m_data[9]; /* when satellite frontend then + data[0] = lastcsw -> state of the committed switch + data[1] = lastucsw -> state of the uncommitted switch + data[2] = lastToneburst -> current state of toneburst switch + data[3] = newRotorCmd -> last sent rotor cmd + data[4] = newRotorPos -> current Rotor Position + data[5] = curRotorCmd + data[6] = curRotorPos + data[7] = linkedToTunerNo + data[8] = dependsToTunerNo (just satpos.. for rotor with twin lnb) */ + + int m_idleInputpower[2]; // 13V .. 18V + int m_runningInputpower; + int m_timeoutCount; // needed for timeout + int m_retryCount; // diseqc retry for rotor + int m_curVoltage; + void feEvent(int); void timeout(); + void tuneLoop(); // called by m_tuneTimer + void setFrontend(); + int readInputpower(); + bool setSecSequencePos(int steps); public: eDVBFrontend(int adap, int fe, int &ok); virtual ~eDVBFrontend(); @@ -59,7 +90,18 @@ public: RESULT setTone(int tone); RESULT setVoltage(int voltage); RESULT sendDiseqc(const eDVBDiseqcCommand &diseqc); + RESULT sendToneburst(int burst); RESULT setSEC(iDVBSatelliteEquipmentControl *sec); + RESULT setSecSequence(const eSecCommandList &list); + RESULT getData(int num, int &data); + RESULT setData(int num, int val); + + int readFrontendData(int type); // bitErrorRate, signalPower, signalQuality + int isCompatibleWith(ePtr &feparm); + int getID() { return m_fe; } + + int openFrontend(); + int closeFrontend(); }; #endif