]> git.puffer.fish Git - mirror/frr.git/commitdiff
bgpd: Allow inbound connections to non-default view
authorSteve Hill <quagga@cheesy.sackheads.org>
Tue, 28 Jul 2009 16:54:35 +0000 (17:54 +0100)
committerPaul Jakma <paul@quagga.net>
Tue, 28 Jul 2009 17:06:39 +0000 (18:06 +0100)
* bgpd.c: (peer_lookup) Search through all BGP instances for matches, not just
  the default instance, if no specific instance is given.
  (peer_lookup_with_open) same.

bgpd/bgpd.c

index ef8fbe9755aebf81f5260d9f9a106d32d5a5e6ff..366ee4328a9c22f49e6bce7ce7077c5b3d129e17 100644 (file)
@@ -2144,18 +2144,29 @@ peer_lookup (struct bgp *bgp, union sockunion *su)
   struct peer *peer;
   struct listnode *node, *nnode;
 
-  if (! bgp)
-    bgp = bgp_get_default ();
-
-  if (! bgp)
-    return NULL;
+  if (bgp != NULL)
+  {
+    for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
+    {
+      if (sockunion_same (&peer->su, su)
+         && ! CHECK_FLAG (peer->sflags, PEER_STATUS_ACCEPT_PEER))
+       return peer;
+    }
+  }
+  else if (bm->bgp != NULL)
+  {
+    struct listnode *bgpnode, *nbgpnode;
   
+    for(ALL_LIST_ELEMENTS(bm->bgp, bgpnode, nbgpnode, bgp))
+    {
   for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
     {
       if (sockunion_same (&peer->su, su)
          && ! CHECK_FLAG (peer->sflags, PEER_STATUS_ACCEPT_PEER))
        return peer;
     }
+    }
+  }
   return NULL;
 }
 
@@ -2165,12 +2176,14 @@ peer_lookup_with_open (union sockunion *su, as_t remote_as,
 {
   struct peer *peer;
   struct listnode *node, *nnode;
+  struct listnode *bgpnode, *nbgpnode;
   struct bgp *bgp;
 
-  bgp = bgp_get_default ();
-  if (! bgp)
+  if (! bm->bgp)
     return NULL;
 
+  for(ALL_LIST_ELEMENTS(bm->bgp, bgpnode, nbgpnode, bgp))
+  {
   for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
     {
       if (sockunion_same (&peer->su, su)
@@ -2183,6 +2196,7 @@ peer_lookup_with_open (union sockunion *su, as_t remote_as,
            *as = 1;
        }
     }
+
   for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
     {
       if (sockunion_same (&peer->su, su)
@@ -2195,6 +2209,7 @@ peer_lookup_with_open (union sockunion *su, as_t remote_as,
            *as = 1;
        }
     }
+  }
   return NULL;
 }
 \f