diff options
| author | Quentin Young <qlyoung@cumulusnetworks.com> | 2018-02-23 11:21:42 -0500 |
|---|---|---|
| committer | Quentin Young <qlyoung@cumulusnetworks.com> | 2018-02-23 11:23:29 -0500 |
| commit | 6b1ebf3c3c8270fa8cf8a59b3204652add55e383 (patch) | |
| tree | 7c44131002fd3e1e0e6a2c4379230693a37b74cd /lib/if.c | |
| parent | 2580e72f8d62d9094ddea2af72de222edcac4ccc (diff) | |
| parent | fb444efb6853da1baa0abbfbc4932657518fe6c3 (diff) | |
Merge branch 'master' into stylechecker
Diffstat (limited to 'lib/if.c')
| -rw-r--r-- | lib/if.c | 18 |
1 files changed, 17 insertions, 1 deletions
@@ -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; |
