]> git.puffer.fish Git - matthieu/frr.git/commitdiff
lib: add utility to get the next index in a vrf
authorPat Ruddy <pat@voltanet.io>
Thu, 1 Oct 2020 11:06:50 +0000 (12:06 +0100)
committerPat Ruddy <pat@voltanet.io>
Tue, 2 Feb 2021 09:37:08 +0000 (09:37 +0000)
Add if_vrf_lookup_by_index_next to get the next ifindex in a vrf
given the previous ifindex or 0 for the first.

Signed-off-by: Pat Ruddy <pat@voltanet.io>
lib/if.c
lib/if.h

index fa0b1d0195adfd06fd2b9c59fa2bc74b0b14dd86..7ec53d356d9b6ea224b3f7ea70c0c8610deb5e05 100644 (file)
--- a/lib/if.c
+++ b/lib/if.c
@@ -351,6 +351,40 @@ struct interface *if_lookup_by_index(ifindex_t ifindex, vrf_id_t vrf_id)
        return NULL;
 }
 
+/* Interface existance check by index. */
+struct interface *if_vrf_lookup_by_index_next(ifindex_t ifindex,
+                                             vrf_id_t vrf_id)
+{
+       struct vrf *vrf = vrf_lookup_by_id(vrf_id);
+       struct interface *tmp_ifp;
+       bool found = false;
+
+       if (!vrf)
+               return NULL;
+
+       if (ifindex == 0) {
+               tmp_ifp = RB_MIN(if_index_head, &vrf->ifaces_by_index);
+               /* skip the vrf interface */
+               if (tmp_ifp && if_is_vrf(tmp_ifp))
+                       ifindex = tmp_ifp->ifindex;
+               else
+                       return tmp_ifp;
+       }
+
+       RB_FOREACH (tmp_ifp, if_index_head, &vrf->ifaces_by_index) {
+               if (found) {
+                       /* skip the vrf interface */
+                       if (tmp_ifp && if_is_vrf(tmp_ifp))
+                               continue;
+                       else
+                               return tmp_ifp;
+               }
+               if (tmp_ifp->ifindex == ifindex)
+                       found = true;
+       }
+       return NULL;
+}
+
 const char *ifindex2ifname(ifindex_t ifindex, vrf_id_t vrf_id)
 {
        struct interface *ifp;
index a2a40d0957240f65204bceccf5051b707adcf7e4..5bf52936aebec7f2ac724accb4da87ac35fedbda 100644 (file)
--- a/lib/if.h
+++ b/lib/if.h
@@ -513,6 +513,8 @@ extern struct interface *if_create_name(const char *name, vrf_id_t vrf_id);
 /* Create new interface, adds to index list only */
 extern struct interface *if_create_ifindex(ifindex_t ifindex, vrf_id_t vrf_id);
 extern struct interface *if_lookup_by_index(ifindex_t, vrf_id_t vrf_id);
+extern struct interface *if_vrf_lookup_by_index_next(ifindex_t ifindex,
+                                                    vrf_id_t vrf_id);
 extern struct interface *if_lookup_by_index_all_vrf(ifindex_t);
 extern struct interface *if_lookup_exact_address(const void *matchaddr,
                                                 int family, vrf_id_t vrf_id);