reelchannelscan for S2API-patched VDR

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

I patched the reelchannelscan-plugin to compile with my patched S2API-VDR.

What I use:
VDR 1.7.1 with
 - vdr-1.7.1_extensions.diff
 - vdr-1.7.1-ext_h264.diff
 - vdr-1.7.1-s2api-ext64.patch

reelchannelscan-plugin from svn
svn co svn://reelbox.org/testing/src/vdr-plugins/src/channelscan-0.6.1
-r9031

and my attached patch.

Beware: I DON'T KNOW WHAT I AM DOING HERE!
It compiles, it scans transponder and finds channels.
It works for me, but I'm no C or C++ programmer...

--
Frank Scherthan

diff -Nu channelscan-0.6.1/channelscan.c channelscan-0.6.1_fks/channelscan.c
--- channelscan-0.6.1/channelscan.c	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/channelscan.c	2008-10-17 13:57:11.000000000 +0200
@@ -74,9 +74,11 @@
 #ifdef REELVDR
     SetupStore("ServiceType", "channelscan", ScanSetup.ServiceType);
     SetupStore("Logfile", "channelscan", ScanSetup.EnableLogfile);
+	SetupStore("AddNewChannels", "channelscan", ScanSetup.AddNewChannels);
 #else
     SetupStore("ServiceType", ScanSetup.ServiceType);
     SetupStore("Logfile", ScanSetup.EnableLogfile);
+	SetupStore("AddNewChannels", ScanSetup.AddNewChannels);
 #endif
 }
 
diff -Nu channelscan-0.6.1/channelscan.h channelscan-0.6.1_fks/channelscan.h
--- channelscan-0.6.1/channelscan.h	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/channelscan.h	2008-10-17 07:46:26.000000000 +0200
@@ -49,6 +49,8 @@
     int ServiceType;
     int EnableLogfile;
       std::string logfile;
+    int AddNewChannels;
+
 };
 
 
diff -Nu channelscan-0.6.1/csmenu.c channelscan-0.6.1_fks/csmenu.c
--- channelscan-0.6.1/csmenu.c	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/csmenu.c	2008-10-17 07:46:24.000000000 +0200
@@ -164,7 +164,7 @@
     addNewChannelsToTexts[1] = tr("new channellist");
     addNewChannelsToTexts[2] = tr("bouquets");
 
-    addNewChannelsTo = Setup.AddNewChannels==1?2:0;
+    addNewChannelsTo = ScanSetup.AddNewChannels==1?2:0;
 
     scanMode = 1;               // auto scan
 
@@ -241,7 +241,8 @@
 
             else if (device->ProvidesSource(cSource::stSat))
             {
-                if (device->ProvidesS2())
+                //if (device->ProvidesS2())
+		if (1==1)
                 {
                     asprintf(&txt, "%s (%s %i)", tr("DVB-S2 - Satellite"),
                              tr("Tuner"), tuner + 1);
@@ -591,7 +592,7 @@
             switch( addNewChannelsTo )
             {
                 case 0:
-                    Setup.AddNewChannels = 0;
+                    ScanSetup.AddNewChannels = 0;
                     break;
                 case 1: 
                     //clear channellist
@@ -628,7 +629,7 @@
                     // fallthrough: no break
                 case 2:
                     //add to own Bouquets
-                    Setup.AddNewChannels = 1;
+                    ScanSetup.AddNewChannels = 1;
                     Setup.Save();
                     break;
                 default: 
@@ -1128,6 +1129,9 @@
     }
 }
 
+
+bool scanning_on_receiving_device;
+
 cMenuScanActive::~cMenuScanActive()
 {
     Scan->ShutDown();
diff -Nu channelscan-0.6.1/filter.c channelscan-0.6.1_fks/filter.c
--- channelscan-0.6.1/filter.c	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/filter.c	2008-10-17 07:46:25.000000000 +0200
@@ -677,7 +677,7 @@
                 }
             }
 #if APIVERSNUM >= 10509 || defined(REELVDR)
-            Channel->SetPids(Vpid, Vpid ? Ppid : 0, Apids, ALangs, Dpids,
+            Channel->SetPids(Vpid, Vpid ? Ppid : 0, 0, Apids, ALangs, Dpids,
                              DLangs, Spids, SLangs, Tpid);
 #else
             Channel->SetPids(Vpid, Vpid ? Ppid : 0, Apids, ALangs, Dpids,
@@ -1233,7 +1233,7 @@
 
                     // same as in channels.c
                     static int CodeRates[] = { FEC_NONE, FEC_1_2, FEC_2_3, FEC_3_4, FEC_4_5, FEC_5_6, FEC_6_7, FEC_7_8, FEC_8_9,        // DVB-S
-                        FEC_1_3, FEC_1_4, FEC_2_5, FEC_3_5, FEC_9_10,
+                        FEC_9_10,
                             FEC_AUTO, FEC_AUTO, FEC_AUTO, FEC_AUTO, FEC_AUTO,
                             FEC_NONE
                     };          // DVB-S2
@@ -1255,8 +1255,8 @@
                                ts.getOriginalNetworkId());
 
                         static int Rolloffs[] =
-                            { FE_ROLLOFF_35, FE_ROLLOFF_25, FE_ROLLOFF_20,
-            FE_ROLLOFF_35 };
+                            { ROLLOFF_35, ROLLOFF_25, ROLLOFF_20,
+            ROLLOFF_35 };
 
 
                         int Modulation = QPSK;
@@ -1267,7 +1267,7 @@
                          */
 
                         static int ModulationsS2[] =
-                            { QPSK, QPSK_S2, PSK8, QPSK,
+                            { QPSK, PSK_8, QPSK,
                             QPSK, QPSK, QPSK, QPSK
                         };      // DVB-S2
 
Gemeinsame Unterverzeichnisse: channelscan-0.6.1/patches und channelscan-0.6.1_fks/patches.
Gemeinsame Unterverzeichnisse: channelscan-0.6.1/po und channelscan-0.6.1_fks/po.
diff -Nu channelscan-0.6.1/scan.c channelscan-0.6.1_fks/scan.c
--- channelscan-0.6.1/scan.c	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/scan.c	2008-10-17 07:46:26.000000000 +0200
@@ -405,7 +405,8 @@
 cScan::ScanDVB_S(cTransponder * tp, cChannel * c)
 {
   //const time_t tt = time(NULL);
-    int maxmods = device->ProvidesS2()? 4 : 2;
+//     int maxmods = device->ProvidesS2()? 3 : 1;
+    int maxmods =  3;
 
    // esyslog("%s cTransponder* tp = %x  cChannel *c = %x", __PRETTY_FUNCTION__);
     esyslog("maxmods = %d",maxmods);
@@ -415,7 +416,7 @@
         ;
 
     // skip HD Transonders on SD Tuner
-    if ( !device->ProvidesS2() && static_cast < cSatTransponder * >(tp)->System() == 1)
+    if (maxmods == 1 && static_cast < cSatTransponder * >(tp)->System() == 1)
         return;
 
   unsigned  int nRadio = radioChannelNames.size();
@@ -442,24 +443,20 @@
                        tp->Frequency(), tp->Symbolrate(), tp->Modulation());
             break;
         case 1:
-            tp->SetModulation(QPSK);
-            break;
-
-        case 2:
-            tp->SetModulation(PSK8);
+            tp->SetModulation(PSK_8);
             //static_cast < cSatTransponder * >(tp)->SetFEC(FEC_2_3);
-            static_cast < cSatTransponder * >(tp)->SetRollOff(FE_ROLLOFF_35);
+            static_cast < cSatTransponder * >(tp)->SetRollOff(ROLLOFF_35);
             DEBUG_SCAN
                 (" DEBUG [DVB_S]; trying PSK8: freq: %d srate:%d   mod: %d  \n",
                  tp->Frequency(), tp->Symbolrate(), tp->Modulation());
 
             break;
-        case 3:
-            tp->SetModulation(QPSK_S2);
+        case 2:
+            tp->SetModulation(QPSK);
             //static_cast < cSatTransponder * >(tp)->SetFEC(FEC_9_10);
-            static_cast < cSatTransponder * >(tp)->SetRollOff(FE_ROLLOFF_35);
+            static_cast < cSatTransponder * >(tp)->SetRollOff(ROLLOFF_35);
             DEBUG_SCAN
-                (" DEBUG [DVB_S]; trying QPSK_S2: freq: %d srate:%d   mod: %d  \n",
+                (" DEBUG [DVB_S]; trying QPSK: freq: %d srate:%d   mod: %d  \n",
                  tp->Frequency(), tp->Symbolrate(), tp->Modulation());
             break;
         default:
Gemeinsame Unterverzeichnisse: channelscan-0.6.1/.svn und channelscan-0.6.1_fks/.svn.
Gemeinsame Unterverzeichnisse: channelscan-0.6.1/transponders und channelscan-0.6.1_fks/transponders.
diff -Nu channelscan-0.6.1/transponders.c channelscan-0.6.1_fks/transponders.c
--- channelscan-0.6.1/transponders.c	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/transponders.c	2008-10-17 07:46:25.000000000 +0200
@@ -191,10 +191,10 @@
     int stat2fecs2[] = {
         FEC_AUTO,
         FEC_1_2,
-        FEC_1_3, //S2
-        FEC_1_4, //S2
+//         FEC_1_3, //S2
+//         FEC_1_4, //S2
         FEC_2_3,
-        FEC_2_5, //S2
+//         FEC_2_5, //S2
         FEC_3_4,
         FEC_3_5, //S2
         FEC_4_5,
@@ -219,9 +219,9 @@
     case 0:
         return 0;               // auto  (SD only)
     case 1:
-        return QPSK_S2;
+        return QPSK;
     case 2:
-        return PSK8;
+        return PSK_8;
     case 3:
         return VSB_8;
     case 4:
@@ -229,7 +229,7 @@
     case 5:
         return 999;             // try all
     }
-    return PSK8;
+    return PSK_8;
 }
 
 //----------- Class cSatTransponder -------------------------------
@@ -252,14 +252,17 @@
                       frequency_, pol_, symbolrate_, modulation_, fec_);
 }
 
+//extern bool VagHackIsS2;
+
 bool
 cSatTransponder::SetTransponderData(cChannel * c, int Code)
 {
     DEBUG_TRANSPONDER(DBGT
                       " SetSatTransponderData(source:%d,f:%6d,p:%c,sRate:%d,mod%3d,fec%d \n",
                       Code, frequency_, pol_, symbolrate_, modulation_, fec_);
-    return c->SetSatTransponderData(Code, frequency_, pol_, symbolrate_, fec_,
-                                    modulation_, rolloff_);
+//    return c->SetSatTransponderData(Code, frequency_, pol_, symbolrate_, fec_,
+//                                    modulation_, rolloff_);
+return c->SetSatTransponderData(Code, frequency_, pol_, symbolrate_, FEC_AUTO, QPSK, SYS_DVBS, ROLLOFF_AUTO); 
 }
 
 
@@ -360,7 +363,10 @@
     else
         bandwidth_ = BANDWIDTH_8_MHZ;
 
-    return c->SetTerrTransponderData(type, frequency_, bandwidth_, modulation_, hierarchy_, fec_h_, fec_l_, guard_, transmission_);     //
+//    return c->SetTerrTransponderData(type, frequency_, bandwidth_, modulation_, hierarchy_, fec_h_, fec_l_, guard_, transmission_);     //
+
+return c->SetTerrTransponderData(type, frequency_, bandwidth_, modulation_, 
+hierarchy_, fec_h_, fec_l_, guard_, transmission_);
 
 }
 
diff -Nu channelscan-0.6.1/transponders.h channelscan-0.6.1_fks/transponders.h
--- channelscan-0.6.1/transponders.h	2008-10-17 14:33:07.000000000 +0200
+++ channelscan-0.6.1_fks/transponders.h	2008-10-17 07:46:25.000000000 +0200
@@ -106,7 +106,7 @@
     }
     int  ChannelNum() const;
     int  Frequency() const;
-    int  Modulation()
+    int  Modulation()	
     {
         return modulation_;
     };
@@ -195,6 +195,7 @@
     int FEC() const;
     void SetRollOff(int rolloff);
     void SetFEC(int fec);
+    void SetSystem(int syst) {system_=syst;};
     int System() const;
     bool Parse(const std::string & line);
     /* over write */ void PrintData();
_______________________________________________
vdr mailing list
vdr@xxxxxxxxxxx
http://www.linuxtv.org/cgi-bin/mailman/listinfo/vdr

[Index of Archives]     [Linux Media]     [Asterisk]     [DCCP]     [Netdev]     [Xorg]     [Util Linux NG]     [Xfree86]     [Big List of Linux Books]     [Fedora Users]     [Fedora Women]     [ALSA Devel]     [Linux USB]

  Powered by Linux