]> git.rkrishnan.org Git - pihpsdr.git/commitdiff
use loopback interface if its the only one up-and-running.
authorc vw <dl1ycf@darc.de>
Mon, 20 Jan 2020 09:21:04 +0000 (10:21 +0100)
committerc vw <dl1ycf@darc.de>
Mon, 20 Jan 2020 09:21:04 +0000 (10:21 +0100)
new_discovery.c
old_discovery.c

index 4d7a4975d362f7394ae034ce5b19fa54e7b35bf5..3fba2ea9c509cbd3dddb3aa1fb2b8af5d02f6357 100644 (file)
@@ -71,14 +71,37 @@ void new_discovery() {
     struct ifaddrs *addrs,*ifa;
     getifaddrs(&addrs);
     ifa = addrs;
+
+//
+//  count number of "up and running" interfaces
+//
+    int num_up_and_running = 0;
+    while (ifa) {
+      if (ifa->ifa_addr) {
+        if (ifa->ifa_addr->sa_family == AF_INET
+            && (ifa->ifa_flags & IFF_UP) == IFF_UP
+            && (ifa->ifa_flags & IFF_RUNNING) == IFF_RUNNING) {
+                num_up_and_running++;
+        }
+      }
+      ifa=ifa->ifa_next;
+    }
+
+    ifa=addrs;
     while (ifa) {
         g_main_context_iteration(NULL, 0);
-        if (ifa->ifa_addr && ifa->ifa_addr->sa_family == AF_INET) {
-            if((ifa->ifa_flags&IFF_UP)==IFF_UP
-                && (ifa->ifa_flags&IFF_RUNNING)==IFF_RUNNING
-                && (ifa->ifa_flags&IFF_LOOPBACK)!=IFF_LOOPBACK) {
-                new_discover(ifa);
-            }
+        if (ifa->ifa_addr) {
+          if(ifa->ifa_addr->sa_family == AF_INET &&
+            (ifa->ifa_flags&IFF_UP)==IFF_UP &&
+            (ifa->ifa_flags&IFF_RUNNING)==IFF_RUNNING) {
+//
+// if this is the loopback interface, do the discover only if
+// there is at most one interface
+//
+                if ((ifa->ifa_flags & IFF_LOOPBACK) != IFF_LOOPBACK
+                    || num_up_and_running <= 1)
+                                new_discover(ifa);
+          }
         }
         ifa = ifa->ifa_next;
     }
index 9f065b743302ba42c4b8982dba0e2d75cd0fa1ef..82b4230155fb51d2099d34dd9362db2ebae10c11 100644 (file)
@@ -515,33 +515,41 @@ void old_discovery() {
 fprintf(stderr,"old_discovery\n");
     getifaddrs(&addrs);
     ifa = addrs;
+//
+//  count number of "up and running" interfaces
+//
+    int num_up_and_running = 0;
+    while (ifa) {
+      if (ifa->ifa_addr) {
+       if (ifa->ifa_addr->sa_family == AF_INET
+           && (ifa->ifa_flags & IFF_UP) == IFF_UP
+            && (ifa->ifa_flags & IFF_RUNNING) == IFF_RUNNING) {
+               num_up_and_running++;
+       }
+      }
+      ifa=ifa->ifa_next;
+    }
+       
+    ifa=addrs;
     while (ifa) {
         g_main_context_iteration(NULL, 0);
-        if (ifa->ifa_addr && ifa->ifa_addr->sa_family == AF_INET) {
-#if 0
+        if (ifa->ifa_addr) {
+         if(ifa->ifa_addr->sa_family == AF_INET &&
+            (ifa->ifa_flags&IFF_UP)==IFF_UP &&
+            (ifa->ifa_flags&IFF_RUNNING)==IFF_RUNNING) {
 //
-// used to be a hook for RADIOBERRY, but does is really need the
-// loopback interface?
+// if this is the loopback interface, do the discover only if
+// there is at most one interface
 //
-                       if((ifa->ifa_flags&IFF_UP)==IFF_UP
-                && (ifa->ifa_flags&IFF_RUNNING)==IFF_RUNNING) {
+               if ((ifa->ifa_flags & IFF_LOOPBACK) != IFF_LOOPBACK
+                   || num_up_and_running <= 1)
                                discover(ifa);
-                       }
-#else
-            if((ifa->ifa_flags&IFF_UP)==IFF_UP
-                && (ifa->ifa_flags&IFF_RUNNING)==IFF_RUNNING
-                && (ifa->ifa_flags&IFF_LOOPBACK)!=IFF_LOOPBACK) {
-                discover(ifa);
-            }
-#endif 
+         }
         }
         ifa = ifa->ifa_next;
     }
     freeifaddrs(addrs);
 
-    // Do one additional "discover" for a fixed TCP address
-    discover(NULL);
-
     fprintf(stderr, "discovery found %d devices\n",devices);
 
     int i;