summaryrefslogtreecommitdiff
path: root/lib/if.c
diff options
context:
space:
mode:
authorQuentin Young <qlyoung@cumulusnetworks.com>2018-02-23 11:21:42 -0500
committerQuentin Young <qlyoung@cumulusnetworks.com>2018-02-23 11:23:29 -0500
commit6b1ebf3c3c8270fa8cf8a59b3204652add55e383 (patch)
tree7c44131002fd3e1e0e6a2c4379230693a37b74cd /lib/if.c
parent2580e72f8d62d9094ddea2af72de222edcac4ccc (diff)
parentfb444efb6853da1baa0abbfbc4932657518fe6c3 (diff)
Merge branch 'master' into stylechecker
Diffstat (limited to 'lib/if.c')
-rw-r--r--lib/if.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/lib/if.c b/lib/if.c
index 0fe7da1c0d..7866ddb8c4 100644
--- a/lib/if.c
+++ b/lib/if.c
@@ -210,6 +210,9 @@ void if_delete(struct interface *ifp)
if_link_params_free(ifp);
+ if (ifp->desc)
+ XFREE(MTYPE_TMP, ifp->desc);
+
XFREE(MTYPE_IF, ifp);
}
@@ -219,6 +222,18 @@ struct interface *if_lookup_by_index(ifindex_t ifindex, vrf_id_t vrf_id)
struct vrf *vrf;
struct interface if_tmp;
+ if (vrf_id == VRF_UNKNOWN) {
+ struct interface *ifp;
+
+ RB_FOREACH(vrf, vrf_id_head, &vrfs_by_id) {
+ ifp = if_lookup_by_index(ifindex, vrf->vrf_id);
+ if (ifp)
+ return ifp;
+ }
+
+ return NULL;
+ }
+
vrf = vrf_lookup_by_id(vrf_id);
if (!vrf)
return NULL;
@@ -663,8 +678,9 @@ DEFUN_NOSH (no_interface,
"Interface's name\n"
VRF_CMD_HELP_STR)
{
+ int idx_vrf = 4;
const char *ifname = argv[2]->arg;
- const char *vrfname = (argc > 3) ? argv[3]->arg : NULL;
+ const char *vrfname = (argc > 3) ? argv[idx_vrf]->arg : NULL;
// deleting interface
struct interface *ifp;